mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-18 07:56:37 +07:00
07f08d9cee
Rockchip SoCs use 2 different numbering schemes. Where the gpio- controllers just count 0-31 for their 32 gpios, the underlying iomux controller splits these into 4 separate entities A-D. Device-schematics always use these iomux-values to identify pins, so to make mapping schematics to devicetree easier Andy Yan introduced named constants for the pins but so far we only used them on new additions. Using a sed-script created by Emil Renner Berthing bulk-convert the remaining raw gpio numbers into their descriptive counterparts and also gets rid of the unhelpful RK_FUNC_x -> x and RK_GPIOx -> x mappings: /rockchip,pins *=/bcheck b # to end of script :append-next-line N :check /^[^;]*$/bappend-next-line s/<RK_GPIO\([0-9]\) /<\1 /g s/<\([^ ][^ ]* *\)0 /<\1RK_PA0 /g s/<\([^ ][^ ]* *\)1 /<\1RK_PA1 /g s/<\([^ ][^ ]* *\)2 /<\1RK_PA2 /g s/<\([^ ][^ ]* *\)3 /<\1RK_PA3 /g s/<\([^ ][^ ]* *\)4 /<\1RK_PA4 /g s/<\([^ ][^ ]* *\)5 /<\1RK_PA5 /g s/<\([^ ][^ ]* *\)6 /<\1RK_PA6 /g s/<\([^ ][^ ]* *\)7 /<\1RK_PA7 /g s/<\([^ ][^ ]* *\)8 /<\1RK_PB0 /g s/<\([^ ][^ ]* *\)9 /<\1RK_PB1 /g s/<\([^ ][^ ]* *\)10 /<\1RK_PB2 /g s/<\([^ ][^ ]* *\)11 /<\1RK_PB3 /g s/<\([^ ][^ ]* *\)12 /<\1RK_PB4 /g s/<\([^ ][^ ]* *\)13 /<\1RK_PB5 /g s/<\([^ ][^ ]* *\)14 /<\1RK_PB6 /g s/<\([^ ][^ ]* *\)15 /<\1RK_PB7 /g s/<\([^ ][^ ]* *\)16 /<\1RK_PC0 /g s/<\([^ ][^ ]* *\)17 /<\1RK_PC1 /g s/<\([^ ][^ ]* *\)18 /<\1RK_PC2 /g s/<\([^ ][^ ]* *\)19 /<\1RK_PC3 /g s/<\([^ ][^ ]* *\)20 /<\1RK_PC4 /g s/<\([^ ][^ ]* *\)21 /<\1RK_PC5 /g s/<\([^ ][^ ]* *\)22 /<\1RK_PC6 /g s/<\([^ ][^ ]* *\)23 /<\1RK_PC7 /g s/<\([^ ][^ ]* *\)24 /<\1RK_PD0 /g s/<\([^ ][^ ]* *\)25 /<\1RK_PD1 /g s/<\([^ ][^ ]* *\)26 /<\1RK_PD2 /g s/<\([^ ][^ ]* *\)27 /<\1RK_PD3 /g s/<\([^ ][^ ]* *\)28 /<\1RK_PD4 /g s/<\([^ ][^ ]* *\)29 /<\1RK_PD5 /g s/<\([^ ][^ ]* *\)30 /<\1RK_PD6 /g s/<\([^ ][^ ]* *\)31 /<\1RK_PD7 /g s/<\([^ ][^ ]* *[^ ][^ ]* *\)0 /<\1RK_FUNC_GPIO /g s/<\([^ ][^ ]* *[^ ][^ ]* *\)RK_FUNC_\([1-9]\) /<\1\2 /g Suggested-by: Emil Renner Berthing <esmil@mailme.dk> Signed-off-by: Heiko Stuebner <heiko@sntech.de>
274 lines
5.6 KiB
Plaintext
274 lines
5.6 KiB
Plaintext
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
|
|
|
#include <dt-bindings/pwm/pwm.h>
|
|
#include "rk3288.dtsi"
|
|
|
|
/ {
|
|
memory@0 {
|
|
reg = <0x0 0x0 0x0 0x80000000>;
|
|
device_type = "memory";
|
|
};
|
|
|
|
emmc_pwrseq: emmc-pwrseq {
|
|
compatible = "mmc-pwrseq-emmc";
|
|
pinctrl-0 = <&emmc_reset>;
|
|
pinctrl-names = "default";
|
|
reset-gpios = <&gpio3 RK_PB1 GPIO_ACTIVE_LOW>;
|
|
};
|
|
|
|
ext_gmac: external-gmac-clock {
|
|
compatible = "fixed-clock";
|
|
#clock-cells = <0>;
|
|
clock-frequency = <125000000>;
|
|
clock-output-names = "ext_gmac";
|
|
};
|
|
|
|
vcc_flash: flash-regulator {
|
|
compatible = "regulator-fixed";
|
|
regulator-name = "vcc_flash";
|
|
regulator-min-microvolt = <1800000>;
|
|
regulator-max-microvolt = <1800000>;
|
|
startup-delay-us = <150>;
|
|
vin-supply = <&vcc_io>;
|
|
};
|
|
|
|
vcc_sys: vsys-regulator {
|
|
compatible = "regulator-fixed";
|
|
regulator-name = "vcc_sys";
|
|
regulator-min-microvolt = <5000000>;
|
|
regulator-max-microvolt = <5000000>;
|
|
regulator-always-on;
|
|
regulator-boot-on;
|
|
};
|
|
};
|
|
|
|
&cpu0 {
|
|
cpu0-supply = <&vdd_cpu>;
|
|
};
|
|
|
|
&emmc {
|
|
bus-width = <8>;
|
|
cap-mmc-highspeed;
|
|
disable-wp;
|
|
non-removable;
|
|
mmc-pwrseq = <&emmc_pwrseq>;
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&emmc_clk &emmc_cmd &emmc_bus8>;
|
|
vmmc-supply = <&vcc_io>;
|
|
vqmmc-supply = <&vcc_flash>;
|
|
status = "okay";
|
|
};
|
|
|
|
&gmac {
|
|
assigned-clocks = <&cru SCLK_MAC>;
|
|
assigned-clock-parents = <&ext_gmac>;
|
|
clock_in_out = "input";
|
|
phy-mode = "rgmii";
|
|
phy-supply = <&vccio_pmu>;
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&rgmii_pins &phy_rst>;
|
|
snps,reset-gpio = <&gpio4 RK_PB0 GPIO_ACTIVE_LOW>;
|
|
snps,reset-active-low;
|
|
snps,reset-delays-us = <0 10000 30000>;
|
|
rx_delay = <0x10>;
|
|
tx_delay = <0x30>;
|
|
};
|
|
|
|
&gpu {
|
|
mali-supply = <&vdd_gpu>;
|
|
status = "okay";
|
|
};
|
|
|
|
&i2c0 {
|
|
status = "okay";
|
|
|
|
act8846: act8846@5a {
|
|
compatible = "active-semi,act8846";
|
|
reg = <0x5a>;
|
|
system-power-controller;
|
|
inl1-supply = <&vcc_io>;
|
|
inl2-supply = <&vcc_sys>;
|
|
inl3-supply = <&vcc_20>;
|
|
vp1-supply = <&vcc_sys>;
|
|
vp2-supply = <&vcc_sys>;
|
|
vp3-supply = <&vcc_sys>;
|
|
vp4-supply = <&vcc_sys>;
|
|
|
|
regulators {
|
|
vcc_ddr: REG1 {
|
|
regulator-name = "VCC_DDR";
|
|
regulator-min-microvolt = <1200000>;
|
|
regulator-max-microvolt = <1200000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcc_io: vccio_codec: REG2 {
|
|
regulator-name = "VCC_IO";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vdd_log: REG3 {
|
|
regulator-name = "VDD_LOG";
|
|
regulator-min-microvolt = <1000000>;
|
|
regulator-max-microvolt = <1000000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcc_20: REG4 {
|
|
regulator-name = "VCC_20";
|
|
regulator-min-microvolt = <2000000>;
|
|
regulator-max-microvolt = <2000000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vccio_sd: REG5 {
|
|
regulator-name = "VCCIO_SD";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vdd10_lcd: REG6 {
|
|
regulator-name = "VDD10_LCD";
|
|
regulator-min-microvolt = <1000000>;
|
|
regulator-max-microvolt = <1000000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcca_codec: REG7 {
|
|
regulator-name = "VCCA_CODEC";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcca_tp: REG8 {
|
|
regulator-name = "VCCA_TP";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vccio_pmu: REG9 {
|
|
regulator-name = "VCCIO_PMU";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vdd_10: REG10 {
|
|
regulator-name = "VDD_10";
|
|
regulator-min-microvolt = <1000000>;
|
|
regulator-max-microvolt = <1000000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcc_18: REG11 {
|
|
regulator-name = "VCC_18";
|
|
regulator-min-microvolt = <1800000>;
|
|
regulator-max-microvolt = <1800000>;
|
|
regulator-always-on;
|
|
};
|
|
|
|
vcc18_lcd: REG12 {
|
|
regulator-name = "VCC18_LCD";
|
|
regulator-min-microvolt = <1800000>;
|
|
regulator-max-microvolt = <1800000>;
|
|
regulator-always-on;
|
|
};
|
|
};
|
|
};
|
|
|
|
vdd_cpu: syr827@40 {
|
|
compatible = "silergy,syr827";
|
|
reg = <0x40>;
|
|
fcs,suspend-voltage-selector = <1>;
|
|
regulator-always-on;
|
|
regulator-boot-on;
|
|
regulator-enable-ramp-delay = <300>;
|
|
regulator-name = "vdd_cpu";
|
|
regulator-min-microvolt = <850000>;
|
|
regulator-max-microvolt = <1350000>;
|
|
regulator-ramp-delay = <8000>;
|
|
vin-supply = <&vcc_sys>;
|
|
};
|
|
|
|
vdd_gpu: syr828@41 {
|
|
compatible = "silergy,syr828";
|
|
reg = <0x41>;
|
|
fcs,suspend-voltage-selector = <1>;
|
|
regulator-always-on;
|
|
regulator-enable-ramp-delay = <300>;
|
|
regulator-min-microvolt = <850000>;
|
|
regulator-max-microvolt = <1350000>;
|
|
regulator-name = "vdd_gpu";
|
|
regulator-ramp-delay = <8000>;
|
|
vin-supply = <&vcc_sys>;
|
|
};
|
|
};
|
|
|
|
&io_domains {
|
|
status = "okay";
|
|
|
|
audio-supply = <&vcc_io>;
|
|
bb-supply = <&vcc_io>;
|
|
dvp-supply = <&vcc_18>;
|
|
flash0-supply = <&vcc_flash>;
|
|
flash1-supply = <&vccio_pmu>;
|
|
gpio30-supply = <&vccio_pmu>;
|
|
gpio1830 = <&vcc_io>;
|
|
lcdc-supply = <&vcc_io>;
|
|
sdcard-supply = <&vccio_sd>;
|
|
wifi-supply = <&vcc_18>;
|
|
};
|
|
|
|
&pinctrl {
|
|
pcfg_output_high: pcfg-output-high {
|
|
output-high;
|
|
};
|
|
|
|
emmc {
|
|
emmc_reset: emmc-reset {
|
|
rockchip,pins = <3 RK_PB1 RK_FUNC_GPIO &pcfg_pull_none>;
|
|
};
|
|
};
|
|
|
|
gmac {
|
|
phy_rst: phy-rst {
|
|
rockchip,pins = <4 RK_PB0 RK_FUNC_GPIO &pcfg_output_high>;
|
|
};
|
|
};
|
|
};
|
|
|
|
&saradc {
|
|
vref-supply = <&vcc_18>;
|
|
};
|
|
|
|
&tsadc {
|
|
rockchip,hw-tshut-mode = <0>; /* tshut mode 0:CRU 1:GPIO */
|
|
rockchip,hw-tshut-polarity = <0>; /* tshut polarity 0:LOW 1:HIGH */
|
|
status = "okay";
|
|
};
|
|
|
|
&vopb {
|
|
status = "okay";
|
|
};
|
|
|
|
&vopb_mmu {
|
|
status = "okay";
|
|
};
|
|
|
|
&vopl {
|
|
status = "okay";
|
|
};
|
|
|
|
&vopl_mmu {
|
|
status = "okay";
|
|
};
|
|
|
|
&wdt {
|
|
status = "okay";
|
|
};
|