STM32 DT updates for v4.21, round 1

Highlights:
 ----------
 
 -MPU STM32MP157 platform update:
  -Declare DMAs for timers
  -Add sleep support for CAN
  -Split CAN RAM mapping between the 2 FDCAN instances
  -Add support of thermal sensor (DTS)
 -----BEGIN PGP SIGNATURE-----
 Version: GnuPG v1
 
 iQIcBAABAgAGBQJcBQ9HAAoJEH+ayWryHnCFhkIP/2hX4e+FYtqSJOUkSu9LL5tf
 FmqKnDcA7VWpE2lkWrwv8faYQ/BTJ0v5J6reCUhXntomcOZtCyWv+MllbgANEHrL
 UWRakenbOe5vSZR5v2SapV0zX/AKZl2o7WUmtnjq1hf9sopeVVVWfLObx8HmwVmA
 Q8S/7lqqPntapb0JSPGUr8cI3nuXfTHlRl1x8YIq8e0LfKPyF9euprmXtkZ01rwu
 YTFvBogRJfVMxT9VWqLtEU4DWsluqKobNU6Xq06/cN+81aS3iUaNR1dprMwURoWq
 yE22y876y2Ytgj5Y2PcxlGO+7w9RbLHEPgF1Gx+yM8Tu4m2jq6V8peVAw4814ow1
 ALduE+/iQ/zGUvHkyyIRkl01y03H1OburA/WoTrkbOeppESUMH+mW5rF9rW+kEtR
 RSoik3YnWKD8pcmKNk4HNNhKRaLmhPDif5EDrF66c5QpMoDlJbnZ2n1pBZJMCboQ
 ASNF7zWUxbshw+o9TDdbkF0nu/IsRlO+t+CXiTPHJ4WzWVWra+2DAMMnrgjZH62Q
 2i6+jRFQdhNmWNhvz4Gspm5v1bptllXjBGlg3TZ9c38l2hVWyTFi03777EJtrj8h
 b6ZLeK0qfXaBH8Ix/BZ9d6FmVpBntTh/vTNyWCJqywVwO4YA2C/5xBjbL9NH9zFV
 /GKMyE1fKI9pziO9REu2
 =660S
 -----END PGP SIGNATURE-----

Merge tag 'stm32-dt-for-v4.21-1' of git://git.kernel.org/pub/scm/linux/kernel/git/atorgue/stm32 into arm/dt

STM32 DT updates for v4.21, round 1

Highlights:
----------

-MPU STM32MP157 platform update:
 -Declare DMAs for timers
 -Add sleep support for CAN
 -Split CAN RAM mapping between the 2 FDCAN instances
 -Add support of thermal sensor (DTS)

* tag 'stm32-dt-for-v4.21-1' of git://git.kernel.org/pub/scm/linux/kernel/git/atorgue/stm32:
  ARM: dts: stm32: add thermal sensor support on STM32MP157c
  ARM: dts: stm32: add can1 sleep pins muxing on stm32mp157c-ev1 board
  ARM: dts: stm32: add can1 sleep pins muxing
  ARM: dts: stm32: change CAN RAM mapping on stm32mp157c
  ARM: dts: stm32: don't use timers dmas on stm32mp157c-ev1
  ARM: dts: stm32: don't use timers dmas on stm32mp157c-ed1
  ARM: dts: stm32: Add dmas to timer on stm32mp157c

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
Arnd Bergmann 2019-01-30 17:26:33 +01:00
commit 6569df3d62
4 changed files with 114 additions and 3 deletions

View File

@ -246,6 +246,13 @@
}; };
}; };
m_can1_sleep_pins_a: m_can1-sleep@0 {
pins {
pinmux = <STM32_PINMUX('H', 13, ANALOG)>, /* CAN1_TX */
<STM32_PINMUX('I', 9, ANALOG)>; /* CAN1_RX */
};
};
pwm2_pins_a: pwm2-0 { pwm2_pins_a: pwm2-0 {
pins { pins {
pinmux = <STM32_PINMUX('A', 3, AF1)>; /* TIM2_CH4 */ pinmux = <STM32_PINMUX('A', 3, AF1)>; /* TIM2_CH4 */

View File

@ -72,6 +72,9 @@
&timers6 { &timers6 {
status = "okay"; status = "okay";
/* spare dmas for other usage */
/delete-property/dmas;
/delete-property/dma-names;
timer@5 { timer@5 {
status = "okay"; status = "okay";
}; };

View File

@ -124,8 +124,9 @@
}; };
&m_can1 { &m_can1 {
pinctrl-names = "default"; pinctrl-names = "default", "sleep";
pinctrl-0 = <&m_can1_pins_a>; pinctrl-0 = <&m_can1_pins_a>;
pinctrl-1 = <&m_can1_sleep_pins_a>;
status = "okay"; status = "okay";
}; };
@ -161,6 +162,9 @@
}; };
&timers2 { &timers2 {
/* spare dmas for other usage (un-delete to enable pwm capture) */
/delete-property/dmas;
/delete-property/dma-names;
status = "disabled"; status = "disabled";
pwm { pwm {
pinctrl-0 = <&pwm2_pins_a>; pinctrl-0 = <&pwm2_pins_a>;
@ -173,6 +177,8 @@
}; };
&timers8 { &timers8 {
/delete-property/dmas;
/delete-property/dma-names;
status = "disabled"; status = "disabled";
pwm { pwm {
pinctrl-0 = <&pwm8_pins_a>; pinctrl-0 = <&pwm8_pins_a>;
@ -185,6 +191,8 @@
}; };
&timers12 { &timers12 {
/delete-property/dmas;
/delete-property/dma-names;
status = "disabled"; status = "disabled";
pwm { pwm {
pinctrl-0 = <&pwm12_pins_a>; pinctrl-0 = <&pwm12_pins_a>;

View File

@ -84,6 +84,31 @@
}; };
}; };
thermal-zones {
cpu_thermal: cpu-thermal {
polling-delay-passive = <0>;
polling-delay = <0>;
thermal-sensors = <&dts>;
trips {
cpu_alert1: cpu-alert1 {
temperature = <85000>;
hysteresis = <0>;
type = "passive";
};
cpu-crit {
temperature = <120000>;
hysteresis = <0>;
type = "critical";
};
};
cooling-maps {
};
};
};
soc { soc {
compatible = "simple-bus"; compatible = "simple-bus";
#address-cells = <1>; #address-cells = <1>;
@ -98,6 +123,12 @@
reg = <0x40000000 0x400>; reg = <0x40000000 0x400>;
clocks = <&rcc TIM2_K>; clocks = <&rcc TIM2_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 18 0x400 0x1>,
<&dmamux1 19 0x400 0x1>,
<&dmamux1 20 0x400 0x1>,
<&dmamux1 21 0x400 0x1>,
<&dmamux1 22 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4", "up";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -119,6 +150,13 @@
reg = <0x40001000 0x400>; reg = <0x40001000 0x400>;
clocks = <&rcc TIM3_K>; clocks = <&rcc TIM3_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 23 0x400 0x1>,
<&dmamux1 24 0x400 0x1>,
<&dmamux1 25 0x400 0x1>,
<&dmamux1 26 0x400 0x1>,
<&dmamux1 27 0x400 0x1>,
<&dmamux1 28 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4", "up", "trig";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -140,6 +178,11 @@
reg = <0x40002000 0x400>; reg = <0x40002000 0x400>;
clocks = <&rcc TIM4_K>; clocks = <&rcc TIM4_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 29 0x400 0x1>,
<&dmamux1 30 0x400 0x1>,
<&dmamux1 31 0x400 0x1>,
<&dmamux1 32 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -161,6 +204,13 @@
reg = <0x40003000 0x400>; reg = <0x40003000 0x400>;
clocks = <&rcc TIM5_K>; clocks = <&rcc TIM5_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 55 0x400 0x1>,
<&dmamux1 56 0x400 0x1>,
<&dmamux1 57 0x400 0x1>,
<&dmamux1 58 0x400 0x1>,
<&dmamux1 59 0x400 0x1>,
<&dmamux1 60 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4", "up", "trig";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -182,6 +232,8 @@
reg = <0x40004000 0x400>; reg = <0x40004000 0x400>;
clocks = <&rcc TIM6_K>; clocks = <&rcc TIM6_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 69 0x400 0x1>;
dma-names = "up";
status = "disabled"; status = "disabled";
timer@5 { timer@5 {
@ -198,6 +250,8 @@
reg = <0x40005000 0x400>; reg = <0x40005000 0x400>;
clocks = <&rcc TIM7_K>; clocks = <&rcc TIM7_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 70 0x400 0x1>;
dma-names = "up";
status = "disabled"; status = "disabled";
timer@6 { timer@6 {
@ -465,6 +519,15 @@
reg = <0x44000000 0x400>; reg = <0x44000000 0x400>;
clocks = <&rcc TIM1_K>; clocks = <&rcc TIM1_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 11 0x400 0x1>,
<&dmamux1 12 0x400 0x1>,
<&dmamux1 13 0x400 0x1>,
<&dmamux1 14 0x400 0x1>,
<&dmamux1 15 0x400 0x1>,
<&dmamux1 16 0x400 0x1>,
<&dmamux1 17 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4",
"up", "trig", "com";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -486,6 +549,15 @@
reg = <0x44001000 0x400>; reg = <0x44001000 0x400>;
clocks = <&rcc TIM8_K>; clocks = <&rcc TIM8_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 47 0x400 0x1>,
<&dmamux1 48 0x400 0x1>,
<&dmamux1 49 0x400 0x1>,
<&dmamux1 50 0x400 0x1>,
<&dmamux1 51 0x400 0x1>,
<&dmamux1 52 0x400 0x1>,
<&dmamux1 53 0x400 0x1>;
dma-names = "ch1", "ch2", "ch3", "ch4",
"up", "trig", "com";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -543,6 +615,11 @@
reg = <0x44006000 0x400>; reg = <0x44006000 0x400>;
clocks = <&rcc TIM15_K>; clocks = <&rcc TIM15_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 105 0x400 0x1>,
<&dmamux1 106 0x400 0x1>,
<&dmamux1 107 0x400 0x1>,
<&dmamux1 108 0x400 0x1>;
dma-names = "ch1", "up", "trig", "com";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -564,6 +641,9 @@
reg = <0x44007000 0x400>; reg = <0x44007000 0x400>;
clocks = <&rcc TIM16_K>; clocks = <&rcc TIM16_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 109 0x400 0x1>,
<&dmamux1 110 0x400 0x1>;
dma-names = "ch1", "up";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -584,6 +664,9 @@
reg = <0x44008000 0x400>; reg = <0x44008000 0x400>;
clocks = <&rcc TIM17_K>; clocks = <&rcc TIM17_K>;
clock-names = "int"; clock-names = "int";
dmas = <&dmamux1 111 0x400 0x1>,
<&dmamux1 112 0x400 0x1>;
dma-names = "ch1", "up";
status = "disabled"; status = "disabled";
pwm { pwm {
@ -684,14 +767,14 @@
m_can1: can@4400e000 { m_can1: can@4400e000 {
compatible = "bosch,m_can"; compatible = "bosch,m_can";
reg = <0x4400e000 0x400>, <0x44011000 0x2800>; reg = <0x4400e000 0x400>, <0x44011000 0x1400>;
reg-names = "m_can", "message_ram"; reg-names = "m_can", "message_ram";
interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>, interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>; <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "int0", "int1"; interrupt-names = "int0", "int1";
clocks = <&rcc CK_HSE>, <&rcc FDCAN_K>; clocks = <&rcc CK_HSE>, <&rcc FDCAN_K>;
clock-names = "hclk", "cclk"; clock-names = "hclk", "cclk";
bosch,mram-cfg = <0x0 0 0 32 0 0 2 2>; bosch,mram-cfg = <0x1400 0 0 32 0 0 2 2>;
status = "disabled"; status = "disabled";
}; };
@ -908,6 +991,16 @@
status = "disabled"; status = "disabled";
}; };
dts: thermal@50028000 {
compatible = "st,stm32-thermal";
reg = <0x50028000 0x100>;
interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&rcc TMPSENS>;
clock-names = "pclk";
#thermal-sensor-cells = <0>;
status = "disabled";
};
cryp1: cryp@54001000 { cryp1: cryp@54001000 {
compatible = "st,stm32mp1-cryp"; compatible = "st,stm32mp1-cryp";
reg = <0x54001000 0x400>; reg = <0x54001000 0x400>;