#define MHZ_TO_KBPS(mhz, w) ((mhz * 1000000 * w) / (1024)) &soc { msm_gpu: qcom,kgsl-3d0@2c00000 { label = "kgsl-3d0"; compatible = "qcom,kgsl-3d0", "qcom,kgsl-3d"; status = "ok"; reg = <0x2c00000 0x40000>, <0x2c61000 0x800>, <0x6900000 0x44000>, <0x780000 0x6fff>; reg-names = "kgsl_3d0_reg_memory", "cx_dbgc", "qdss_gfx", "qfprom_memory"; interrupts = <0 300 IRQ_TYPE_LEVEL_HIGH>; interrupt-names = "kgsl_3d0_irq"; qcom,id = <0>; qcom,chipid = <0x06040000>; qcom,initial-pwrlevel = <5>; qcom,gpu-quirk-secvid-set-once; qcom,gpu-quirk-cx-gdsc; qcom,idle-timeout = <80>; //msecs qcom,no-nap; qcom,highest-bank-bit = <15>; qcom,min-access-length = <32>; qcom,ubwc-mode = <3>; qcom,gpu-qdss-stm = <0x161c0000 0x40000>; // base addr, size #cooling-cells = <2>; clocks = <&gcc GCC_GPU_CFG_AHB_CLK>, <&gpucc GPU_CC_CXO_CLK>, <&gcc GCC_DDRSS_GPU_AXI_CLK>, <&gcc GCC_GPU_MEMNOC_GFX_CLK>, <&gpucc GPU_CC_CX_GMU_CLK>, <&gpucc GPU_CC_AHB_CLK>; clock-names = "gcc_gpu_ahb", "rbbmtimer_clk", "gcc_gpu_axi_clk", "gcc_gpu_memnoc_gfx", "gmu_clk", "gpu_cc_ahb"; qcom,isense-clk-on-level = <1>; interconnects = <&gem_noc MASTER_GFX3D &mc_virt SLAVE_EBI1>; interconnect-names = "gpu_icc_path"; qcom,bus-table-ddr = , /* index=0 */ , /* index=1 */ , /* index=2 */ , /* index=3 */ , /* index=4 */ , /* index=5 */ , /* index=6 */ , /* index=7 */ , /* index=8 */ , /* index=9 */ , /* index=10 */ , /* index=11 */ ; /* index=12 */ qcom,bus-table-cnoc = <0>, /* Off */ <100>; /* On */ /* GDSC regulator names */ regulator-names = "vddcx", "vdd"; /* GDSC oxili regulators */ vddcx-supply = <&gpu_cx_gdsc>; vdd-supply = <&gpu_gx_gdsc>; zap-shader { memory-region = <&gpu_micro_code_mem>; }; qcom,l3-pwrlevels { #address-cells = <1>; #size-cells = <0>; compatible = "qcom,l3-pwrlevels"; qcom,l3-pwrlevel@0 { reg = <0>; qcom,l3-freq = <0>; }; qcom,l3-pwrlevel@1 { reg = <1>; qcom,l3-freq = <864000000>; }; qcom,l3-pwrlevel@2 { reg = <2>; qcom,l3-freq = <1344000000>; }; }; /* GPU Mempools */ qcom,gpu-mempools { #address-cells = <1>; #size-cells = <0>; compatible = "qcom,gpu-mempools"; /* 4K Page Pool configuration */ qcom,gpu-mempool@0 { reg = <0>; qcom,mempool-page-size = <4096>; qcom,mempool-reserved = <2048>; qcom,mempool-allocate; }; /* 8K Page Pool configuration */ qcom,gpu-mempool@1 { reg = <1>; qcom,mempool-page-size = <8192>; qcom,mempool-reserved = <1024>; qcom,mempool-allocate; }; /* 64K Page Pool configuration */ qcom,gpu-mempool@2 { reg = <2>; qcom,mempool-page-size = <65536>; qcom,mempool-reserved = <256>; }; /* 1M Page Pool configuration */ qcom,gpu-mempool@3 { reg = <3>; qcom,mempool-page-size = <1048576>; qcom,mempool-reserved = <32>; }; }; /* Power levels */ qcom,gpu-pwrlevels { #address-cells = <1>; #size-cells = <0>; compatible = "qcom,gpu-pwrlevels"; qcom,gpu-pwrlevel@0 { reg = <0>; qcom,gpu-freq = <600000000>; qcom,level = ; qcom,bus-freq = <12>; qcom,bus-min = <10>; qcom,bus-max = <12>; }; qcom,gpu-pwrlevel@1 { reg = <1>; qcom,gpu-freq = <553850000>; qcom,level = ; qcom,bus-freq = <10>; qcom,bus-min = <9>; qcom,bus-max = <11>; }; qcom,gpu-pwrlevel@2 { reg = <2>; qcom,gpu-freq = <486460000>; qcom,level = ; qcom,bus-freq = <9>; qcom,bus-min = <8>; qcom,bus-max = <10>; }; qcom,gpu-pwrlevel@3 { reg = <3>; qcom,gpu-freq = <379650000>; qcom,level = ; qcom,bus-freq = <8>; qcom,bus-min = <7>; qcom,bus-max = <9>; }; qcom,gpu-pwrlevel@4 { reg = <4>; qcom,gpu-freq = <309110000>; qcom,level = ; qcom,bus-freq = <5>; qcom,bus-min = <5>; qcom,bus-max = <7>; }; qcom,gpu-pwrlevel@5 { reg = <5>; qcom,gpu-freq = <215000000>; qcom,level = ; qcom,bus-freq = <4>; qcom,bus-min = <3>; qcom,bus-max = <5>; }; qcom,gpu-pwrlevel@6 { reg = <6>; qcom,gpu-freq = <0>; qcom,level = ; qcom,bus-freq = <0>; qcom,bus-min = <0>; qcom,bus-max = <0>; }; }; }; kgsl_msm_iommu: qcom,kgsl-iommu@2ca0000 { compatible = "qcom,kgsl-smmu-v2"; reg = <0x2ca0000 0x10000>; gfx3d_user: gfx3d_user { compatible = "qcom,smmu-kgsl-cb"; label = "gfx3d_user"; iommus = <&kgsl_smmu 0x0 0x401>; qcom,iommu-dma = "disabled"; }; gfx3d_secure: gfx3d_secure { compatible = "qcom,smmu-kgsl-cb"; label = "gfx3d_secure"; iommus = <&kgsl_smmu 0x2 0x400>; qcom,iommu-dma = "disabled"; }; }; gmu: qcom,gmu@2c6a000 { compatible = "qcom,gpu-gmu"; reg = <0x2c6a000 0x30000>, <0xb280000 0x10000>, <0xb480000 0x10000>; reg-names = "kgsl_gmu_reg", "kgsl_gmu_pdc_cfg", "kgsl_gmu_pdc_seq"; interrupts = <0 304 IRQ_TYPE_LEVEL_HIGH>, <0 305 IRQ_TYPE_LEVEL_HIGH>; interrupt-names = "kgsl_hfi_irq", "kgsl_gmu_irq"; regulator-names = "vddcx", "vdd"; iommus = <&kgsl_smmu 0x5 0x400>; qcom,iommu-dma = "disabled"; vddcx-supply = <&gpu_cx_gdsc>; vdd-supply = <&gpu_gx_gdsc>; clocks = <&gpucc GPU_CC_CX_GMU_CLK>, <&gpucc GPU_CC_CXO_CLK>, <&gcc GCC_DDRSS_GPU_AXI_CLK>, <&gcc GCC_GPU_MEMNOC_GFX_CLK>, <&gpucc GPU_CC_AHB_CLK>; clock-names = "gmu_clk", "cxo_clk", "axi_clk", "gcc_gpu_memnoc_gfx_clk", "gpu_cc_ahb"; /* AOP mailbox for sending ACD enable and disable messages */ mboxes = <&qmp_aop 0>; mbox-names = "aop"; }; };