Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 32e4f092 authored by Gaurav Gagrani's avatar Gaurav Gagrani
Browse files

ARM: dts: msm: Add 8929 gpu dtsi files



In 8929 gpu will run on 465Mhz, 400Mhz, 220Mhz.
BIMC will be running at max 331.2 Mhz

Change-Id: I33a4a93d55d65ce1a85053f7900055e1a4e010ba
Signed-off-by: default avatarGaurav Gagrani <ggagrani@codeaurora.org>
parent 1a15b14b
Loading
Loading
Loading
Loading
+135 −0
Original line number Diff line number Diff line
/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 and
 * only version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 */

&soc {

	/* To use BIMC based bus governor */
	gpubw: qcom,gpubw {
		compatible = "qcom,devbw";
		governor = "bw_hwmon";
		qcom,src-dst-ports = <26 512>;
		qcom,bw-tbl =
			< 146 >,	/* 9.6 MHz */
			< 1977 >,	/* 129.6 MHz */
			< 2673 >,	/* 175.2 MHz */
			< 3076 >,	/* 201.6 MHz */
			< 3955 >,	/* 259.2 MHz */
			< 5053 >;	/* 331.2 MHz*/
	};

	qcom,gpu-bwmon@410000 {
		compatible = "qcom,bimc-bwmon";
		reg = <0x00410000 0x300>, <0x00401000 0x200>;
		reg-names = "base", "global_base";
		interrupts = <0 183 4>;
		qcom,mport = <2>;
		qcom,target-dev = <&gpubw>;
	};

	msm_gpu: qcom,kgsl-3d0@1C00000 {
		label = "kgsl-3d0";
		compatible = "qcom,kgsl-3d0", "qcom,kgsl-3d";
		reg = <0x1C00000 0x10000
		       0x1C20000 0x10000>;
		reg-names = "kgsl_3d0_reg_memory" , "kgsl_3d0_shader_memory";
		interrupts = <0 33 0>;
		interrupt-names = "kgsl_3d0_irq";
		qcom,id = <0>;

		qcom,chipid = <0x04000500>;

		qcom,initial-pwrlevel = <1>;

		qcom,idle-timeout = <8>; //<HZ/12>
		qcom,strtstp-sleepwake;

		/* Clocks = KGSL_CLK_CORE | KGSL_CLK_IFACE | KGSL_CLK_MEM |
		KGSL_CLK_MEM_IFACE | KGSL_CLK_ALT_MEM_IFACE */
		qcom,clk-map = <0x0000035E>;

		clocks = <&clock_gcc clk_gcc_oxili_gfx3d_clk>,
		         <&clock_gcc clk_gcc_oxili_ahb_clk>,
		         <&clock_gcc clk_gcc_oxili_gmem_clk>,
		         <&clock_gcc clk_gcc_bimc_gfx_clk>,
		         <&clock_gcc clk_gcc_bimc_gpu_clk>,
		         <&clock_gcc clk_gcc_gtcu_ahb_clk>,
			 <&clock_gcc clk_gcc_gfx_tcu_clk>,
			 <&clock_gcc clk_gcc_gfx_tbu_clk>;

		clock-names = "core_clk", "iface_clk", "mem_clk",
		              "mem_iface_clk", "alt_mem_iface_clk",
		              "gtcu_iface_clk", "gtcu_clk", "gtbu_clk";

		/* Bus Scale Settings */
		qcom,gpubw-dev = <&gpubw>;
		qcom,msm-bus,name = "grp3d";
		qcom,msm-bus,num-cases = <4>;
		qcom,msm-bus,num-paths = <1>;
		qcom,msm-bus,vectors-KBps =
		        <26 512 0 0>,
		        <26 512 0 2800000>,
		        <26 512 0 4147200>,
		        <26 512 0 5299200>;

		/* GDSC oxili regulators */
		vdd-supply = <&gdsc_oxili_gx>;

		/* IOMMU Data */
		iommu = <&gfx_iommu>;

		/* Trace bus */
		coresight-id = <67>;
		coresight-name = "coresight-gfx";
		coresight-nr-inports = <0>;
		coresight-outports = <0>;
		coresight-child-list = <&funnel_in0>;
		coresight-child-ports = <4>;

		/* CPU latency parameter */
		qcom,pm-qos-active-latency = <401>;
		qcom,pm-qos-wakeup-latency = <401>;

		/* Power levels */
		qcom,gpu-pwrlevels {
			#address-cells = <1>;
			#size-cells = <0>;

			compatible = "qcom,gpu-pwrlevels";

			qcom,gpu-pwrlevel@0 {
				reg = <0>;
				qcom,gpu-freq = <465000000>;
				qcom,bus-freq = <3>;
			};

			qcom,gpu-pwrlevel@1 {
				reg = <1>;
				qcom,gpu-freq = <400000000>;
				qcom,bus-freq = <2>;
			};

			qcom,gpu-pwrlevel@2 {
				reg = <2>;
				qcom,gpu-freq = <220000000>;
				qcom,bus-freq = <1>;
			};

			qcom,gpu-pwrlevel@3 {
				reg = <3>;
				qcom,gpu-freq = <19200000>;
				qcom,bus-freq = <0>;
			};
		};

	};
};