Commit 819167e7 authored by Olof Johansson's avatar Olof Johansson

Merge tag 'samsung-late-dt' of...

Merge tag 'samsung-late-dt' of git://git.kernel.org/pub/scm/linux/kernel/git/kgene/linux-samsung into next/late

Samsung 2nd DT updates for v4.3

- for exynos3250, 4212, 4412 and 5250
  : add CPU OPP and regulator supply property

- for exynos3250
  : add CPU cooling binding for exynos3250 boards

- for exynos4 SoCs
  : add iommu property to JPEG device

- for exynos4412-odroidu3
  : enable SPI1

- for exynos5250-snow
  : add SPI CS

- for exynos5422
  : add exynos5422-cpus.dtsi to correct cpu order

* Note this branch is depending on tags/samsung-clk-driver

* tag 'samsung-late-dt' of git://git.kernel.org/pub/scm/linux/kernel/git/kgene/linux-samsung: (22 commits)
  ARM: dts: add iommu property to JPEG device for exynos4
  ARM: dts: enable SPI1 for exynos4412-odroidu3
  ARM: dts: Add SPI CS on exynos5250-snow
  ARM: dts: Add CPU cooling binding for exynos3250 boards
  ARM: dts: add exynos5422-cpus.dtsi to correct cpu order
  ARM: dts: add CPU OPP and regulator supply property for exynos4x12
  ARM: dts: Add CPU OPP and regulator supply property for exynos3250
  ARM: dts: add CPU OPP and regulator supply property for exynos5250
  ARM: dts: Extend exynos5420-pinctrl nodes using labels instead of paths
  ARM: dts: Include exynos5420-pinctrl after the nodes were defined for exynos5420
  ARM: dts: Extend exynos5250-pinctrl nodes using labels instead of paths
  ARM: dts: Include exynos5250-pinctrl after the nodes were defined for exynos5250
  ARM: dts: Enable thermal-zones for exynos5422-odroidxu3
  ARM: dts: Define default thermal-zones for exynos5422
  ARM: dts: Enable TMU for exynos5422-odroidxu3
  ARM: dts: Add pwm-fan node for exynos5422-odroidxu3
  ARM: dts: Use labels for overriding nodes for exynos4210-universal_c210
  ARM: dts: Set max17047 over heat and voltage thresholds for exynos4412-trats2
  ARM: dts: Enable USB3 regulators for exynos5422-odroidxu3
  ARM: dts: Clean up indentation for exynos5410-smdk5410
  ...
Signed-off-by: default avatarOlof Johansson <olof@lixom.net>
parents 6b077058 ba032795
...@@ -116,6 +116,21 @@ haptics { ...@@ -116,6 +116,21 @@ haptics {
min-microvolt = <1100000>; min-microvolt = <1100000>;
max-microvolt = <2700000>; max-microvolt = <2700000>;
}; };
thermal-zones {
cpu_thermal: cpu-thermal {
cooling-maps {
map0 {
/* Correspond to 500MHz at freq_table */
cooling-device = <&cpu0 5 5>;
};
map1 {
/* Correspond to 200MHz at freq_table */
cooling-device = <&cpu0 8 8>;
};
};
};
};
}; };
&adc { &adc {
...@@ -141,6 +156,10 @@ thermistor-battery { ...@@ -141,6 +156,10 @@ thermistor-battery {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&exynos_usbphy { &exynos_usbphy {
status = "okay"; status = "okay";
}; };
......
...@@ -107,6 +107,21 @@ haptics { ...@@ -107,6 +107,21 @@ haptics {
min-microvolt = <1100000>; min-microvolt = <1100000>;
max-microvolt = <2700000>; max-microvolt = <2700000>;
}; };
thermal-zones {
cpu_thermal: cpu-thermal {
cooling-maps {
map0 {
/* Corresponds to 500MHz */
cooling-device = <&cpu0 5 5>;
};
map1 {
/* Corresponds to 200MHz */
cooling-device = <&cpu0 8 8>;
};
};
};
};
}; };
&adc { &adc {
...@@ -132,6 +147,10 @@ thermistor-battery { ...@@ -132,6 +147,10 @@ thermistor-battery {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&exynos_usbphy { &exynos_usbphy {
status = "okay"; status = "okay";
}; };
......
...@@ -53,6 +53,22 @@ cpu0: cpu@0 { ...@@ -53,6 +53,22 @@ cpu0: cpu@0 {
compatible = "arm,cortex-a7"; compatible = "arm,cortex-a7";
reg = <0>; reg = <0>;
clock-frequency = <1000000000>; clock-frequency = <1000000000>;
clocks = <&cmu CLK_ARM_CLK>;
clock-names = "cpu";
#cooling-cells = <2>;
operating-points = <
1000000 1150000
900000 1112500
800000 1075000
700000 1037500
600000 1000000
500000 962500
400000 925000
300000 887500
200000 850000
100000 850000
>;
}; };
cpu1: cpu@1 { cpu1: cpu@1 {
...@@ -138,8 +154,8 @@ pmu_system_controller: system-controller@10020000 { ...@@ -138,8 +154,8 @@ pmu_system_controller: system-controller@10020000 {
mipi_phy: video-phy@10020710 { mipi_phy: video-phy@10020710 {
compatible = "samsung,s5pv210-mipi-video-phy"; compatible = "samsung,s5pv210-mipi-video-phy";
reg = <0x10020710 8>;
#phy-cells = <1>; #phy-cells = <1>;
syscon = <&pmu_system_controller>;
}; };
pd_cam: cam-power-domain@10023C00 { pd_cam: cam-power-domain@10023C00 {
......
...@@ -702,6 +702,7 @@ jpeg_codec: jpeg-codec@11840000 { ...@@ -702,6 +702,7 @@ jpeg_codec: jpeg-codec@11840000 {
clocks = <&clock CLK_JPEG>; clocks = <&clock CLK_JPEG>;
clock-names = "jpeg"; clock-names = "jpeg";
power-domains = <&pd_cam>; power-domains = <&pd_cam>;
iommus = <&sysmmu_jpeg>;
}; };
hdmi: hdmi@12D00000 { hdmi: hdmi@12D00000 {
......
...@@ -127,6 +127,10 @@ timing0: timing { ...@@ -127,6 +127,10 @@ timing0: timing {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck1_reg>;
};
&fimd { &fimd {
pinctrl-0 = <&lcd_en &lcd_clk &lcd_data24 &pwm0_out>; pinctrl-0 = <&lcd_en &lcd_clk &lcd_data24 &pwm0_out>;
pinctrl-names = "default"; pinctrl-names = "default";
......
...@@ -188,6 +188,10 @@ fimc_3: fimc@11830000 { ...@@ -188,6 +188,10 @@ fimc_3: fimc@11830000 {
}; };
}; };
&cpu0 {
cpu0-supply = <&varm_breg>;
};
&dsi_0 { &dsi_0 {
vddcore-supply = <&vusb_reg>; vddcore-supply = <&vusb_reg>;
vddio-supply = <&vmipi_reg>; vddio-supply = <&vmipi_reg>;
......
...@@ -69,66 +69,6 @@ vemmc_reg: voltage-regulator { ...@@ -69,66 +69,6 @@ vemmc_reg: voltage-regulator {
enable-active-high; enable-active-high;
}; };
hsotg@12480000 {
vusb_d-supply = <&ldo3_reg>;
vusb_a-supply = <&ldo8_reg>;
dr_mode = "peripheral";
status = "okay";
};
sdhci_emmc: sdhci@12510000 {
bus-width = <8>;
non-removable;
pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus8>;
pinctrl-names = "default";
vmmc-supply = <&vemmc_reg>;
status = "okay";
};
sdhci_sd: sdhci@12530000 {
bus-width = <4>;
pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4>;
pinctrl-names = "default";
vmmc-supply = <&ldo5_reg>;
cd-gpios = <&gpx3 4 0>;
cd-inverted;
status = "okay";
};
ehci@12580000 {
status = "okay";
port@0 {
status = "okay";
};
};
ohci@12590000 {
status = "okay";
port@0 {
status = "okay";
};
};
exynos-usbphy@125B0000 {
status = "okay";
};
serial@13800000 {
status = "okay";
};
serial@13810000 {
status = "okay";
};
serial@13820000 {
status = "okay";
};
serial@13830000 {
status = "okay";
};
gpio-keys { gpio-keys {
compatible = "gpio-keys"; compatible = "gpio-keys";
...@@ -186,7 +126,166 @@ tsp_reg: voltage-regulator { ...@@ -186,7 +126,166 @@ tsp_reg: voltage-regulator {
enable-active-high; enable-active-high;
}; };
i2c@13890000 { spi-lcd {
compatible = "spi-gpio";
#address-cells = <1>;
#size-cells = <0>;
gpio-sck = <&gpy3 1 0>;
gpio-mosi = <&gpy3 3 0>;
num-chipselects = <1>;
cs-gpios = <&gpy4 3 0>;
lcd@0 {
compatible = "samsung,ld9040";
reg = <0>;
vdd3-supply = <&ldo7_reg>;
vci-supply = <&ldo17_reg>;
reset-gpios = <&gpy4 5 0>;
spi-max-frequency = <1200000>;
spi-cpol;
spi-cpha;
power-on-delay = <10>;
reset-delay = <10>;
panel-width-mm = <90>;
panel-height-mm = <154>;
display-timings {
timing {
clock-frequency = <23492370>;
hactive = <480>;
vactive = <800>;
hback-porch = <16>;
hfront-porch = <16>;
vback-porch = <2>;
vfront-porch = <28>;
hsync-len = <2>;
vsync-len = <1>;
hsync-active = <0>;
vsync-active = <0>;
de-active = <0>;
pixelclk-active = <0>;
};
};
port {
lcd_ep: endpoint {
remote-endpoint = <&fimd_dpi_ep>;
};
};
};
};
camera {
status = "okay";
pinctrl-names = "default";
pinctrl-0 = <>;
fimc_0: fimc@11800000 {
status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC0>,
<&clock CLK_SCLK_FIMC0>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
fimc_1: fimc@11810000 {
status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC1>,
<&clock CLK_SCLK_FIMC1>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
fimc_2: fimc@11820000 {
status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC2>,
<&clock CLK_SCLK_FIMC2>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
fimc_3: fimc@11830000 {
status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC3>,
<&clock CLK_SCLK_FIMC3>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
};
hdmi_en: voltage-regulator-hdmi-5v {
compatible = "regulator-fixed";
regulator-name = "HDMI_5V";
regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>;
gpio = <&gpe0 1 0>;
enable-active-high;
};
hdmi_ddc: i2c-ddc {
compatible = "i2c-gpio";
gpios = <&gpe4 2 0 &gpe4 3 0>;
i2c-gpio,delay-us = <100>;
#address-cells = <1>;
#size-cells = <0>;
pinctrl-0 = <&i2c_ddc_bus>;
pinctrl-names = "default";
status = "okay";
};
};
&cpu0 {
cpu0-supply = <&vdd_arm_reg>;
};
&ehci {
status = "okay";
port@0 {
status = "okay";
};
};
&exynos_usbphy {
status = "okay";
};
&fimd {
pinctrl-0 = <&lcd_clk>, <&lcd_data24>;
pinctrl-names = "default";
status = "okay";
samsung,invert-vden;
samsung,invert-vclk;
#address-cells = <1>;
#size-cells = <0>;
port@3 {
reg = <3>;
fimd_dpi_ep: endpoint {
remote-endpoint = <&lcd_ep>;
};
};
};
&hdmi {
hpd-gpio = <&gpx3 7 0>;
pinctrl-names = "default";
pinctrl-0 = <&hdmi_hpd>;
hdmi-en-supply = <&hdmi_en>;
vdd-supply = <&ldo3_reg>;
vdd_osc-supply = <&ldo4_reg>;
vdd_pll-supply = <&ldo3_reg>;
ddc = <&hdmi_ddc>;
status = "okay";
};
&hsotg {
vusb_d-supply = <&ldo3_reg>;
vusb_a-supply = <&ldo8_reg>;
dr_mode = "peripheral";
status = "okay";
};
&i2c_3 {
samsung,i2c-sda-delay = <100>; samsung,i2c-sda-delay = <100>;
samsung,i2c-slave-addr = <0x10>; samsung,i2c-slave-addr = <0x10>;
samsung,i2c-max-bus-freq = <100000>; samsung,i2c-max-bus-freq = <100000>;
...@@ -198,9 +297,9 @@ tsp@4a { ...@@ -198,9 +297,9 @@ tsp@4a {
/* TBD: Atmel maXtouch touchscreen */ /* TBD: Atmel maXtouch touchscreen */
reg = <0x4a>; reg = <0x4a>;
}; };
}; };
i2c@138B0000 { &i2c_5 {
samsung,i2c-sda-delay = <100>; samsung,i2c-sda-delay = <100>;
samsung,i2c-slave-addr = <0x10>; samsung,i2c-slave-addr = <0x10>;
samsung,i2c-max-bus-freq = <100000>; samsung,i2c-max-bus-freq = <100000>;
...@@ -396,174 +495,79 @@ safeout2_reg: ESAFEOUT2 { ...@@ -396,174 +495,79 @@ safeout2_reg: ESAFEOUT2 {
}; };
}; };
}; };
}; };
spi-lcd {
compatible = "spi-gpio";
#address-cells = <1>;
#size-cells = <0>;
gpio-sck = <&gpy3 1 0>;
gpio-mosi = <&gpy3 3 0>;
num-chipselects = <1>;
cs-gpios = <&gpy4 3 0>;
lcd@0 {
compatible = "samsung,ld9040";
reg = <0>;
vdd3-supply = <&ldo7_reg>;
vci-supply = <&ldo17_reg>;
reset-gpios = <&gpy4 5 0>;
spi-max-frequency = <1200000>;
spi-cpol;
spi-cpha;
power-on-delay = <10>;
reset-delay = <10>;
panel-width-mm = <90>;
panel-height-mm = <154>;
display-timings {
timing {
clock-frequency = <23492370>;
hactive = <480>;
vactive = <800>;
hback-porch = <16>;
hfront-porch = <16>;
vback-porch = <2>;
vfront-porch = <28>;
hsync-len = <2>;
vsync-len = <1>;
hsync-active = <0>;
vsync-active = <0>;
de-active = <0>;
pixelclk-active = <0>;
};
};
port {
lcd_ep: endpoint {
remote-endpoint = <&fimd_dpi_ep>;
};
};
};
};
fimd: fimd@11c00000 {
pinctrl-0 = <&lcd_clk>, <&lcd_data24>;
pinctrl-names = "default";
status = "okay";
samsung,invert-vden;
samsung,invert-vclk;
#address-cells = <1>;
#size-cells = <0>;
port@3 {
reg = <3>;
fimd_dpi_ep: endpoint {
remote-endpoint = <&lcd_ep>;
};
};
};
pwm@139D0000 { &i2c_8 {
compatible = "samsung,s5p6440-pwm";
status = "okay";
};
camera {
status = "okay"; status = "okay";
};
pinctrl-names = "default"; &mdma1 {
pinctrl-0 = <>; reg = <0x12840000 0x1000>;
};
fimc_0: fimc@11800000 { &mixer {
status = "okay"; status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC0>, };
<&clock CLK_SCLK_FIMC0>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
fimc_1: fimc@11810000 { &ohci {
status = "okay"; status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC1>, port@0 {
<&clock CLK_SCLK_FIMC1>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
fimc_2: fimc@11820000 {
status = "okay"; status = "okay";
assigned-clocks = <&clock CLK_MOUT_FIMC2>,
<&clock CLK_SCLK_FIMC2>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
}; };
};
fimc_3: fimc@11830000 { &pinctrl_1 {
status = "okay"; hdmi_hpd: hdmi-hpd {
assigned-clocks = <&clock CLK_MOUT_FIMC3>, samsung,pins = "gpx3-7";
<&clock CLK_SCLK_FIMC3>; samsung,pin-pud = <0>;
assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
assigned-clock-rates = <0>, <160000000>;
};
}; };
};
hdmi_en: voltage-regulator-hdmi-5v { &pinctrl_0 {
compatible = "regulator-fixed"; i2c_ddc_bus: i2c-ddc-bus {
regulator-name = "HDMI_5V"; samsung,pins = "gpe4-2", "gpe4-3";
regulator-min-microvolt = <5000000>; samsung,pin-function = <2>;
regulator-max-microvolt = <5000000>; samsung,pin-pud = <3>;
gpio = <&gpe0 1 0>; samsung,pin-drv = <0>;
enable-active-high;
}; };
};
hdmi_ddc: i2c-ddc { &pwm {
compatible = "i2c-gpio"; compatible = "samsung,s5p6440-pwm";
gpios = <&gpe4 2 0 &gpe4 3 0>;
i2c-gpio,delay-us = <100>;
#address-cells = <1>;
#size-cells = <0>;
pinctrl-0 = <&i2c_ddc_bus>;
pinctrl-names = "default";
status = "okay"; status = "okay";
}; };
mixer@12C10000 { &sdhci_0 {
bus-width = <8>;
non-removable;
pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus8>;
pinctrl-names = "default";
vmmc-supply = <&vemmc_reg>;
status = "okay"; status = "okay";
}; };
hdmi@12D00000 { &sdhci_2 {
hpd-gpio = <&gpx3 7 0>; bus-width = <4>;
pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&hdmi_hpd>; vmmc-supply = <&ldo5_reg>;
hdmi-en-supply = <&hdmi_en>; cd-gpios = <&gpx3 4 0>;
vdd-supply = <&ldo3_reg>; cd-inverted;
vdd_osc-supply = <&ldo4_reg>;
vdd_pll-supply = <&ldo3_reg>;
ddc = <&hdmi_ddc>;
status = "okay"; status = "okay";
}; };
i2c@138E0000 { &serial_0 {
status = "okay"; status = "okay";
};
}; };
&pinctrl_1 { &serial_1 {
hdmi_hpd: hdmi-hpd { status = "okay";
samsung,pins = "gpx3-7";
samsung,pin-pud = <0>;
};
}; };
&pinctrl_0 { &serial_2 {
i2c_ddc_bus: i2c-ddc-bus { status = "okay";
samsung,pins = "gpe4-2", "gpe4-3";
samsung,pin-function = <2>;
samsung,pin-pud = <3>;
samsung,pin-drv = <0>;
};
}; };
&mdma1 { &serial_3 {
reg = <0x12840000 0x1000>; status = "okay";
}; };
...@@ -40,6 +40,18 @@ cpu0: cpu@900 { ...@@ -40,6 +40,18 @@ cpu0: cpu@900 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0x900>; reg = <0x900>;
clocks = <&clock CLK_ARM_CLK>;
clock-names = "cpu";
clock-latency = <160000>;
operating-points = <
1200000 1250000
1000000 1150000
800000 1075000
500000 975000
400000 975000
200000 950000
>;
cooling-min-level = <4>; cooling-min-level = <4>;
cooling-max-level = <2>; cooling-max-level = <2>;
#cooling-cells = <2>; /* min followed by max */ #cooling-cells = <2>; /* min followed by max */
......
...@@ -30,6 +30,9 @@ cpu0: cpu@A00 { ...@@ -30,6 +30,9 @@ cpu0: cpu@A00 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA00>; reg = <0xA00>;
clocks = <&clock CLK_ARM_CLK>;
clock-names = "cpu";
operating-points-v2 = <&cpu0_opp_table>;
cooling-min-level = <13>; cooling-min-level = <13>;
cooling-max-level = <7>; cooling-max-level = <7>;
#cooling-cells = <2>; /* min followed by max */ #cooling-cells = <2>; /* min followed by max */
...@@ -39,6 +42,84 @@ cpu@A01 { ...@@ -39,6 +42,84 @@ cpu@A01 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA01>; reg = <0xA01>;
operating-points-v2 = <&cpu0_opp_table>;
};
};
cpu0_opp_table: opp_table0 {
compatible = "operating-points-v2";
opp-shared;
opp00 {
opp-hz = /bits/ 64 <200000000>;
opp-microvolt = <900000>;
clock-latency-ns = <200000>;
};
opp01 {
opp-hz = /bits/ 64 <300000000>;
opp-microvolt = <900000>;
clock-latency-ns = <200000>;
};
opp02 {
opp-hz = /bits/ 64 <400000000>;
opp-microvolt = <925000>;
clock-latency-ns = <200000>;
};
opp03 {
opp-hz = /bits/ 64 <500000000>;
opp-microvolt = <950000>;
clock-latency-ns = <200000>;
};
opp04 {
opp-hz = /bits/ 64 <600000000>;
opp-microvolt = <975000>;
clock-latency-ns = <200000>;
};
opp05 {
opp-hz = /bits/ 64 <700000000>;
opp-microvolt = <987500>;
clock-latency-ns = <200000>;
};
opp06 {
opp-hz = /bits/ 64 <800000000>;
opp-microvolt = <1000000>;
clock-latency-ns = <200000>;
};
opp07 {
opp-hz = /bits/ 64 <900000000>;
opp-microvolt = <1037500>;
clock-latency-ns = <200000>;
};
opp08 {
opp-hz = /bits/ 64 <1000000000>;
opp-microvolt = <1087500>;
clock-latency-ns = <200000>;
};
opp09 {
opp-hz = /bits/ 64 <1100000000>;
opp-microvolt = <1137500>;
clock-latency-ns = <200000>;
};
opp10 {
opp-hz = /bits/ 64 <1200000000>;
opp-microvolt = <1187500>;
clock-latency-ns = <200000>;
};
opp11 {
opp-hz = /bits/ 64 <1300000000>;
opp-microvolt = <1250000>;
clock-latency-ns = <200000>;
};
opp12 {
opp-hz = /bits/ 64 <1400000000>;
opp-microvolt = <1287500>;
clock-latency-ns = <200000>;
};
opp13 {
opp-hz = /bits/ 64 <1500000000>;
opp-microvolt = <1350000>;
clock-latency-ns = <200000>;
turbo-mode;
}; };
}; };
}; };
......
...@@ -107,6 +107,10 @@ map1 { ...@@ -107,6 +107,10 @@ map1 {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
/* RSTN signal for eMMC */ /* RSTN signal for eMMC */
&sd1_cd { &sd1_cd {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
/dts-v1/; /dts-v1/;
#include "exynos4412-odroid-common.dtsi" #include "exynos4412-odroid-common.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ { / {
model = "Hardkernel ODROID-U3 board based on Exynos4412"; model = "Hardkernel ODROID-U3 board based on Exynos4412";
...@@ -61,3 +62,10 @@ &sound { ...@@ -61,3 +62,10 @@ &sound {
"Speakers", "SPKL", "Speakers", "SPKL",
"Speakers", "SPKR"; "Speakers", "SPKR";
}; };
&spi_1 {
pinctrl-names = "default";
pinctrl-0 = <&spi1_bus>;
cs-gpios = <&gpb 5 GPIO_ACTIVE_HIGH>;
status = "okay";
};
...@@ -78,6 +78,10 @@ xusbxti { ...@@ -78,6 +78,10 @@ xusbxti {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&fimd { &fimd {
pinctrl-0 = <&lcd_clk &lcd_data24 &pwm1_out>; pinctrl-0 = <&lcd_clk &lcd_data24 &pwm1_out>;
pinctrl-names = "default"; pinctrl-names = "default";
......
...@@ -190,6 +190,9 @@ max77693-fuel-gauge@36 { ...@@ -190,6 +190,9 @@ max77693-fuel-gauge@36 {
interrupt-parent = <&gpx2>; interrupt-parent = <&gpx2>;
interrupts = <3 IRQ_TYPE_EDGE_FALLING>; interrupts = <3 IRQ_TYPE_EDGE_FALLING>;
reg = <0x36>; reg = <0x36>;
maxim,over-heat-temp = <700>;
maxim,over-volt = <4500>;
}; };
}; };
...@@ -285,6 +288,10 @@ &adc { ...@@ -285,6 +288,10 @@ &adc {
status = "okay"; status = "okay";
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&csis_0 { &csis_0 {
status = "okay"; status = "okay";
vddcore-supply = <&ldo8_reg>; vddcore-supply = <&ldo8_reg>;
......
...@@ -30,6 +30,9 @@ cpu0: cpu@A00 { ...@@ -30,6 +30,9 @@ cpu0: cpu@A00 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA00>; reg = <0xA00>;
clocks = <&clock CLK_ARM_CLK>;
clock-names = "cpu";
operating-points-v2 = <&cpu0_opp_table>;
cooling-min-level = <13>; cooling-min-level = <13>;
cooling-max-level = <7>; cooling-max-level = <7>;
#cooling-cells = <2>; /* min followed by max */ #cooling-cells = <2>; /* min followed by max */
...@@ -39,18 +42,98 @@ cpu@A01 { ...@@ -39,18 +42,98 @@ cpu@A01 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA01>; reg = <0xA01>;
operating-points-v2 = <&cpu0_opp_table>;
}; };
cpu@A02 { cpu@A02 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA02>; reg = <0xA02>;
operating-points-v2 = <&cpu0_opp_table>;
}; };
cpu@A03 { cpu@A03 {
device_type = "cpu"; device_type = "cpu";
compatible = "arm,cortex-a9"; compatible = "arm,cortex-a9";
reg = <0xA03>; reg = <0xA03>;
operating-points-v2 = <&cpu0_opp_table>;
};
};
cpu0_opp_table: opp_table0 {
compatible = "operating-points-v2";
opp-shared;
opp00 {
opp-hz = /bits/ 64 <200000000>;
opp-microvolt = <900000>;
clock-latency-ns = <200000>;
};
opp01 {
opp-hz = /bits/ 64 <300000000>;
opp-microvolt = <900000>;
clock-latency-ns = <200000>;
};
opp02 {
opp-hz = /bits/ 64 <400000000>;
opp-microvolt = <925000>;
clock-latency-ns = <200000>;
};
opp03 {
opp-hz = /bits/ 64 <500000000>;
opp-microvolt = <950000>;
clock-latency-ns = <200000>;
};
opp04 {
opp-hz = /bits/ 64 <600000000>;
opp-microvolt = <975000>;
clock-latency-ns = <200000>;
};
opp05 {
opp-hz = /bits/ 64 <700000000>;
opp-microvolt = <987500>;
clock-latency-ns = <200000>;
};
opp06 {
opp-hz = /bits/ 64 <800000000>;
opp-microvolt = <1000000>;
clock-latency-ns = <200000>;
};
opp07 {
opp-hz = /bits/ 64 <900000000>;
opp-microvolt = <1037500>;
clock-latency-ns = <200000>;
};
opp08 {
opp-hz = /bits/ 64 <1000000000>;
opp-microvolt = <1087500>;
clock-latency-ns = <200000>;
};
opp09 {
opp-hz = /bits/ 64 <1100000000>;
opp-microvolt = <1137500>;
clock-latency-ns = <200000>;
};
opp10 {
opp-hz = /bits/ 64 <1200000000>;
opp-microvolt = <1187500>;
clock-latency-ns = <200000>;
};
opp11 {
opp-hz = /bits/ 64 <1300000000>;
opp-microvolt = <1250000>;
clock-latency-ns = <200000>;
};
opp12 {
opp-hz = /bits/ 64 <1400000000>;
opp-microvolt = <1287500>;
clock-latency-ns = <200000>;
};
opp13 {
opp-hz = /bits/ 64 <1500000000>;
opp-microvolt = <1350000>;
clock-latency-ns = <200000>;
turbo-mode;
}; };
}; };
......
...@@ -117,6 +117,10 @@ usb_hub: usb-hub { ...@@ -117,6 +117,10 @@ usb_hub: usb-hub {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&dp { &dp {
status = "okay"; status = "okay";
samsung,color-space = <0>; samsung,color-space = <0>;
......
...@@ -12,8 +12,7 @@ ...@@ -12,8 +12,7 @@
* published by the Free Software Foundation. * published by the Free Software Foundation.
*/ */
/ { &pinctrl_0 {
pinctrl@11400000 {
gpa0: gpa0 { gpa0: gpa0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -588,9 +587,9 @@ dp_hpd: dp_hpd { ...@@ -588,9 +587,9 @@ dp_hpd: dp_hpd {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@13400000 { &pinctrl_1 {
gpe0: gpe0 { gpe0: gpe0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -734,9 +733,9 @@ cam_port_a: cam-port-a { ...@@ -734,9 +733,9 @@ cam_port_a: cam-port-a {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@10d10000 { &pinctrl_2 {
gpv0: gpv0 { gpv0: gpv0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -796,9 +795,9 @@ c2c_txd: c2c-txd { ...@@ -796,9 +795,9 @@ c2c_txd: c2c-txd {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@03860000 { &pinctrl_3 {
gpz: gpz { gpz: gpz {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -814,5 +813,4 @@ i2s0_bus: i2s0-bus { ...@@ -814,5 +813,4 @@ i2s0_bus: i2s0-bus {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
};
}; };
...@@ -74,6 +74,10 @@ codec_mclk: codec-mclk { ...@@ -74,6 +74,10 @@ codec_mclk: codec-mclk {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&dp { &dp {
samsung,color-space = <0>; samsung,color-space = <0>;
samsung,dynamic-range = <0>; samsung,dynamic-range = <0>;
......
...@@ -235,6 +235,10 @@ mmc3_pwrseq: mmc3_pwrseq { ...@@ -235,6 +235,10 @@ mmc3_pwrseq: mmc3_pwrseq {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&dp { &dp {
status = "okay"; status = "okay";
pinctrl-names = "default"; pinctrl-names = "default";
...@@ -688,6 +692,7 @@ &spi_1 { ...@@ -688,6 +692,7 @@ &spi_1 {
status = "okay"; status = "okay";
samsung,spi-src-clk = <0>; samsung,spi-src-clk = <0>;
num-cs = <1>; num-cs = <1>;
cs-gpios = <&gpa2 5 GPIO_ACTIVE_HIGH>;
}; };
&usbdrd_dwc3 { &usbdrd_dwc3 {
......
...@@ -65,6 +65,10 @@ xxti { ...@@ -65,6 +65,10 @@ xxti {
}; };
}; };
&cpu0 {
cpu0-supply = <&buck2_reg>;
};
&dp { &dp {
status = "okay"; status = "okay";
pinctrl-names = "default"; pinctrl-names = "default";
......
...@@ -19,7 +19,6 @@ ...@@ -19,7 +19,6 @@
#include <dt-bindings/clock/exynos5250.h> #include <dt-bindings/clock/exynos5250.h>
#include "exynos5.dtsi" #include "exynos5.dtsi"
#include "exynos5250-pinctrl.dtsi"
#include "exynos4-cpu-thermal.dtsi" #include "exynos4-cpu-thermal.dtsi"
#include <dt-bindings/clock/exynos-audss-clk.h> #include <dt-bindings/clock/exynos-audss-clk.h>
...@@ -63,6 +62,28 @@ cpu0: cpu@0 { ...@@ -63,6 +62,28 @@ cpu0: cpu@0 {
compatible = "arm,cortex-a15"; compatible = "arm,cortex-a15";
reg = <0>; reg = <0>;
clock-frequency = <1700000000>; clock-frequency = <1700000000>;
clocks = <&clock CLK_ARM_CLK>;
clock-names = "cpu";
clock-latency = <140000>;
operating-points = <
1700000 1300000
1600000 1250000
1500000 1225000
1400000 1200000
1300000 1150000
1200000 1125000
1100000 1100000
1000000 1075000
900000 1050000
800000 1025000
700000 1012500
600000 1000000
500000 975000
400000 950000
300000 937500
200000 925000
>;
cooling-min-level = <15>; cooling-min-level = <15>;
cooling-max-level = <9>; cooling-max-level = <9>;
#cooling-cells = <2>; /* min followed by max */ #cooling-cells = <2>; /* min followed by max */
...@@ -1062,3 +1083,5 @@ &serial_3 { ...@@ -1062,3 +1083,5 @@ &serial_3 {
clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>; clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>;
clock-names = "uart", "clk_uart_baud0"; clock-names = "uart", "clk_uart_baud0";
}; };
#include "exynos5250-pinctrl.dtsi"
...@@ -12,8 +12,7 @@ ...@@ -12,8 +12,7 @@
* published by the Free Software Foundation. * published by the Free Software Foundation.
*/ */
/ { &pinctrl_0 {
pinctrl@13400000 {
gpy7: gpy7 { gpy7: gpy7 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -66,9 +65,9 @@ dp_hpd: dp_hpd { ...@@ -66,9 +65,9 @@ dp_hpd: dp_hpd {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@13410000 { &pinctrl_1 {
gpc0: gpc0 { gpc0: gpc0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -284,9 +283,9 @@ sd2_bus4: sd2-bus-width4 { ...@@ -284,9 +283,9 @@ sd2_bus4: sd2-bus-width4 {
samsung,pin-pud = <3>; samsung,pin-pud = <3>;
samsung,pin-drv = <3>; samsung,pin-drv = <3>;
}; };
}; };
pinctrl@14000000 { &pinctrl_2 {
gpe0: gpe0 { gpe0: gpe0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -374,6 +373,7 @@ cam_i2c2_bus: cam-i2c2-bus { ...@@ -374,6 +373,7 @@ cam_i2c2_bus: cam-i2c2-bus {
samsung,pin-pud = <3>; samsung,pin-pud = <3>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
cam_spi1_bus: cam-spi1-bus { cam_spi1_bus: cam-spi1-bus {
samsung,pins = "gpe0-4", "gpe0-5", "gpf0-2", "gpf0-3"; samsung,pins = "gpe0-4", "gpe0-5", "gpf0-2", "gpf0-3";
samsung,pin-function = <4>; samsung,pin-function = <4>;
...@@ -412,9 +412,9 @@ cam_bayrgb_bus: cam-bayrgb-bus { ...@@ -412,9 +412,9 @@ cam_bayrgb_bus: cam-bayrgb-bus {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@14010000 { &pinctrl_3 {
gpa0: gpa0 { gpa0: gpa0 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -700,9 +700,9 @@ i2c10_hs_bus: i2c10-hs-bus { ...@@ -700,9 +700,9 @@ i2c10_hs_bus: i2c10-hs-bus {
samsung,pin-pud = <3>; samsung,pin-pud = <3>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
}; };
pinctrl@03860000 { &pinctrl_4 {
gpz: gpz { gpz: gpz {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
...@@ -718,5 +718,4 @@ i2s0_bus: i2s0-bus { ...@@ -718,5 +718,4 @@ i2s0_bus: i2s0-bus {
samsung,pin-pud = <0>; samsung,pin-pud = <0>;
samsung,pin-drv = <0>; samsung,pin-drv = <0>;
}; };
};
}; };
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include <dt-bindings/clock/exynos5420.h> #include <dt-bindings/clock/exynos5420.h>
#include "exynos5.dtsi" #include "exynos5.dtsi"
#include "exynos5420-pinctrl.dtsi"
#include <dt-bindings/clock/exynos-audss-clk.h> #include <dt-bindings/clock/exynos-audss-clk.h>
...@@ -1166,3 +1165,5 @@ &serial_3 { ...@@ -1166,3 +1165,5 @@ &serial_3 {
clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>; clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>;
clock-names = "uart", "clk_uart_baud0"; clock-names = "uart", "clk_uart_baud0";
}; };
#include "exynos5420-pinctrl.dtsi"
/*
* Device tree sources for Exynos5422 thermal zone
*
* Copyright (c) 2015 Lukasz Majewski <l.majewski@samsung.com>
* Anand Moon <linux.amoon@gmail.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
*/
#include <dt-bindings/thermal/thermal.h>
/ {
thermal-zones {
cpu0_thermal: cpu0-thermal {
thermal-sensors = <&tmu_cpu0 0>;
polling-delay-passive = <0>;
polling-delay = <0>;
trips {
cpu_alert0: cpu-alert-0 {
temperature = <50000>; /* millicelsius */
hysteresis = <5000>; /* millicelsius */
type = "active";
};
cpu_alert1: cpu-alert-1 {
temperature = <60000>; /* millicelsius */
hysteresis = <5000>; /* millicelsius */
type = "active";
};
cpu_alert2: cpu-alert-2 {
temperature = <70000>; /* millicelsius */
hysteresis = <5000>; /* millicelsius */
type = "active";
};
cpu_crit0: cpu-crit-0 {
temperature = <120000>; /* millicelsius */
hysteresis = <0>; /* millicelsius */
type = "critical";
};
};
cooling-maps {
map0 {
trip = <&cpu_alert0>;
cooling-device = <&fan0 0 1>;
};
map1 {
trip = <&cpu_alert1>;
cooling-device = <&fan0 1 2>;
};
map2 {
trip = <&cpu_alert2>;
cooling-device = <&fan0 2 3>;
};
};
};
};
};
/*
* SAMSUNG EXYNOS5422 SoC cpu device tree source
*
* Copyright (c) 2015 Samsung Electronics Co., Ltd.
* http://www.samsung.com
*
* The only difference between EXYNOS5422 and EXYNOS5800 is cpu ordering. The
* EXYNOS5422 is booting from Cortex-A7 core while the EXYNOS5800 is booting
* from Cortex-A15 core.
*
* EXYNOS5422 based board files can include this file to provide cpu ordering
* which could boot a cortex-a7 from cpu0.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
&cpu0 {
device_type = "cpu";
compatible = "arm,cortex-a7";
reg = <0x100>;
clock-frequency = <1000000000>;
cci-control-port = <&cci_control0>;
};
&cpu1 {
device_type = "cpu";
compatible = "arm,cortex-a7";
reg = <0x101>;
clock-frequency = <1000000000>;
cci-control-port = <&cci_control0>;
};
&cpu2 {
device_type = "cpu";
compatible = "arm,cortex-a7";
reg = <0x102>;
clock-frequency = <1000000000>;
cci-control-port = <&cci_control0>;
};
&cpu3 {
device_type = "cpu";
compatible = "arm,cortex-a7";
reg = <0x103>;
clock-frequency = <1000000000>;
cci-control-port = <&cci_control0>;
};
&cpu4 {
device_type = "cpu";
compatible = "arm,cortex-a15";
reg = <0x0>;
clock-frequency = <1800000000>;
cci-control-port = <&cci_control1>;
};
&cpu5 {
device_type = "cpu";
compatible = "arm,cortex-a15";
reg = <0x1>;
clock-frequency = <1800000000>;
cci-control-port = <&cci_control1>;
};
&cpu6 {
device_type = "cpu";
compatible = "arm,cortex-a15";
reg = <0x2>;
clock-frequency = <1800000000>;
cci-control-port = <&cci_control1>;
};
&cpu7 {
device_type = "cpu";
compatible = "arm,cortex-a15";
reg = <0x3>;
clock-frequency = <1800000000>;
cci-control-port = <&cci_control1>;
};
...@@ -15,6 +15,8 @@ ...@@ -15,6 +15,8 @@
#include <dt-bindings/gpio/gpio.h> #include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/sound/samsung-i2s.h> #include <dt-bindings/sound/samsung-i2s.h>
#include "exynos5800.dtsi" #include "exynos5800.dtsi"
#include "exynos5422-cpus.dtsi"
#include "exynos5422-cpu-thermal.dtsi"
/ { / {
memory { memory {
...@@ -107,6 +109,15 @@ link0_codec: simple-audio-card,codec { ...@@ -107,6 +109,15 @@ link0_codec: simple-audio-card,codec {
clocks = <&i2s0 CLK_I2S_CDCLK>; clocks = <&i2s0 CLK_I2S_CDCLK>;
}; };
}; };
fan0: pwm-fan {
compatible = "pwm-fan";
pwms = <&pwm 0 20972 0>;
cooling-min-state = <0>;
cooling-max-state = <3>;
#cooling-cells = <2>;
cooling-levels = <0 130 170 230>;
};
}; };
&clock_audss { &clock_audss {
...@@ -461,6 +472,32 @@ &pwm { ...@@ -461,6 +472,32 @@ &pwm {
*/ */
pinctrl-0 = <&pwm0_out &pwm1_out &pwm2_out &pwm3_out>; pinctrl-0 = <&pwm0_out &pwm1_out &pwm2_out &pwm3_out>;
pinctrl-names = "default"; pinctrl-names = "default";
samsung,pwm-outputs = <0>;
status = "okay";
};
&tmu_cpu0 {
vtmu-supply = <&ldo7_reg>;
status = "okay";
};
&tmu_cpu1 {
vtmu-supply = <&ldo7_reg>;
status = "okay";
};
&tmu_cpu2 {
vtmu-supply = <&ldo7_reg>;
status = "okay";
};
&tmu_cpu3 {
vtmu-supply = <&ldo7_reg>;
status = "okay";
};
&tmu_gpu {
vtmu-supply = <&ldo7_reg>;
status = "okay"; status = "okay";
}; };
...@@ -477,3 +514,13 @@ &usbdrd_dwc3_0 { ...@@ -477,3 +514,13 @@ &usbdrd_dwc3_0 {
&usbdrd_dwc3_1 { &usbdrd_dwc3_1 {
dr_mode = "otg"; dr_mode = "otg";
}; };
&usbdrd3_0 {
vdd33-supply = <&ldo9_reg>;
vdd10-supply = <&ldo11_reg>;
};
&usbdrd3_1 {
vdd33-supply = <&ldo9_reg>;
vdd10-supply = <&ldo11_reg>;
};
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment