/dts-v1/; / { model = "Amlogic"; compatible = "amlogic, Gxm"; amlogic-dt-id = "gxm_q200_2g"; interrupt-parent = <0x01>; #address-cells = <0x02>; #size-cells = <0x02>; t82x@d00c0000 { compatible = "arm,malit602\0arm,malit60x\0arm,malit6xx\0arm,mali-midgard"; #cooling-cells = <0x02>; reg = <0x00 0xd00c0000 0x00 0x100000 0x00 0xc1104440 0x00 0x1000 0x00 0xc8100000 0x00 0x1000 0x00 0xc883c000 0x00 0x1000 0x00 0xc1104440 0x00 0x1000>; interrupt-parent = <0x01>; interrupts = <0x00 0xa0 0x04 0x00 0xa1 0x04 0x00 0xa2 0x04>; interrupt-names = "GPU\0MMU\0JOB"; num_of_pp = <0x03>; sc_mpp = <0x01>; operating-points = <0xa2c2a 0xf4240 0x7a120 0xf4240 0x61a80 0xf4240 0x45c12 0xf4240 0x3d090 0xf4240 0x1e848 0xf4240>; tbl = <0x02 0x03 0x04 0x05 0x05>; clocks = <0x06 0x08 0x06 0x09 0x06 0x11 0x06 0x12 0x06 0x1e 0x06 0x15 0x06 0x13 0x06 0x14>; clock-names = "fclk_div3\0fclk_div4\0fclk_div5\0fclk_div7\0gp0_pll\0clk_gpu\0clk_gpu_0\0clk_gpu_1"; linux,phandle = <0x7b>; phandle = <0x7b>; clk125_cfg { clk_freq = <0x7735940>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x1e 0x78>; }; dvfs250_cfg { clk_freq = <0xee6b280>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x50 0xaa>; }; dvfs285_cfg { clk_freq = <0x1107a650>; clk_parent = "fclk_div7"; clkp_freq = <0x1107a650>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x64 0xbe>; linux,phandle = <0x02>; phandle = <0x02>; }; dvfs400_cfg { clk_freq = <0x17d78400>; clk_parent = "fclk_div5"; clkp_freq = <0x17d78400>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x98 0xcf>; linux,phandle = <0x03>; phandle = <0x03>; }; dvfs500_cfg { clk_freq = <0x1dcd6500>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xb4 0xdc>; linux,phandle = <0x04>; phandle = <0x04>; }; dvfs666_cfg { clk_freq = <0x27b25a80>; clk_parent = "fclk_div3"; clkp_freq = <0x27b25a80>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xd2 0xec>; linux,phandle = <0x05>; phandle = <0x05>; }; dvfs800_cfg { clk_freq = <0x2f34f600>; clk_parent = "gp0_pll"; clkp_freq = <0x2f34f600>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xe6 0xff>; }; }; gpu_clk@c883c00 { compatible = "meson, gpu-clkgen-1.00.a"; #clock-cells = <0x00>; reg = <0x00 0xc883c000 0x00 0x1000>; clocks = <0x06 0x08 0x06 0x09 0x06 0x11 0x06 0x12 0x06 0x1e 0x06 0x15 0x06 0x13 0x06 0x14>; clock-names = "fclk_div3\0fclk_div4\0fclk_div5\0fclk_div7\0gp0_pll\0clk_gpu\0clk_gpu_0\0clk_gpu_1"; clock-output-names = "clk_mali"; tbl = <0x07 0x08 0x09 0x0a 0x0b 0x0c>; clk125_cfg { clk_freq = <0x7735940>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x1e 0x78>; linux,phandle = <0x07>; phandle = <0x07>; }; clk250_cfg { clk_freq = <0xee6b280>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x50 0xaa>; linux,phandle = <0x08>; phandle = <0x08>; }; clk285_cfg { clk_freq = <0x1107a650>; clk_parent = "fclk_div7"; clkp_freq = <0x1107a650>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x64 0xbe>; linux,phandle = <0x09>; phandle = <0x09>; }; clk400_cfg { clk_freq = <0x17d78400>; clk_parent = "fclk_div5"; clkp_freq = <0x17d78400>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0x98 0xcf>; linux,phandle = <0x0a>; phandle = <0x0a>; }; clk500_cfg { clk_freq = <0x1dcd6500>; clk_parent = "fclk_div4"; clkp_freq = <0x1dcd6500>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xb4 0xdc>; linux,phandle = <0x0b>; phandle = <0x0b>; }; clk666_cfg { clk_freq = <0x27bc8410>; clk_parent = "fclk_div3"; clkp_freq = <0x27bc8410>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xd2 0xec>; linux,phandle = <0x0c>; phandle = <0x0c>; }; clk720_cfg { clk_freq = <0x2aea5400>; clk_parent = "gp0_pll"; clkp_freq = <0x2aea5400>; voltage = <0x47e>; keep_count = <0x05>; threshold = <0xe6 0xff>; }; }; cpus { #address-cells = <0x02>; #size-cells = <0x00>; cpu-map { cluster0 { #cooling-cells = <0x02>; linux,phandle = <0x77>; phandle = <0x77>; core0 { cpu = <0x0d>; }; core1 { cpu = <0x0e>; }; core2 { cpu = <0x0f>; }; core3 { cpu = <0x10>; }; }; cluster1 { #cooling-cells = <0x02>; linux,phandle = <0x78>; phandle = <0x78>; core0 { cpu = <0x11>; }; core1 { cpu = <0x12>; }; core2 { cpu = <0x13>; }; core3 { cpu = <0x14>; }; }; }; cpu@0 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x00>; enable-method = "psci"; clocks = <0x15 0x00>; clock-names = "cpu-cluster.0"; linux,phandle = <0x0d>; phandle = <0x0d>; }; cpu@1 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x01>; enable-method = "psci"; clocks = <0x15 0x00>; clock-names = "cpu-cluster.0"; linux,phandle = <0x0e>; phandle = <0x0e>; }; cpu@2 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x02>; enable-method = "psci"; clocks = <0x15 0x00>; clock-names = "cpu-cluster.0"; linux,phandle = <0x0f>; phandle = <0x0f>; }; cpu@3 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x03>; enable-method = "psci"; clocks = <0x15 0x00>; clock-names = "cpu-cluster.0"; linux,phandle = <0x10>; phandle = <0x10>; }; cpu@100 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x100>; enable-method = "psci"; clocks = <0x15 0x01>; clock-names = "cpu-cluster.1"; linux,phandle = <0x11>; phandle = <0x11>; }; cpu@101 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x101>; enable-method = "psci"; clocks = <0x15 0x01>; clock-names = "cpu-cluster.1"; linux,phandle = <0x12>; phandle = <0x12>; }; cpu@102 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x102>; enable-method = "psci"; clocks = <0x15 0x01>; clock-names = "cpu-cluster.1"; linux,phandle = <0x13>; phandle = <0x13>; }; cpu@103 { device_type = "cpu"; compatible = "arm,cortex-a53\0arm,armv8"; reg = <0x00 0x103>; enable-method = "psci"; clocks = <0x15 0x01>; clock-names = "cpu-cluster.1"; linux,phandle = <0x14>; phandle = <0x14>; }; idle-states { entry-method = "arm,psci"; cpu-sleep-0 { arm,psci-suspend-param = <0x10000>; local-timer-stop; entry-latency-us = <0x1388>; exit-latency-us = <0x1f40>; min-residency-us = <0x4e20>; }; cluster-sleep-0 { arm,psci-suspend-param = <0x1010000>; local-timer-stop; entry-latency-us = <0x1388>; exit-latency-us = <0x1f40>; min-residency-us = <0x61a8>; }; }; }; timer { compatible = "arm,armv8-timer"; interrupts = <0x01 0x0d 0xff01 0x01 0x0e 0xff01 0x01 0x0b 0xff01 0x01 0x0a 0xff01>; }; timer_bc { compatible = "arm, meson-bc-timer"; reg = <0x00 0xc1109990 0x00 0x04 0x00 0xc1109994 0x00 0x04>; timer_name = "Meson TimerF"; clockevent-rating = <0x12c>; clockevent-shift = <0x14>; clockevent-features = <0x23>; interrupts = <0x00 0x3c 0x01>; bit_enable = <0x10>; bit_mode = <0x0c>; bit_resolution = <0x00>; }; arm_pmu { compatible = "arm,armv8-pmuv3"; interrupts = <0x00 0x89 0x04 0x00 0x8a 0x04 0x00 0x99 0x04 0x00 0x9a 0x04>; }; pm { compatible = "amlogic, pm"; device_name = "aml_pm"; gxbaby-suspend; reg = <0x00 0xc81000a8 0x00 0x04 0x00 0xc810023c 0x00 0x04>; }; interrupt-controller@2c001000 { compatible = "arm,cortex-a15-gic\0arm,cortex-a9-gic"; #interrupt-cells = <0x03>; #address-cells = <0x00>; interrupt-controller; reg = <0x00 0xc4301000 0x00 0x1000 0x00 0xc4302000 0x00 0x100>; interrupts = <0x01 0x09 0xf04>; linux,phandle = <0x01>; phandle = <0x01>; }; aml_restart { compatible = "aml, restart"; sys_reset = <0x84000009>; sys_poweroff = <0x84000008>; }; psci { compatible = "arm,psci"; method = "smc"; cpu_suspend = <0xc4000001>; cpu_off = <0x84000002>; cpu_on = <0xc4000003>; migrate = <0xc4000005>; }; secmon { compatible = "amlogic, secmon"; memory-region = <0x16>; in_base_func = <0x82000020>; out_base_func = <0x82000021>; }; securitykey { compatible = "aml, securitykey"; storage_query = <0x82000060>; storage_read = <0x82000061>; storage_write = <0x82000062>; storage_tell = <0x82000063>; storage_verify = <0x82000064>; storage_status = <0x82000065>; storage_list = <0x82000067>; storage_remove = <0x82000068>; storage_in_func = <0x82000023>; storage_out_func = <0x82000024>; storage_block_func = <0x82000025>; storage_size_func = <0x82000027>; }; cpu_iomap { compatible = "amlogic, iomap"; #address-cells = <0x02>; #size-cells = <0x02>; ranges; io_cbus_base { reg = <0x00 0xc1100000 0x00 0x100000>; }; io_apb_base { reg = <0x00 0xd0000000 0x00 0x200000>; }; io_aobus_base { reg = <0x00 0xc8100000 0x00 0x100000>; }; }; cpufreq { compatible = "arm, scpi-cpufreq"; }; amlogic-watchdog { compatible = "amlogic, gx-wdt"; status = "disable"; default_timeout = <0x0a>; reset_watchdog_method = <0x01>; reset_watchdog_time = <0x02>; shutdown_timeout = <0x0a>; firmware_timeout = <0x06>; suspend_timeout = <0x06>; reg = <0x00 0xc11098d0 0x00 0x10>; clocks = <0x06 0x02>; }; amlogic-jtag { compatible = "amlogic, jtag"; status = "okay"; pinctrl-names = "jtag_apao_pins\0jtag_apee_pins"; pinctrl-0 = <0x17>; pinctrl-1 = <0x18>; }; meson_clock { compatible = "amlogic, gxl-clock"; reg = <0x00 0xc883c000 0x00 0x1000 0x00 0xc8100000 0x00 0x1000>; #clock-cells = <0x01>; #reset-cells = <0x01>; sys_max = <0x5b8d8000>; linux,phandle = <0x06>; phandle = <0x06>; }; cpu_info { compatible = "amlogic, cpuinfo"; cpuinfo_cmd = <0x82000044>; }; pinmux { compatible = "amlogic, pinmux-gxl"; dev_name = "pinmux"; #pinmux-cells = <0x02>; #address-cells = <0x02>; #size-cells = <0x02>; reg = <0x00 0xc1109880 0x00 0x10>; ranges; banks@c11080b0 { reg = <0x00 0xc88344b0 0x00 0x28 0x00 0xc88344e8 0x00 0x14 0x00 0xc8834520 0x00 0x14 0x00 0xc8834430 0x00 0x40>; reg-names = "mux\0pull\0pull-enable\0gpio"; gpio-controller; #gpio-cells = <0x02>; linux,phandle = <0x24>; phandle = <0x24>; }; ao-bank@c1108030 { reg = <0x00 0xc8100014 0x00 0x08 0x00 0xc810002c 0x00 0x04 0x00 0xc8100024 0x00 0x08>; reg-names = "mux\0pull\0gpio"; gpio-controller; #gpio-cells = <0x02>; linux,phandle = <0x25>; phandle = <0x25>; }; external_eth_pins { amlogic,setmask = <0x04 0xfffc00>; amlogic,clrmask = <0x04 0x3fc 0x03 0xffcff800>; amlogic,pins = "GPIOZ_0\0GPIOZ_1\0GPIOZ_2\0GPIOZ_3\0GPIOZ_4\0GPIOZ_5\0GPIOZ_6\0GPIOZ_7\0GPIOZ_8\0GPIOZ_9\0GPIOZ_10\0GPIOZ_11\0GPIOZ_12\0GPIOZ_13"; linux,phandle = <0x28>; phandle = <0x28>; }; internal_eth_pins { amlogic,setmask = <0x04 0x3000000>; amlogic,clrmask = <0x03 0x300000>; amlogic,pins = "GPIOZ_14\0GPIOZ_15"; }; jtag_apao_pin { amlogic,clrmask = <0x06 0x7fe0000>; amlogic,pins = "GPIOH_6\0GPIOH_7\0GPIOH_8\0GPIOH_9"; linux,phandle = <0x17>; phandle = <0x17>; }; jtag_apee_pin { amlogic,clrmask = <0x06 0x3c>; amlogic,pins = "CARD_0\0CARD_1\0CARD_2\0CARD_3"; linux,phandle = <0x18>; phandle = <0x18>; }; remote_pin { amlogic,setmask = <0x10 0x01>; amlogic,pins = "GPIOAO_7"; linux,phandle = <0x23>; phandle = <0x23>; }; ao_uart { amlogic,setmask = <0x10 0x1800>; amlogic,pins = "GPIOAO_0\0GPIOAO_1"; }; ao_b_uart { amlogic,setmask = <0x10 0x1800000>; amlogic,pins = "GPIOAO_4\0GPIOAO_5"; linux,phandle = <0x61>; phandle = <0x61>; }; a_uart { amlogic,setmask = <0x05 0xf0000>; amlogic,clrmask = <0x05 0x3c0>; amlogic,pins = "GPIOX_12\0GPIOX_13\0GPIOX_14\0GPIOX_15"; linux,phandle = <0x5e>; phandle = <0x5e>; }; b_uart { amlogic,setmask = <0x02 0x18000>; amlogic,pins = "GPIODV_24\0GPIODV_25"; linux,phandle = <0x5f>; phandle = <0x5f>; }; c_uart { amlogic,setmask = <0x05 0x3000>; amlogic,pins = "GPIOX_8\0GPIOX_9"; linux,phandle = <0x60>; phandle = <0x60>; }; wifi_32k_pins { amlogic,setmask = <0x05 0x8000>; amlogic,pins = "GPIOX_16"; linux,phandle = <0x2d>; phandle = <0x2d>; }; sd_clk_cmd_pins { amlogic,setmask = <0x06 0x0c 0x10 0x1800>; amlogic,pins = "CARD_2\0CARD_3"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x32>; phandle = <0x32>; }; sd_all_pins { amlogic,setmask = <0x06 0x3f 0x10 0x1800>; amlogic,clrmask = <0x06 0xfc0>; amlogic,pins = "CARD_0\0CARD_1\0CARD_2\0CARD_3\0CARD_4\0CARD_5"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x33>; phandle = <0x33>; }; sd_1bit_pins { amlogic,setmask = <0x06 0x1c 0x10 0x1800>; amlogic,clrmask = <0x06 0xcc3>; amlogic,pins = "CARD_1\0CARD_2\0CARD_3"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x34>; phandle = <0x34>; }; sd_clk_cmd_uart_pins { amlogic,setmask = <0x06 0x30c>; amlogic,clrmask = <0x06 0xcc3 0x10 0x1800>; amlogic,pins = "CARD_2\0CARD_3"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x35>; phandle = <0x35>; }; sd_1bit_uart_pins { amlogic,setmask = <0x06 0x31c>; amlogic,clrmask = <0x06 0xcc3 0x10 0x1800>; amlogic,pins = "CARD_1\0CARD_2\0CARD_3"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x36>; phandle = <0x36>; }; sd_to_ao_uart_pins { amlogic,setmask = <0x10 0x1800>; amlogic,clrmask = <0x06 0x300>; amlogic,pins = "GPIOAO_0\0GPIOAO_1"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x37>; phandle = <0x37>; }; ao_to_sd_uart_pins { amlogic,setmask = <0x06 0x300>; amlogic,clrmask = <0x10 0x1800 0x06 0xcc3>; amlogic,pins = "CARD_4\0CARD_5"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x38>; phandle = <0x38>; }; ao_to_sd_jtag_pins { amlogic,setmask = <0x06 0x300>; amlogic,clrmask = <0x06 0xcff 0x10 0x1800>; amlogic,pins = "CARD_4\0CARD_5"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x39>; phandle = <0x39>; }; sd_to_ao_jtag_pins { amlogic,setmask = <0x10 0x1800>; amlogic,clrmask = <0x06 0xfc0>; amlogic,pins = "GPIOAO_0\0GPIOAO_1"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x3a>; phandle = <0x3a>; }; emmc_clk_cmd_pins { amlogic,setmask = <0x07 0x60000000>; amlogic,clrmask = <0x07 0xe0>; amlogic,pins = "BOOT_8\0BOOT_10"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x2e>; phandle = <0x2e>; }; emmc_conf_pull_up { amlogic,pins = "BOOT_0\0BOOT_1\0BOOT_2\0BOOT_3\0BOOT_4\0BOOT_5\0BOOT_6\0BOOT_7\0BOOT_8\0BOOT_10"; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x2f>; phandle = <0x2f>; }; emmc_conf_pull_done { amlogic,pins = "BOOT_15"; amlogic,pullup = <0x00>; amlogic,pullupen = <0x01>; linux,phandle = <0x30>; phandle = <0x30>; }; emmc_all_pins { amlogic,setmask = <0x07 0xf0000000>; amlogic,clrmask = <0x07 0xe0>; amlogic,pins = "BOOT_0\0BOOT_1\0BOOT_2\0BOOT_3\0BOOT_4\0BOOT_5\0BOOT_6\0BOOT_7\0BOOT_8\0BOOT_10\0BOOT_15"; amlogic,enable-output = <0x01>; linux,phandle = <0x31>; phandle = <0x31>; }; sdio_clk_cmd_pins { amlogic,setmask = <0x05 0xc000000>; amlogic,pins = "GPIOX_4\0GPIOX_5"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x3b>; phandle = <0x3b>; }; sdio_all_pins { amlogic,setmask = <0x05 0xfc000000>; amlogic,pins = "GPIOX_0\0GPIOX_1\0GPIOX_2\0GPIOX_3\0GPIOX_4\0GPIOX_5"; amlogic,enable-output = <0x01>; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x3c>; phandle = <0x3c>; }; conf_nand_pulldown { amlogic,pins = "BOOT_0\0BOOT_1\0BOOT_2\0BOOT_3\0BOOT_4\0BOOT_5\0BOOT_6\0BOOT_7\0BOOT_15"; amlogic,pullup = <0x00>; amlogic,pullupen = <0x01>; linux,phandle = <0x3d>; phandle = <0x3d>; }; conf_nand_pullup { amlogic,pins = "BOOT_8\0BOOT_10"; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; linux,phandle = <0x3e>; phandle = <0x3e>; }; all_nand_pins { amlogic,setmask = <0x07 0x800000ff>; amlogic,clrmask = <0x07 0x70ffbc00>; amlogic,pins = "BOOT_0\0BOOT_1\0BOOT_2\0BOOT_3\0BOOT_4\0BOOT_5\0BOOT_6\0BOOT_7\0BOOT_8\0BOOT_9\0BOOT_10\0BOOT_11\0BOOT_12\0BOOT_13\0BOOT_14\0BOOT_15"; amlogic,enable-output = <0x01>; linux,phandle = <0x3f>; phandle = <0x3f>; }; nand_cs { amlogic,setmask = <0x07 0xc0>; amlogic,clrmask = <0x07 0x40040000>; amlogic,pins = "BOOT_8\0BOOT_9"; linux,phandle = <0x40>; phandle = <0x40>; }; hdmitx_hpd { amlogic,setmask = <0x06 0x80000000>; amlogic,pins = "GPIOH_0"; linux,phandle = <0x5b>; phandle = <0x5b>; }; hdmitx_ddc { amlogic,setmask = <0x06 0x30000000>; amlogic,pins = "GPIOH_1\0GPIOH_2"; linux,phandle = <0x5c>; phandle = <0x5c>; }; hdmitx_aocec { amlogic,setmask = <0x10 0x8000>; amlogic,clrmask = <0x10 0x24000 0x11 0x01>; amlogic,pins = "GPIOAO_8"; linux,phandle = <0x5d>; phandle = <0x5d>; }; hdmitx_eecec { amlogic,setmask = <0x10 0x4000>; amlogic,clrmask = <0x10 0x28000 0x11 0x01>; amlogic,pins = "GPIOAO_8"; }; a_i2c { amlogic,setmask = <0x01 0xc000>; amlogic,clrmask = <0x03 0x18 0x02 0x18000 0x02 0xc0 0x01 0x600000>; amlogic,pins = "GPIODV_24\0GPIODV_25"; linux,phandle = <0x19>; phandle = <0x19>; }; b_i2c { amlogic,setmask = <0x01 0x3000>; amlogic,clrmask = <0x02 0x6000 0x01 0x1c0000>; amlogic,pins = "GPIODV_26\0GPIODV_27"; linux,phandle = <0x1a>; phandle = <0x1a>; }; c_i2c { amlogic,setmask = <0x01 0xc00>; amlogic,clrmask = <0x02 0x1800 0x01 0x200 0x02 0x20>; amlogic,pins = "GPIODV_28\0GPIODV_29"; linux,phandle = <0x1b>; phandle = <0x1b>; }; d_i2c { amlogic,setmask = <0x05 0x30>; amlogic,clrmask = <0x05 0x300c03>; amlogic,pins = "GPIOX_10\0GPIOX_11"; linux,phandle = <0x1c>; phandle = <0x1c>; }; spicc_pins_z11z12z13 { amlogic,setmask = <0x04 0x1c>; amlogic,clrmask = <0x03 0x800 0x04 0x1c00>; amlogic,pins = "GPIOZ_11\0GPIOZ_12\0GPIOZ_13"; }; spicc_pulldown_z11z12z13 { amlogic,pins = "GPIOZ_11\0GPIOZ_12\0GPIOZ_13"; amlogic,pullup = <0x00>; amlogic,pullupen = <0x01>; }; spicc_pullup_z11z12z13 { amlogic,pins = "GPIOZ_11\0GPIOZ_12\0GPIOZ_13"; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; }; spicc_pins_x8x9x11 { amlogic,setmask = <0x05 0x0d>; amlogic,clrmask = <0x05 0xd03430 0x06 0x0d>; amlogic,pins = "GPIOX_8\0GPIOX_9\0GPIOX_11"; }; spicc_pulldown_x8x9x11 { amlogic,pins = "GPIOX_8\0GPIOX_9\0GPIOX_11"; amlogic,pullup = <0x00>; amlogic,pullupen = <0x01>; }; spicc_pullup_x8x9x11 { amlogic,pins = "GPIOX_8\0GPIOX_9\0GPIOX_11"; amlogic,pullup = <0x01>; amlogic,pullupen = <0x01>; }; audio_pin { amlogic,setmask = <0x06 0x7800000>; amlogic,clrmask = <0x06 0x7e0000>; amlogic,pins = "GPIOH_6\0GPIOH_7\0GPIOH_8\0GPIOH_9"; linux,phandle = <0x66>; phandle = <0x66>; }; audio_pin1 { amlogic,setmask = <0x06 0x10000000>; amlogic,clrmask = <0x06 0x8000000>; amlogic,pins = "GPIOH_4"; linux,phandle = <0x65>; phandle = <0x65>; }; audio_btpcm_pins { amlogic,setmask = <0x05 0xf00000>; amlogic,clrmask = <0x05 0x3c33>; amlogic,pins = "GPIOX_8\0GPIOX_9\0GPIOX_10\0GPIOX_11"; linux,phandle = <0x64>; phandle = <0x64>; }; }; cpu_version { reg = <0x00 0xc8100220 0x00 0x04>; }; meson_clk_msr { compatible = "amlogic, gxl_measure"; reg = <0x00 0xc110875c 0x00 0x04 0x00 0xc1108764 0x00 0x04>; }; i2c@c1108500 { compatible = "amlogic, meson-i2c"; dev_name = "i2c-A"; status = "disabled"; reg = <0x00 0xc1108500 0x00 0x20>; device_id = <0x01>; pinctrl-names = "default"; pinctrl-0 = <0x19>; #address-cells = <0x01>; #size-cells = <0x00>; use_pio = <0x00>; master_i2c_speed = <0x493e0>; clocks = <0x06 0x0a>; clock-names = "clk_i2c"; resets = <0x06 0x09>; }; i2c@c11087c0 { compatible = "amlogic, meson-i2c"; dev_name = "i2c-B"; status = "disabled"; reg = <0x00 0xc11087c0 0x00 0x20>; device_id = <0x02>; pinctrl-names = "default"; pinctrl-0 = <0x1a>; #address-cells = <0x01>; #size-cells = <0x00>; use_pio = <0x00>; master_i2c_speed = <0x493e0>; clocks = <0x06 0x0a>; clock-names = "clk_i2c"; resets = <0x06 0x09>; }; i2c@c11087e0 { compatible = "amlogic, meson-i2c"; dev_name = "i2c-C"; status = "disabled"; reg = <0x00 0xc11087e0 0x00 0x20>; device_id = <0x03>; pinctrl-names = "default"; pinctrl-0 = <0x1b>; #address-cells = <0x01>; #size-cells = <0x00>; use_pio = <0x00>; master_i2c_speed = <0x493e0>; clocks = <0x06 0x0a>; clock-names = "clk_i2c"; resets = <0x06 0x09>; }; i2c@c1108d20 { compatible = "amlogic, meson-i2c"; dev_name = "i2c-D"; status = "disabled"; reg = <0x00 0xc1108d20 0x00 0x20>; device_id = <0x04>; pinctrl-names = "default"; pinctrl-0 = <0x1c>; #address-cells = <0x01>; #size-cells = <0x00>; use_pio = <0x00>; master_i2c_speed = <0x493e0>; clocks = <0x06 0x0a>; clock-names = "clk_i2c"; resets = <0x06 0x09>; }; efuse { compatible = "amlogic, efuse"; read_cmd = <0x82000030>; write_cmd = <0x82000031>; get_max_cmd = <0x82000033>; key = <0x1d>; resets = <0x06 0x3e>; reset-names = "efuse_clk"; status = "ok"; }; efusekey { keynum = <0x04>; key0 = <0x1e>; key1 = <0x1f>; key2 = <0x20>; key3 = <0x21>; linux,phandle = <0x1d>; phandle = <0x1d>; key0 { keyname = "mac"; offset = <0x00>; size = <0x06>; linux,phandle = <0x1e>; phandle = <0x1e>; }; key1 { keyname = "mac_bt"; offset = <0x06>; size = <0x06>; linux,phandle = <0x1f>; phandle = <0x1f>; }; key2 { keyname = "mac_wifi"; offset = <0x0c>; size = <0x06>; linux,phandle = <0x20>; phandle = <0x20>; }; key3 { keyname = "usid"; offset = <0x12>; size = <0x10>; linux,phandle = <0x21>; phandle = <0x21>; }; }; mhu@c883c400 { compatible = "amlogic, meson_mhu"; reg = <0x00 0xc883c400 0x00 0x4c 0x00 0xc8013000 0x00 0x800>; interrupts = <0x00 0xd1 0x08 0x00 0xd2 0x08>; #mbox-cells = <0x01>; mbox-names = "cpu_to_scp_low\0cpu_to_scp_high"; mboxes = <0x22 0x00 0x22 0x01>; linux,phandle = <0x22>; phandle = <0x22>; }; scpi_clocks { compatible = "arm,scpi-clks"; scpi_clocks@0 { compatible = "arm,scpi-clk-indexed"; #clock-cells = <0x01>; clock-indices = <0x00 0x01>; clock-output-names = "vbig\0vlittle"; linux,phandle = <0x15>; phandle = <0x15>; }; }; meson-remote { compatible = "amlogic, aml_remote"; dev_name = "meson-remote"; status = "okay"; remote_ao_offset = <0x580>; interrupts = <0x00 0xc4 0x01>; pinctrl-names = "default"; pinctrl-0 = <0x23>; }; rng { compatible = "amlogic,meson-rng"; reg = <0x00 0xc8834000 0x00 0x04>; }; audio_data { compatible = "amlogic, audio_data"; query_licence_cmd = <0x82000050>; status = "okay"; }; saradc { compatible = "amlogic, saradc"; status = "okay"; interrupts = <0x00 0x09 0x01>; interrupt-names = "saradc_int"; clocks = <0x06 0x02>; clock-names = "saradc_clk"; resets = <0x06 0x56>; reg = <0x00 0xc1108680 0x00 0x30 0x00 0xc883c3d8 0x00 0x08>; }; defendkey { compatible = "amlogic, defendkey"; reg = <0x00 0xc8834500 0x00 0x04>; mem_size = <0x00 0x100000>; status = "okay"; }; spicc { compatible = "amlogic, spicc"; status = "disabled"; reg = <0x00 0xc1108d80 0x00 0x28>; resets = <0x06 0x08>; clocks = <0x06 0x0a>; clock-names = "spicc_clk"; interrupts = <0x00 0x51 0x01>; device_id = <0x00>; }; aml_aes { compatible = "amlogic,aes_dma"; dev_name = "aml_aes_dma"; interrupts = <0x00 0xbc 0x01 0x00 0xbd 0x01>; reg = <0x00 0xc883e000 0x00 0x28>; }; aml_tdes { compatible = "amlogic,des_dma,tdes_dma"; dev_name = "aml_tdes_dma"; interrupts = <0x00 0xbc 0x01 0x00 0xbd 0x01>; reg = <0x00 0xc883e000 0x00 0x28>; }; aml_sha { compatible = "amlogic,sha_dma"; dev_name = "aml_sha_dma"; interrupts = <0x00 0xbc 0x01 0x00 0xbd 0x01>; reg = <0x00 0xc883e000 0x00 0x28>; }; aliases { serial0 = "/serial@c81004c0"; serial1 = "/serial@c11084c0"; serial2 = "/serial@c11084dc"; serial3 = "/serial@c1108700"; serial4 = "/serial@c81004e0"; }; memory@00000000 { device_type = "memory"; linux,usable-memory = <0x00 0x100000 0x00 0x7f000000>; }; reserved-memory { #address-cells = <0x02>; #size-cells = <0x02>; ranges; linux,secmon { compatible = "amlogic, aml_secmon_memory"; reg = <0x00 0x10000000 0x00 0x200000>; no-map; linux,phandle = <0x16>; phandle = <0x16>; }; linux,secos { status = "disable"; compatible = "amlogic, aml_secos_memory"; reg = <0x00 0x5300000 0x00 0x2000000>; no-map; }; aml_pstore { compatible = "amlogic, pstore"; reg = <0x00 0x7300000 0x00 0x100000>; no-map; }; linux,di { compatible = "amlogic, di-mem"; size = <0x00 0x1e00000>; linux,phandle = <0x2c>; phandle = <0x2c>; }; linux,ion-dev { compatible = "amlogic, idev-mem"; size = <0x00 0x4000000>; linux,phandle = <0x29>; phandle = <0x29>; }; linux,ppmgr { compatible = "shared-dma-pool"; size = <0x00 0x00>; linux,phandle = <0x2b>; phandle = <0x2b>; }; linux,codec_mm_cma { compatible = "shared-dma-pool"; reusable; size = <0x00 0xc000000>; alignment = <0x00 0x400000>; linux,contiguous-region; linux,phandle = <0x26>; phandle = <0x26>; }; linux,picdec { compatible = "shared-dma-pool"; reusable; size = <0x00 0x00>; alignment = <0x00 0x00>; linux,contiguous-region; linux,phandle = <0x2a>; phandle = <0x2a>; }; linux,codec_mm_reserved { compatible = "amlogic, codec-mm-reserved"; size = <0x00 0x4100000>; alignment = <0x00 0x100000>; linux,phandle = <0x27>; phandle = <0x27>; }; }; sysled { compatible = "amlogic, sysled"; dev_name = "sysled"; status = "okay"; red_gpio = <0x24 0x4d 0x00>; led_gpio = <0x25 0x09 0x00>; mcu_gpio = <0x25 0x06 0x00>; led_active_low = <0x01>; }; hbs658 { compatible = "amlogic, hbs658"; dev_name = "hbs658"; status = "okay"; gpio-scl = <0x24 0x4c 0x00>; gpio-sda = <0x24 0x4b 0x00>; }; meson-vout { compatible = "amlogic, meson-vout"; dev_name = "meson-vout"; status = "okay"; }; meson-fb { compatible = "amlogic, meson-fb"; dev_name = "meson-fb"; status = "okay"; interrupts = <0x00 0x03 0x01 0x00 0x59 0x01>; interrupt-names = "viu-vsync\0rdma"; mem_size = <0x1851000 0x100000>; display_mode_default = "1080p60hz"; scale_mode = <0x01>; display_size_default = <0x780 0x438 0x780 0xca8 0x20>; logo_addr = "0x3d851000"; }; ge2d { compatible = "amlogic, ge2d"; dev_name = "ge2d"; status = "okay"; interrupts = <0x00 0x96 0x01>; interrupt-names = "ge2d"; clocks = <0x06 0x17 0x06 0x19>; clock-names = "clk_vapb_0\0clk_ge2d"; resets = <0x06 0x34>; reset-names = "ge2d"; }; codec_io { compatible = "amlogic, codec_io"; #address-cells = <0x02>; #size-cells = <0x02>; ranges; io_cbus_base { reg = <0x00 0xc1100000 0x00 0x100000>; }; io_dos_base { reg = <0x00 0xc8820000 0x00 0x10000>; }; io_hiubus_base { reg = <0x00 0xc883c000 0x00 0x2000>; }; io_aobus_base { reg = <0x00 0xc8100000 0x00 0x100000>; }; io_vcbus_base { reg = <0x00 0xd0100000 0x00 0x40000>; }; io_dmc_base { reg = <0x00 0xc8838000 0x00 0x400>; }; }; codec_mm { compatible = "amlogic, codec, mm"; memory-region = <0x26 0x27>; dev_name = "codec_mm"; status = "okay"; }; ethernet@0xc9410000 { compatible = "amlogic, gxbb-rgmii-dwmac"; reg = <0x00 0xc9410000 0x00 0x10000 0x00 0xc8834540 0x00 0x08 0x00 0xc8834558 0x00 0x0c>; interrupts = <0x00 0x08 0x01>; phy-mode = "rgmii"; pinctrl-names = "external_eth_pins"; pinctrl-0 = <0x28>; rst_pin-gpios = <0x24 0x0e 0x00>; GPIOZ4_pin-gpios = <0x24 0x04 0x00>; GPIOZ5_pin-gpios = <0x24 0x05 0x00>; mc_val = <0x1621>; cali_val = <0x20000>; resets = <0x06 0x23>; reset-names = "ethpower"; interrupt-names = "macirq"; clocks = <0x06 0x0a>; clock-names = "ethclk81"; internal_phy = <0x00>; }; mesonstream { compatible = "amlogic, codec, streambuf"; dev_name = "mesonstream"; status = "okay"; resets = <0x06 0x39 0x06 0x59 0x06 0x24 0x06 0x01>; reset-names = "parser_top\0vpu_intr\0demux\0vdec"; }; amvideocap { compatible = "amlogic, amvideocap"; dev_name = "amvideocap.0"; status = "okay"; max_size = <0x08>; }; ion_dev { compatible = "amlogic, ion_dev"; memory-region = <0x29>; }; vdec { compatible = "amlogic, vdec"; dev_name = "vdec.0"; status = "okay"; interrupts = <0x00 0x03 0x01 0x00 0x17 0x01 0x00 0x20 0x01 0x00 0x2b 0x01 0x00 0x2c 0x01 0x00 0x2d 0x01>; interrupt-names = "vsync\0demux\0parser\0mailbox_0\0mailbox_1\0mailbox_2"; }; picdec { compatible = "amlogic, picdec"; memory-region = <0x2a>; dev_name = "picdec"; status = "okay"; }; ppmgr { compatible = "amlogic, ppmgr"; memory-region = <0x2b>; dev_name = "ppmgr"; status = "okay"; }; deinterlace { compatible = "amlogic, deinterlace"; status = "okay"; memory-region = <0x2c>; interrupts = <0x00 0x2e 0x01 0x00 0x06 0x01>; interrupt-names = "de_irq\0timerc"; buffer-size = <0x2fd000>; hw-version = <0x02>; }; amvdec_656in0 { compatible = "amlogic, amvdec_656in"; dev_name = "amvdec_656in0"; status = "ok"; reg = <0x00 0xd0048000 0x00 0x7c>; clocks = <0x06 0x07 0x06 0x26>; clock-names = "fclk_div2\0cts_bt656_clk0"; bt656_id = <0x00>; }; amvdec_656in1 { compatible = "amlogic, amvdec_656in"; dev_name = "amvdec_656in1"; status = "ok"; reg = <0x00 0xd0050000 0x00 0x7c>; clocks = <0x06 0x07 0x06 0x27>; clock-names = "fclk_div2\0cts_bt656_clk1"; bt656_id = <0x01>; }; amlvecm { compatible = "amlogic, vecm"; dev_name = "aml_vecm"; status = "okay"; gamma_en = <0x00>; wb_en = <0x00>; cm_en = <0x00>; }; amvenc_avc { compatible = "amlogic, amvenc_avc"; dev_name = "amvenc_avc"; status = "okay"; interrupts = <0x00 0x2d 0x01>; interrupt-names = "mailbox_2"; }; hevc_enc { compatible = "cnm, HevcEnc"; dev_name = "HevcEnc"; status = "okay"; interrupts = <0x00 0xbb 0x01>; interrupt-names = "wave420l_irq"; #address-cells = <0x02>; #size-cells = <0x02>; ranges; io_reg_base { reg = <0x00 0xc8810000 0x00 0x4000>; }; }; vpu { compatible = "amlogic, vpu"; dev_name = "vpu"; status = "ok"; clk_level = <0x07>; }; bt-dev { compatible = "amlogic, bt-dev"; dev_name = "bt-dev"; status = "okay"; gpio_reset = <0x24 0x60 0x00>; }; rtc { compatible = "amlogic, aml_vrtc"; alarm_reg_addr = <0xc81000a8>; timer_e_addr = <0xc1109988>; init_date = "2015/01/01"; status = "okay"; }; wifi { compatible = "amlogic, aml_wifi"; dev_name = "aml_wifi"; status = "okay"; interrupt_pin = <0x24 0x56 0x00>; interrupts = <0x00 0x44 0x04>; irq_trigger_type = "GPIO_IRQ_LOW"; power_on_pin = <0x24 0x55 0x00>; dhd_static_buf; pinctrl-names = "wifi_32k_pins"; pinctrl-0 = <0x2d>; }; emmc { compatible = "amlogic, aml_sd_emmc"; dev_name = "aml_newsd.0"; status = "okay"; reg = <0x00 0xd0074000 0x00 0x2000>; interrupts = <0x00 0xda 0x01>; pinctrl-names = "emmc_clk_cmd_pins\0emmc_all_pins"; pinctrl-0 = <0x2e>; pinctrl-1 = <0x2f 0x30 0x31>; emmc { status = "disabled"; pinname = "emmc"; ocr_avail = <0x200080>; caps = "MMC_CAP_8_BIT_DATA\0MMC_CAP_MMC_HIGHSPEED\0MMC_CAP_SD_HIGHSPEED\0MMC_CAP_NONREMOVABLE\0MMC_CAP_1_8V_DDR\0MMC_CAP_HW_RESET\0MMC_CAP_ERASE\0MMC_CAP_CMD23"; caps2 = "MMC_CAP2_HS200\0MMC_CAP2_HS400"; f_min = <0x493e0>; f_max = <0x5f5e100>; max_req_size = <0x20000>; gpio_dat3 = <0x24 0x1d 0x00>; hw_reset = <0x24 0x23 0x00>; card_type = <0x01>; }; }; sd { compatible = "amlogic, aml_sd_emmc"; dev_name = "aml_newsd.0"; status = "okay"; reg = <0x00 0xd0072000 0x00 0x2000>; interrupts = <0x00 0xd9 0x01 0x00 0x43 0x01 0x00 0x45 0x01>; pinctrl-names = "sd_clk_cmd_pins\0sd_all_pins\0sd_1bit_pins\0sd_clk_cmd_uart_pins\0sd_1bit_uart_pins\0sd_to_ao_uart_pins\0ao_to_sd_uart_pins\0ao_to_sd_jtag_pins\0sd_to_ao_jtag_pins"; pinctrl-0 = <0x32>; pinctrl-1 = <0x33>; pinctrl-2 = <0x34>; pinctrl-3 = <0x35>; pinctrl-4 = <0x36>; pinctrl-5 = <0x37>; pinctrl-6 = <0x38>; pinctrl-7 = <0x39>; pinctrl-8 = <0x3a>; sd { status = "okay"; pinname = "sd"; ocr_avail = <0x200080>; caps = "MMC_CAP_4_BIT_DATA\0MMC_CAP_MMC_HIGHSPEED\0MMC_CAP_SD_HIGHSPEED"; f_min = <0x61a80>; f_max = <0x5f5e100>; max_req_size = <0x20000>; gpio_dat3 = <0x24 0x2e 0x00>; jtag_pin = <0x24 0x2a 0x00>; gpio_cd = <0x24 0x30 0x00>; card_in_delay = <0x190>; irq_in = <0x03>; irq_out = <0x05>; card_type = <0x05>; }; }; sdio { compatible = "amlogic, aml_sd_emmc"; dev_name = "aml_newsd.0"; status = "okay"; reg = <0x00 0xd0070000 0x00 0x2000>; interrupts = <0x00 0xd8 0x01>; pinctrl-names = "sdio_clk_cmd_pins\0sdio_all_pins"; pinctrl-0 = <0x3b>; pinctrl-1 = <0x3c>; sdio { status = "okay"; pinname = "sdio"; ocr_avail = <0x200080>; caps = "MMC_CAP_4_BIT_DATA\0MMC_CAP_MMC_HIGHSPEED\0MMC_CAP_SD_HIGHSPEED\0MMC_CAP_NONREMOVABLE\0MMC_CAP_UHS_SDR12\0MMC_CAP_UHS_SDR25\0MMC_CAP_UHS_SDR50\0MMC_CAP_UHS_SDR104\0MMC_PM_KEEP_POWER"; f_min = <0x61a80>; f_max = <0xbebc200>; max_req_size = <0x20000>; card_type = <0x03>; }; }; nand { compatible = "amlogic, aml_nand"; dev_name = "nand"; status = "disabled"; reg = <0x00 0xd0074800 0x00 0x200>; interrupts = <0x00 0x22 0x01>; pinctrl-names = "nand_rb_mod\0nand_norb_mod\0nand_cs_pins_only"; pinctrl-0 = <0x3d 0x3e 0x3f>; pinctrl-1 = <0x3d 0x3e 0x3f>; pinctrl-2 = <0x40>; device_id = <0x00>; plat-names = "nandnormal"; plat-num = <0x01>; plat-part-0 = <0x41>; normal { enable_pad = "ce0\0ce1\0ce2\0ce3"; busy_pad = "rb0"; linux,phandle = <0x41>; phandle = <0x41>; }; }; aml_nftl { compatible = "amlogic, nftl"; }; partitions { parts = <0x0b>; part-0 = <0x42>; part-1 = <0x43>; part-2 = <0x44>; part-3 = <0x45>; part-4 = <0x46>; part-5 = <0x47>; part-6 = <0x48>; part-7 = <0x49>; part-8 = <0x4a>; part-9 = <0x4b>; part-10 = <0x4c>; logo { pname = "logo"; size = <0x00 0x2000000>; mask = <0x01>; linux,phandle = <0x42>; phandle = <0x42>; }; recovery { pname = "recovery"; size = <0x00 0x2000000>; mask = <0x01>; linux,phandle = <0x43>; phandle = <0x43>; }; rsv { pname = "rsv"; size = <0x00 0x800000>; mask = <0x01>; linux,phandle = <0x44>; phandle = <0x44>; }; tee { pname = "tee"; size = <0x00 0x800000>; mask = <0x01>; linux,phandle = <0x45>; phandle = <0x45>; }; crypt { pname = "crypt"; size = <0x00 0x2000000>; mask = <0x01>; linux,phandle = <0x46>; phandle = <0x46>; }; misc { pname = "misc"; size = <0x00 0x2000000>; mask = <0x01>; linux,phandle = <0x47>; phandle = <0x47>; }; instaboot { pname = "instaboot"; size = <0x00 0x20000000>; mask = <0x01>; linux,phandle = <0x48>; phandle = <0x48>; }; boot { pname = "boot"; size = <0x00 0x2000000>; mask = <0x01>; linux,phandle = <0x49>; phandle = <0x49>; }; system { pname = "system"; size = <0x00 0x60000000>; mask = <0x01>; linux,phandle = <0x4a>; phandle = <0x4a>; }; cache { pname = "cache"; size = <0x00 0x20000000>; mask = <0x02>; linux,phandle = <0x4b>; phandle = <0x4b>; }; data { pname = "data"; size = <0xffffffff 0xffffffff>; mask = <0x04>; linux,phandle = <0x4c>; phandle = <0x4c>; }; }; unifykey { compatible = "amlogic, unifykey"; status = "ok"; unifykey-num = <0x0e>; unifykey-index-0 = <0x4d>; unifykey-index-1 = <0x4e>; unifykey-index-2 = <0x4f>; unifykey-index-3 = <0x50>; unifykey-index-4 = <0x51>; unifykey-index-5 = <0x52>; unifykey-index-6 = <0x53>; unifykey-index-7 = <0x54>; unifykey-index-8 = <0x55>; unifykey-index-9 = <0x56>; unifykey-index-10 = <0x57>; unifykey-index-11 = <0x58>; unifykey-index-12 = <0x59>; unifykey-index-13 = <0x5a>; key_0 { key-name = "usid"; key-device = "normal"; key-permit = "read\0write\0del"; linux,phandle = <0x4d>; phandle = <0x4d>; }; key_1 { key-name = "mac"; key-device = "normal"; key-permit = "read\0write\0del"; linux,phandle = <0x4e>; phandle = <0x4e>; }; key_2 { key-name = "hdcp"; key-device = "secure"; key-type = "sha1"; key-permit = "read\0write\0del"; linux,phandle = <0x4f>; phandle = <0x4f>; }; key_3 { key-name = "secure_boot_set"; key-device = "efuse"; key-permit = "write"; linux,phandle = <0x50>; phandle = <0x50>; }; key_4 { key-name = "mac_bt"; key-device = "normal"; key-permit = "read\0write\0del"; key-type = "mac"; linux,phandle = <0x51>; phandle = <0x51>; }; key_5 { key-name = "mac_wifi"; key-device = "normal"; key-permit = "read\0write\0del"; key-type = "mac"; linux,phandle = <0x52>; phandle = <0x52>; }; key_6 { key-name = "hdcp2_tx"; key-device = "normal"; key-permit = "read\0write\0del"; linux,phandle = <0x53>; phandle = <0x53>; }; key_7 { key-name = "hdcp2_rx"; key-device = "normal"; key-permit = "read\0write\0del"; linux,phandle = <0x54>; phandle = <0x54>; }; key_8 { key-name = "widevinekeybox"; key-device = "secure"; key-permit = "read\0write\0del"; linux,phandle = <0x55>; phandle = <0x55>; }; key_9 { key-name = "deviceid"; key-device = "normal"; key-permit = "read\0write\0del"; linux,phandle = <0x56>; phandle = <0x56>; }; key_10 { key-name = "hdcp22_fw_private"; key-device = "secure"; key-permit = "read\0write\0del"; linux,phandle = <0x57>; phandle = <0x57>; }; key_11 { key-name = "PlayReadykeybox25"; key-device = "secure"; key-permit = "read\0write\0del"; linux,phandle = <0x58>; phandle = <0x58>; }; key_12 { key-name = "prpubkeybox"; key-device = "secure"; key-permit = "read\0write\0del"; linux,phandle = <0x59>; phandle = <0x59>; }; key_13 { key-name = "prprivkeybox"; key-device = "secure"; key-permit = "read\0write\0del"; linux,phandle = <0x5a>; phandle = <0x5a>; }; }; amhdmitx { compatible = "amlogic, amhdmitx"; dev_name = "amhdmitx"; status = "okay"; pinctrl-names = "hdmitx_hpd\0hdmitx_ddc"; pinctrl-0 = <0x5b>; pinctrl-1 = <0x5c>; interrupts = <0x00 0x39 0x01>; interrupt-names = "hdmitx_hpd"; clocks = <0x06 0x0b 0x06 0x0c 0x06 0x0d 0x06 0x0e 0x06 0x0f 0x06 0x16>; clock-names = "hdmitx_clk_sys\0hdmitx_clk_encp\0hdmitx_clk_enci\0hdmitx_clk_pixel\0hdmitx_clk_phy\0hdmitx_clk_vid"; gpio_i2c_en = <0x01>; #address-cells = <0x02>; #size-cells = <0x02>; ranges; }; aocec { compatible = "amlogic, amlogic-aocec"; device_name = "aocec"; status = "okay"; vendor_name = "Amlogic"; vendor_id = <0x00>; product_desc = "GXBB Mbox"; cec_osd_string = "MBox"; port_num = <0x01>; arc_port_mask = <0x00>; interrupts = <0x00 0xc7 0x01>; interrupt-names = "hdmi_aocec"; pinctrl-names = "hdmitx_aocec"; pinctrl-0 = <0x5d>; reg = <0x00 0xc810023c 0x00 0x04 0x00 0xc8100000 0x00 0x200>; }; tvout { compatible = "amlogic, tvout"; dev_name = "tvout"; status = "okay"; }; i2c_gpio { compatible = "i2c-gpio"; status = "okay"; dev_name = "i2c-gpio"; i2c-gpio,delay-us = <0x0a>; gpios = <0x24 0x11 0x00 0x24 0x12 0x00>; #address-cells = <0x02>; #size-cells = <0x02>; i2c-gpio,timeout-ms = <0x0a>; i2c_gpio_edid { compatible = "i2c-gpio-edid"; reg = <0x50 0x00 0x00 0x00>; }; }; serial@c81004c0 { compatible = "amlogic, meson-uart"; reg = <0x00 0xc81004c0 0x00 0x18>; interrupts = <0x00 0xc1 0x01>; status = "okay"; clocks = <0x06 0x02>; clock-names = "clk_uart"; xtal_tick_en = <0x01>; fifosize = <0x40>; pinctrl-names = "default"; support-sysrq = <0x00>; }; serial@c11084c0 { compatible = "amlogic, meson-uart"; reg = <0x00 0xc11084c0 0x00 0x18>; interrupts = <0x00 0x1a 0x01>; status = "okay"; clocks = <0x06 0x02>; clock-names = "clk_uart"; fifosize = <0x80>; pinctrl-names = "default"; pinctrl-0 = <0x5e>; resets = <0x06 0x0d>; }; serial@c11084dc { compatible = "amlogic, meson-uart"; reg = <0x00 0xc11084dc 0x00 0x18>; interrupts = <0x00 0x4b 0x01>; status = "disable"; clocks = <0x06 0x02>; clock-names = "clk_uart"; fifosize = <0x40>; pinctrl-names = "default"; pinctrl-0 = <0x5f>; resets = <0x06 0x30>; }; serial@c1108700 { compatible = "amlogic, meson-uart"; reg = <0x00 0xc1108700 0x00 0x18>; interrupts = <0x00 0x5d 0x01>; status = "disable"; clocks = <0x06 0x02>; clock-names = "clk_uart"; fifosize = <0x40>; pinctrl-names = "default"; pinctrl-0 = <0x60>; resets = <0x06 0x4f>; }; serial@c81004e0 { compatible = "amlogic, meson-uart"; reg = <0x00 0xc81004e0 0x00 0x18>; interrupts = <0x00 0xc5 0x01>; status = "disable"; clocks = <0x06 0x02>; clock-names = "clk_uart"; fifosize = <0x40>; pinctrl-names = "default"; pinctrl-0 = <0x61>; }; canvas { compatible = "amlogic, meson, canvas"; dev_name = "amlogic-canvas"; status = "ok"; reg = <0x00 0xc8838000 0x00 0x400>; }; rdma { compatible = "amlogic, meson, rdma"; dev_name = "amlogic-rdma"; status = "ok"; interrupts = <0x00 0x59 0x01>; interrupt-names = "rdma"; }; dwc3@c9000000 { compatible = "synopsys, dwc3"; reg = <0x00 0xc9000000 0x00 0x100000>; interrupts = <0x00 0x1e 0x04>; usb-phy = <0x62 0x63>; cpu-type = "gxl"; clock-src = "usb3.0"; }; usb2phy@d0078000 { compatible = "amlogic, amlogic-new-usb2"; portnum = <0x03>; reg = <0x00 0xd0078000 0x00 0x80>; linux,phandle = <0x62>; phandle = <0x62>; }; usb3phy@d0078080 { compatible = "amlogic, amlogic-new-usb3"; portnum = <0x00>; reg = <0x00 0xd0078080 0x00 0x20>; interrupts = <0x00 0x10 0x04>; otg = <0x01>; gpio-vbus-power = "GPIOAO_5"; gpios = <0x25 0x05 0x00>; linux,phandle = <0x63>; phandle = <0x63>; }; dwc2_a { compatible = "amlogic,dwc2"; device_name = "dwc2_a"; reg = <0x00 0xc9100000 0x00 0x40000>; status = "okay"; interrupts = <0x00 0x1f 0x04>; pl-periph-id = <0x00>; clock-src = "usb0"; port-id = <0x00>; port-type = <0x02>; port-speed = <0x00>; port-config = <0x00>; port-dma = <0x00>; port-id-mode = <0x00>; usb-fifo = <0x2d8>; cpu-type = "gxl"; controller-type = <0x03>; phy-reg = <0xd0078000>; phy-reg-size = <0xa0>; resets = <0x06 0x3a 0x06 0x48 0x06 0x36>; reset-names = "usb_general\0usb1\0usb1_to_ddr"; }; I2S { #sound-dai-cells = <0x00>; resets = <0x06 0x26 0x06 0x12 0x06 0x28 0x06 0x29 0x06 0x2a 0x06 0x2b 0x06 0x2c 0x06 0x2d 0x06 0x2f 0x06 0x8e 0x06 0x22>; reset-names = "top_glue\0aud_buf\0i2s_out\0amclk_measure\0aififo2\0aud_mixer\0mixer_reg\0adc\0top_level\0aoclk\0aud_in"; clocks = <0x06 0x21 0x06 0x22>; clock-names = "mpll2\0mclk"; compatible = "amlogic, aml-i2s-dai"; linux,phandle = <0x6f>; phandle = <0x6f>; }; SPDIF { #sound-dai-cells = <0x00>; compatible = "amlogic, aml-spdif-dai"; resets = <0x06 0x27 0x06 0x90>; reset-names = "iec958\0iec958_amclk"; clocks = <0x06 0x20 0x06 0x24 0x06 0x22 0x06 0x25 0x06 0x0a>; clock-names = "mpll1\0i958\0mclk\0spdif\0clk_81"; linux,phandle = <0x70>; phandle = <0x70>; }; PCM { #sound-dai-cells = <0x00>; compatible = "amlogic, aml-pcm-dai"; pinctrl-names = "aml_audio_btpcm"; pinctrl-0 = <0x64>; clocks = <0x06 0x1f 0x06 0x2a 0x06 0x2b>; clock-names = "mpll0\0pcm_mclk\0pcm_sclk"; pcm_mode = <0x01>; linux,phandle = <0x71>; phandle = <0x71>; }; i2s_platform { compatible = "amlogic, aml-i2s"; interrupts = <0x00 0x1d 0x01>; linux,phandle = <0x6d>; phandle = <0x6d>; }; pcm_platform { compatible = "amlogic, aml-pcm"; linux,phandle = <0x6e>; phandle = <0x6e>; }; spdif_codec { #sound-dai-cells = <0x00>; compatible = "amlogic, aml-spdif-codec"; pinctrl-names = "aml_audio_spdif"; pinctrl-0 = <0x65>; linux,phandle = <0x73>; phandle = <0x73>; }; pcm_codec { #sound-dai-cells = <0x00>; compatible = "amlogic, pcm2BT-codec"; linux,phandle = <0x74>; phandle = <0x74>; }; dummy { #sound-dai-cells = <0x00>; compatible = "amlogic, aml_dummy_codec"; status = "disable"; }; t9015 { #sound-dai-cells = <0x00>; compatible = "amlogic, aml_codec_T9015"; reg = <0x00 0xc8832000 0x00 0x14>; status = "okay"; linux,phandle = <0x72>; phandle = <0x72>; }; aml_m8_snd { compatible = "aml, aml_snd_m8"; status = "okay"; aml-sound-card,format = "i2s"; aml_sound_card,name = "AML-M8AUDIO"; aml,audio-routing = "Ext Spk\0LOUTL\0Ext Spk\0LOUTR"; mute_gpio-gpios = <0x24 0x15 0x00>; mute_inv; hp_disable; hp_paraments = <0x320 0x12c 0x00 0x05 0x01>; pinctrl-names = "aml_snd_m8"; pinctrl-0 = <0x66>; cpu_list = <0x67 0x68 0x69>; codec_list = <0x6a 0x6b 0x6c>; plat_list = <0x6d 0x6d 0x6e>; cpudai0 { sound-dai = <0x6f>; linux,phandle = <0x67>; phandle = <0x67>; }; cpudai1 { sound-dai = <0x70>; linux,phandle = <0x68>; phandle = <0x68>; }; cpudai2 { sound-dai = <0x71>; linux,phandle = <0x69>; phandle = <0x69>; }; codec0 { sound-dai = <0x72>; linux,phandle = <0x6a>; phandle = <0x6a>; }; codec1 { sound-dai = <0x73>; linux,phandle = <0x6b>; phandle = <0x6b>; }; codec2 { sound-dai = <0x74>; linux,phandle = <0x6c>; phandle = <0x6c>; }; }; gpio_keypad { compatible = "amlogic, gpio_keypad"; status = "okay"; scan_period = <0x14>; key_num = <0x01>; key_name = "power"; key_code = <0x74>; key_pin = <0x25 0x02 0x00>; irq_keyup = <0x06>; irq_keydown = <0x07>; }; aml-sensor@0 { compatible = "amlogic, aml-thermal"; device_name = "thermal"; #thermal-sensor-cells = <0x01>; linux,phandle = <0x75>; phandle = <0x75>; cooling_devices { cpufreq_cool_cluster0 { min_state = <0xf4240>; dyn_coeff = <0x8c>; cluster_id = <0x00>; node_name = "cluster0"; device_type = "cpufreq"; }; cpufreq_cool_cluster1 { min_state = <0x7a120>; dyn_coeff = <0x8c>; cluster_id = <0x01>; node_name = "cluster1"; device_type = "cpufreq"; }; cpucore_cool_cluster0 { min_state = <0x01>; dyn_coeff = <0x00>; cluster_id = <0x00>; node_name = "cpu_core_cluster0"; device_type = "cpucore"; }; cpucore_cool_cluster1 { min_state = <0x01>; dyn_coeff = <0x00>; cluster_id = <0x01>; node_name = "cpu_core_cluster1"; device_type = "cpucore"; }; gpufreq_cool { min_state = <0x190>; dyn_coeff = <0x1b5>; cluster_id = <0x00>; node_name = "t82x"; device_type = "gpufreq"; }; gpucore_cool { min_state = <0x01>; dyn_coeff = <0x00>; cluster_id = <0x00>; node_name = "thermal_gpu_cores"; device_type = "gpucore"; }; }; cpu_core_cluster0 { #cooling-cells = <0x02>; linux,phandle = <0x79>; phandle = <0x79>; }; cpu_core_cluster1 { #cooling-cells = <0x02>; linux,phandle = <0x7a>; phandle = <0x7a>; }; thermal_gpu_cores { #cooling-cells = <0x02>; linux,phandle = <0x7c>; phandle = <0x7c>; }; }; thermal-zones { soc_thermal { polling-delay = <0x3e8>; polling-delay-passive = <0x64>; sustainable-power = <0x992>; thermal-sensors = <0x75 0x03>; trips { trip-point@0 { temperature = <0x11170>; hysteresis = <0x3e8>; type = "passive"; }; trip-point@1 { temperature = <0x13880>; hysteresis = <0x3e8>; type = "passive"; linux,phandle = <0x76>; phandle = <0x76>; }; trip-point@2 { temperature = <0x14c08>; hysteresis = <0x1388>; type = "hot"; }; trip-point@3 { temperature = <0x3f7a0>; hysteresis = <0x3e8>; type = "critical"; }; }; cooling-maps { cpufreq_cooling_map0 { trip = <0x76>; cooling-device = <0x77 0x00 0x04>; contribution = <0x400>; }; cpufreq_cooling_map1 { trip = <0x76>; cooling-device = <0x78 0x00 0x04>; contribution = <0x400>; }; cpucore_cooling_map0 { trip = <0x76>; cooling-device = <0x79 0x00 0x03>; contribution = <0x400>; }; cpucore_cooling_map1 { trip = <0x76>; cooling-device = <0x7a 0x00 0x03>; contribution = <0x400>; }; gpufreq_cooling_map { trip = <0x76>; cooling-device = <0x7b 0x00 0x04>; contribution = <0x400>; }; gpucore_cooling_map { trip = <0x76>; cooling-device = <0x7c 0x00 0x02>; contribution = <0x400>; }; }; }; }; };