mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 22:41:21 +02:00 
			
		
		
		
	- stm32mp: fix compilation issue with DEBUG_UART
- DT update : - Remove buck3 regulator-always-on on AV96 - Enable btrfs support on DHSOM - Drop extra newline from AV96 U-Boot extras DT - Add DHCOR based Testbench board - Fix and expand PLL configuration comments - update SCMI dedicated file -----BEGIN PGP SIGNATURE----- iQJQBAABCgA6FiEEXyrViUccKBz9c35Jysd4L3sz/6YFAmNOT2kcHHBhdHJpY2Uu Y2hvdGFyZEBmb3NzLnN0LmNvbQAKCRDKx3gvezP/ppxSEACdyDYNrTNcFp8+Xl3X Z9xW+bYWJXoqkyTATAAGZnSc9xpmmLg/3TksXjQ4EUPk38+ffGg/JC0vnEVbBuaO UCISp676MktaNAohHudayYzpEvHtzo5ax+7SknMEAOUrCn1m13xYDhDAFWrrhBCv zFjDIEG1dSzCf292NevTSXxxcZzy3CSMWjEy9+0zPZu8MNwVIqskDbnNDyI/LYuP X+rS1en6oYpGJCqCqzg6ArbC2lD4ApOSTryyFzZsnpB+GG7YRDPxDDeeLu13FtpN 7wK/fKpzmQXwAsxILJ+4Go1sp57Zm4rDoLPWhbFKUG4xq2r2t7XcDJk3zjcweas/ 0TrL7QN1j+O0zF2Hfc5V5rJiz6hnHph262Q8Lo1+rqyenEyxMUDKIUJmJZBKa8kx wcBr8DcOqRayfkNiu4Hxo2jA5Rrh5Ftqi4vDgIwnluvUCmMnxHr46fLf2dIVG0Eg QdfbrvAcAwt5cJtqGj4AkZVgA59e4YZlQHrQ4Hva2UNGjHiDMfRwGg8uyo7DWutM ZXNoxeYe2BwqUD0UJX4fXEJlfmV8iLjPqN8wzmCAmMM7mcEinq7xdeMx+qFOsU2n 1nkE9IqE/hb32mrEGQVZdeLghNF2TNM7M9Tjho0Q64xGG7fYnVDBJ7c+znEZ/NUg EhHFrlvLfo0IRgWi+BhE8LlthQ== =rTKw -----END PGP SIGNATURE----- Merge tag 'u-boot-stm32-20221018' of https://source.denx.de/u-boot/custodians/u-boot-stm - stm32mp: fix compilation issue with DEBUG_UART - DT update : - Remove buck3 regulator-always-on on AV96 - Enable btrfs support on DHSOM - Drop extra newline from AV96 U-Boot extras DT - Add DHCOR based Testbench board - Fix and expand PLL configuration comments - update SCMI dedicated file
This commit is contained in:
		
						commit
						d3031d442b
					
				| @ -1205,7 +1205,8 @@ dtb-$(CONFIG_STM32MP15x) += \ | |||||||
| 	stm32mp15xx-dhcom-pdk2.dtb \
 | 	stm32mp15xx-dhcom-pdk2.dtb \
 | ||||||
| 	stm32mp15xx-dhcom-picoitx.dtb \
 | 	stm32mp15xx-dhcom-picoitx.dtb \
 | ||||||
| 	stm32mp15xx-dhcor-avenger96.dtb \
 | 	stm32mp15xx-dhcor-avenger96.dtb \
 | ||||||
| 	stm32mp15xx-dhcor-drc-compact.dtb | 	stm32mp15xx-dhcor-drc-compact.dtb \
 | ||||||
|  | 	stm32mp15xx-dhcor-testbench.dtb | ||||||
| 
 | 
 | ||||||
| dtb-$(CONFIG_SOC_K3_AM654) += \
 | dtb-$(CONFIG_SOC_K3_AM654) += \
 | ||||||
| 	k3-am654-base-board.dtb \
 | 	k3-am654-base-board.dtb \
 | ||||||
|  | |||||||
| @ -103,7 +103,3 @@ | |||||||
| /delete-node/ &clk_lse; | /delete-node/ &clk_lse; | ||||||
| /delete-node/ &clk_lsi; | /delete-node/ &clk_lsi; | ||||||
| /delete-node/ &clk_csi; | /delete-node/ &clk_csi; | ||||||
| /delete-node/ ®11; |  | ||||||
| /delete-node/ ®18; |  | ||||||
| /delete-node/ &usb33; |  | ||||||
| /delete-node/ &pwr_regulators; |  | ||||||
|  | |||||||
| @ -190,6 +190,21 @@ | |||||||
| 		CLK_LPTIM45_LSE | 		CLK_LPTIM45_LSE | ||||||
| 	>; | 	>; | ||||||
| 
 | 
 | ||||||
|  | 	/* | ||||||
|  | 	 * cfg = < DIVM1 DIVN P Q R PQR(p,q,r) >; | ||||||
|  | 	 * frac = < f >; | ||||||
|  | 	 * | ||||||
|  | 	 * PRQ(p,q,r) ... for p,q,r: 0-output disabled / 1-output enabled | ||||||
|  | 	 * DIVN ... actually multiplier, but RCC_PLL1CFGR1 calls the field DIVN | ||||||
|  | 	 * m ... for PLL1,2: m=2 ; for PLL3,4: m=1 | ||||||
|  | 	 * XTAL = 24 MHz | ||||||
|  | 	 * | ||||||
|  | 	 * VCO = ( XTAL / (DIVM1 + 1) ) * m * ( DIVN + 1 + ( f / 8192 ) ) | ||||||
|  | 	 *   P = VCO / (P + 1) | ||||||
|  | 	 *   Q = VCO / (Q + 1) | ||||||
|  | 	 *   R = VCO / (R + 1) | ||||||
|  | 	 */ | ||||||
|  | 
 | ||||||
| 	/* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ | 	/* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ | ||||||
| 	pll2: st,pll@1 { | 	pll2: st,pll@1 { | ||||||
| 		compatible = "st,stm32mp1-pll"; | 		compatible = "st,stm32mp1-pll"; | ||||||
| @ -208,7 +223,7 @@ | |||||||
| 		u-boot,dm-pre-reloc; | 		u-boot,dm-pre-reloc; | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	/* VCO = 600.0 MHz => P = 50, Q = 50, R = 50 */ | 	/* VCO = 600.0 MHz => P = 100, Q = 50, R = 50 */ | ||||||
| 	pll4: st,pll@3 { | 	pll4: st,pll@3 { | ||||||
| 		compatible = "st,stm32mp1-pll"; | 		compatible = "st,stm32mp1-pll"; | ||||||
| 		reg = <3>; | 		reg = <3>; | ||||||
|  | |||||||
| @ -19,7 +19,6 @@ | |||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| ðernet0 { | ðernet0 { | ||||||
| 	phy-reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>; | 	phy-reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>; | ||||||
| 
 | 
 | ||||||
| @ -102,6 +101,10 @@ | |||||||
| 	hnp-srp-disable; | 	hnp-srp-disable; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | &vdd { | ||||||
|  | 	/delete-property/ regulator-always-on; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| &vdd_io { | &vdd_io { | ||||||
| 	u-boot,dm-spl; | 	u-boot,dm-spl; | ||||||
| }; | }; | ||||||
|  | |||||||
							
								
								
									
										100
									
								
								arch/arm/dts/stm32mp15xx-dhcor-testbench-u-boot.dtsi
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								arch/arm/dts/stm32mp15xx-dhcor-testbench-u-boot.dtsi
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,100 @@ | |||||||
|  | // SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause | ||||||
|  | /* | ||||||
|  |  * Copyright (C) 2022 Marek Vasut <marex@denx.de> | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #include "stm32mp15xx-dhcor-u-boot.dtsi" | ||||||
|  | 
 | ||||||
|  | / { | ||||||
|  | 	aliases { | ||||||
|  | 		mmc0 = &sdmmc1; | ||||||
|  | 		mmc1 = &sdmmc2; | ||||||
|  | 		usb0 = &usbotg_hs; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	config { | ||||||
|  | 		dh,board-coding-gpios = <&gpiog 13 0>, <&gpiod 9 0>; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | ðernet0 { | ||||||
|  | 	phy-reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>; | ||||||
|  | 
 | ||||||
|  | 	mdio0 { | ||||||
|  | 		ethernet-phy@7 { | ||||||
|  | 			reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>; | ||||||
|  | 			reset-assert-us = <11000>; | ||||||
|  | 			reset-deassert-us = <1000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc1 { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | 	st,use-ckin; | ||||||
|  | 	st,cmd-gpios = <&gpiod 2 0>; | ||||||
|  | 	st,ck-gpios = <&gpioc 12 0>; | ||||||
|  | 	st,ckin-gpios = <&gpioe 4 0>; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc1_b4_pins_a { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | 	pins1 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | 	pins2 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc1_dir_pins_b { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | 	pins1 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | 	pins2 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc2 { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc2_b4_pins_a { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | 	pins1 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | 	pins2 { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc2_d47_pins_c { | ||||||
|  | 	u-boot,dm-spl; | ||||||
|  | 	pins { | ||||||
|  | 		u-boot,dm-spl; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &uart4 { | ||||||
|  | 	u-boot,dm-pre-reloc; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &uart4_pins_b { | ||||||
|  | 	u-boot,dm-pre-reloc; | ||||||
|  | 	pins1 { | ||||||
|  | 		u-boot,dm-pre-reloc; | ||||||
|  | 	}; | ||||||
|  | 	pins2 { | ||||||
|  | 		u-boot,dm-pre-reloc; | ||||||
|  | 		/delete-property/ bias-disable; | ||||||
|  | 		bias-pull-up; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbotg_hs { | ||||||
|  | 	u-boot,force-b-session-valid; | ||||||
|  | 	hnp-srp-disable; | ||||||
|  | }; | ||||||
							
								
								
									
										178
									
								
								arch/arm/dts/stm32mp15xx-dhcor-testbench.dts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								arch/arm/dts/stm32mp15xx-dhcor-testbench.dts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,178 @@ | |||||||
|  | // SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause) | ||||||
|  | /* | ||||||
|  |  * Copyright (C) 2022 Marek Vasut <marex@denx.de> | ||||||
|  |  */ | ||||||
|  | /dts-v1/; | ||||||
|  | 
 | ||||||
|  | #include "stm32mp151.dtsi" | ||||||
|  | #include "stm32mp15xx-dhcor-som.dtsi" | ||||||
|  | 
 | ||||||
|  | / { | ||||||
|  | 	model = "DH electronics STM32MP15xx DHCOR Testbench"; | ||||||
|  | 	compatible = "dh,stm32mp15xx-dhcor-testbench", "st,stm32mp1xx"; | ||||||
|  | 
 | ||||||
|  | 	aliases { | ||||||
|  | 		ethernet0 = ðernet0; | ||||||
|  | 		mmc0 = &sdmmc1; | ||||||
|  | 		mmc1 = &sdmmc2; | ||||||
|  | 		serial0 = &uart4; | ||||||
|  | 		serial1 = &uart7; | ||||||
|  | 		spi0 = &qspi; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	chosen { | ||||||
|  | 		stdout-path = "serial0:115200n8"; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	sd_switch: regulator-sd_switch { | ||||||
|  | 		compatible = "regulator-gpio"; | ||||||
|  | 		regulator-name = "sd_switch"; | ||||||
|  | 		regulator-min-microvolt = <1800000>; | ||||||
|  | 		regulator-max-microvolt = <2900000>; | ||||||
|  | 		regulator-type = "voltage"; | ||||||
|  | 		regulator-always-on; | ||||||
|  | 
 | ||||||
|  | 		gpios = <&gpioi 5 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		gpios-states = <0>; | ||||||
|  | 		states = <1800000 0x1>, | ||||||
|  | 			 <2900000 0x0>; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &adc { | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	pinctrl-0 = <&adc12_ain_pins_b>; | ||||||
|  | 	vdd-supply = <&vdd>; | ||||||
|  | 	vdda-supply = <&vdda>; | ||||||
|  | 	vref-supply = <&vdda>; | ||||||
|  | 	status = "okay"; | ||||||
|  | 
 | ||||||
|  | 	adc1: adc@0 { | ||||||
|  | 		st,adc-channels = <0 1 6>; | ||||||
|  | 		st,min-sample-time-nsecs = <5000>; | ||||||
|  | 		status = "okay"; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	adc2: adc@100 { | ||||||
|  | 		st,adc-channels = <0 1 2>; | ||||||
|  | 		st,min-sample-time-nsecs = <5000>; | ||||||
|  | 		status = "okay"; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | ðernet0 { | ||||||
|  | 	status = "okay"; | ||||||
|  | 	pinctrl-0 = <ðernet0_rgmii_pins_c>; | ||||||
|  | 	pinctrl-1 = <ðernet0_rgmii_sleep_pins_c>; | ||||||
|  | 	pinctrl-names = "default", "sleep"; | ||||||
|  | 	phy-mode = "rgmii"; | ||||||
|  | 	max-speed = <1000>; | ||||||
|  | 	phy-handle = <&phy0>; | ||||||
|  | 
 | ||||||
|  | 	mdio0 { | ||||||
|  | 		#address-cells = <1>; | ||||||
|  | 		#size-cells = <0>; | ||||||
|  | 		compatible = "snps,dwmac-mdio"; | ||||||
|  | 		reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>; | ||||||
|  | 		reset-delay-us = <1000>; | ||||||
|  | 
 | ||||||
|  | 		phy0: ethernet-phy@7 { | ||||||
|  | 			reg = <7>; | ||||||
|  | 
 | ||||||
|  | 			rxc-skew-ps = <1500>; | ||||||
|  | 			rxdv-skew-ps = <540>; | ||||||
|  | 			rxd0-skew-ps = <420>; | ||||||
|  | 			rxd1-skew-ps = <420>; | ||||||
|  | 			rxd2-skew-ps = <420>; | ||||||
|  | 			rxd3-skew-ps = <420>; | ||||||
|  | 
 | ||||||
|  | 			txc-skew-ps = <1440>; | ||||||
|  | 			txen-skew-ps = <540>; | ||||||
|  | 			txd0-skew-ps = <420>; | ||||||
|  | 			txd1-skew-ps = <420>; | ||||||
|  | 			txd2-skew-ps = <420>; | ||||||
|  | 			txd3-skew-ps = <420>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc1 { | ||||||
|  | 	pinctrl-names = "default", "opendrain", "sleep"; | ||||||
|  | 	pinctrl-0 = <&sdmmc1_b4_pins_a &sdmmc1_dir_pins_b>; | ||||||
|  | 	pinctrl-1 = <&sdmmc1_b4_od_pins_a &sdmmc1_dir_pins_b>; | ||||||
|  | 	pinctrl-2 = <&sdmmc1_b4_sleep_pins_a &sdmmc1_dir_sleep_pins_b>; | ||||||
|  | 	cd-gpios = <&gpioi 8 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>; | ||||||
|  | 	disable-wp; | ||||||
|  | 	st,sig-dir; | ||||||
|  | 	st,neg-edge; | ||||||
|  | 	st,use-ckin; | ||||||
|  | 	bus-width = <4>; | ||||||
|  | 	vmmc-supply = <&vdd_sd>; | ||||||
|  | 	vqmmc-supply = <&sd_switch>; | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &sdmmc2 { | ||||||
|  | 	pinctrl-names = "default", "opendrain", "sleep"; | ||||||
|  | 	pinctrl-0 = <&sdmmc2_b4_pins_a &sdmmc2_d47_pins_c>; | ||||||
|  | 	pinctrl-1 = <&sdmmc2_b4_od_pins_a &sdmmc2_d47_pins_c>; | ||||||
|  | 	pinctrl-2 = <&sdmmc2_b4_sleep_pins_a &sdmmc2_d47_sleep_pins_c>; | ||||||
|  | 	bus-width = <8>; | ||||||
|  | 	mmc-ddr-1_8v; | ||||||
|  | 	no-sd; | ||||||
|  | 	no-sdio; | ||||||
|  | 	non-removable; | ||||||
|  | 	st,neg-edge; | ||||||
|  | 	vmmc-supply = <&v3v3>; | ||||||
|  | 	vqmmc-supply = <&v3v3>; | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &uart4 { | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	pinctrl-0 = <&uart4_pins_b>; | ||||||
|  | 	/delete-property/dmas; | ||||||
|  | 	/delete-property/dma-names; | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &uart7 { | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	pinctrl-0 = <&uart7_pins_a>; | ||||||
|  | 	uart-has-rtscts; | ||||||
|  | 	/delete-property/dmas; | ||||||
|  | 	/delete-property/dma-names; | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbh_ehci { | ||||||
|  | 	phys = <&usbphyc_port0>; | ||||||
|  | 	phy-names = "usb"; | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbotg_hs { | ||||||
|  | 	pinctrl-0 = <&usbotg_hs_pins_a>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	phy-names = "usb2-phy"; | ||||||
|  | 	phys = <&usbphyc_port1 0>; | ||||||
|  | 	status = "okay"; | ||||||
|  | 	vbus-supply = <&vbus_otg>; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbphyc { | ||||||
|  | 	status = "okay"; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbphyc_port0 { | ||||||
|  | 	phy-supply = <&vdd_usb>; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &usbphyc_port1 { | ||||||
|  | 	phy-supply = <&vdd_usb>; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | &vdd { | ||||||
|  | 	/delete-property/ regulator-always-on; | ||||||
|  | 	regulator-min-microvolt = <1200000>; | ||||||
|  | }; | ||||||
| @ -144,6 +144,21 @@ | |||||||
| 		CLK_LPTIM45_LSE | 		CLK_LPTIM45_LSE | ||||||
| 	>; | 	>; | ||||||
| 
 | 
 | ||||||
|  | 	/* | ||||||
|  | 	 * cfg = < DIVM1 DIVN P Q R PQR(p,q,r) >; | ||||||
|  | 	 * frac = < f >; | ||||||
|  | 	 * | ||||||
|  | 	 * PRQ(p,q,r) ... for p,q,r: 0-output disabled / 1-output enabled | ||||||
|  | 	 * DIVN ... actually multiplier, but RCC_PLL1CFGR1 calls the field DIVN | ||||||
|  | 	 * m ... for PLL1,2: m=2 ; for PLL3,4: m=1 | ||||||
|  | 	 * XTAL = 24 MHz | ||||||
|  | 	 * | ||||||
|  | 	 * VCO = ( XTAL / (DIVM1 + 1) ) * m * ( DIVN + 1 + ( f / 8192 ) ) | ||||||
|  | 	 *   P = VCO / (P + 1) | ||||||
|  | 	 *   Q = VCO / (Q + 1) | ||||||
|  | 	 *   R = VCO / (R + 1) | ||||||
|  | 	 */ | ||||||
|  | 
 | ||||||
| 	/* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ | 	/* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ | ||||||
| 	pll2: st,pll@1 { | 	pll2: st,pll@1 { | ||||||
| 		compatible = "st,stm32mp1-pll"; | 		compatible = "st,stm32mp1-pll"; | ||||||
| @ -162,7 +177,7 @@ | |||||||
| 		u-boot,dm-pre-reloc; | 		u-boot,dm-pre-reloc; | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	/* VCO = 600.0 MHz => P = 99, Q = 74, R = 99 */ | 	/* VCO = 594.0 MHz => P = 99, Q = 74, R = 99 */ | ||||||
| 	pll4: st,pll@3 { | 	pll4: st,pll@3 { | ||||||
| 		compatible = "st,stm32mp1-pll"; | 		compatible = "st,stm32mp1-pll"; | ||||||
| 		reg = <3>; | 		reg = <3>; | ||||||
|  | |||||||
| @ -117,7 +117,7 @@ endif | |||||||
| if DEBUG_UART | if DEBUG_UART | ||||||
| 
 | 
 | ||||||
| config DEBUG_UART_BOARD_INIT | config DEBUG_UART_BOARD_INIT | ||||||
| 	default y | 	default y if SPL | ||||||
| 
 | 
 | ||||||
| # debug on UART4 by default | # debug on UART4 by default | ||||||
| config DEBUG_UART_BASE | config DEBUG_UART_BASE | ||||||
|  | |||||||
| @ -547,7 +547,7 @@ static int board_get_regulator_buck3_nvm_uv_av96(int *uv) | |||||||
| 	if (!prop || !len) | 	if (!prop || !len) | ||||||
| 		return -ENODEV; | 		return -ENODEV; | ||||||
| 
 | 
 | ||||||
| 	if (!strstr(prop, "avenger96")) | 	if (!strstr(prop, "avenger96") && !strstr(prop, "dhcor-testbench")) | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 
 | 
 | ||||||
| 	/* Read out STPMIC1 NVM and determine default Buck3 voltage. */ | 	/* Read out STPMIC1 NVM and determine default Buck3 voltage. */ | ||||||
| @ -564,18 +564,32 @@ static int board_get_regulator_buck3_nvm_uv_av96(int *uv) | |||||||
| 	bucks_vout >>= STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_OFFSET(3); | 	bucks_vout >>= STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_OFFSET(3); | ||||||
| 	bucks_vout &= STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_MASK; | 	bucks_vout &= STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_MASK; | ||||||
| 
 | 
 | ||||||
|  | 	if (strstr(prop, "avenger96")) { | ||||||
| 		/*
 | 		/*
 | ||||||
| 		 * Avenger96 board comes in multiple regulator configurations: | 		 * Avenger96 board comes in multiple regulator configurations: | ||||||
| 	 * - rev.100 or rev.200 have Buck3 preconfigured to 3V3 operation on | 		 * - rev.100 or rev.200 have Buck3 preconfigured to | ||||||
| 	 *   boot and contains extra Enpirion EP53A8LQI DCDC converter which | 		 *   3V3 operation on boot and contains extra Enpirion | ||||||
| 	 *   supplies the IO. Reduce Buck3 voltage to 2V9 to not waste power. | 		 *   EP53A8LQI DCDC converter which supplies the IO. | ||||||
| 	 * - rev.200L have Buck3 preconfigured to 1V8 operation and have no | 		 *   Reduce Buck3 voltage to 2V9 to not waste power. | ||||||
| 	 *   Enpirion EP53A8LQI DCDC anymore, the IO is supplied from Buck3. | 		 * - rev.200L have Buck3 preconfigured to 1V8 operation | ||||||
|  | 		 *   and have no Enpirion EP53A8LQI DCDC anymore, the | ||||||
|  | 		 *   IO is supplied from Buck3. | ||||||
| 		 */ | 		 */ | ||||||
| 		if (bucks_vout == STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_3V3) | 		if (bucks_vout == STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_3V3) | ||||||
| 			*uv = 2900000; | 			*uv = 2900000; | ||||||
| 		else | 		else | ||||||
| 			*uv = 1800000; | 			*uv = 1800000; | ||||||
|  | 	} else { | ||||||
|  | 		/* Testbench always respects Buck3 NVM settings */ | ||||||
|  | 		if (bucks_vout == STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_3V3) | ||||||
|  | 			*uv = 3300000; | ||||||
|  | 		else if (bucks_vout == STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_3V0) | ||||||
|  | 			*uv = 3000000; | ||||||
|  | 		else if (bucks_vout == STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_1V8) | ||||||
|  | 			*uv = 1800000; | ||||||
|  | 		else	/* STPMIC_NVM_BUCKS_VOUT_SHR_BUCK_1V2 */ | ||||||
|  | 			*uv = 1200000; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| @ -595,6 +609,7 @@ static void board_init_regulator_av96(void) | |||||||
| 
 | 
 | ||||||
| 	/* Adjust Buck3 per preconfigured PMIC voltage from NVM. */ | 	/* Adjust Buck3 per preconfigured PMIC voltage from NVM. */ | ||||||
| 	regulator_set_value(rdev, uv); | 	regulator_set_value(rdev, uv); | ||||||
|  | 	regulator_set_enable(rdev, true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void board_init_regulator(void) | static void board_init_regulator(void) | ||||||
|  | |||||||
| @ -18,13 +18,21 @@ | |||||||
| 
 | 
 | ||||||
| 		fdt-1 { | 		fdt-1 { | ||||||
| 			description = ".dtb"; | 			description = ".dtb"; | ||||||
| 			data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-avenger96.dtb"); | 			data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-testbench.dtb"); | ||||||
| 			type = "flat_dt"; | 			type = "flat_dt"; | ||||||
| 			arch = "arm"; | 			arch = "arm"; | ||||||
| 			compression = "none"; | 			compression = "none"; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
| 		fdt-2 { | 		fdt-2 { | ||||||
|  | 			description = ".dtb"; | ||||||
|  | 			data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-avenger96.dtb"); | ||||||
|  | 			type = "flat_dt"; | ||||||
|  | 			arch = "arm"; | ||||||
|  | 			compression = "none"; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
|  | 		fdt-3 { | ||||||
| 			description = ".dtb"; | 			description = ".dtb"; | ||||||
| 			data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dtb"); | 			data = /incbin/("arch/arm/dts/stm32mp15xx-dhcor-drc-compact.dtb"); | ||||||
| 			type = "flat_dt"; | 			type = "flat_dt"; | ||||||
| @ -38,18 +46,25 @@ | |||||||
| 
 | 
 | ||||||
| 		config-1 { | 		config-1 { | ||||||
| 			/* DT+SoM+board model */ | 			/* DT+SoM+board model */ | ||||||
| 			description = "arrow,stm32mp15xx-avenger96_somrev0_boardrev1"; | 			description = "dh,stm32mp15xx-dhcor-testbench_somrev0_boardrev1"; | ||||||
| 			firmware = "uboot"; | 			firmware = "uboot"; | ||||||
| 			fdt = "fdt-1"; | 			fdt = "fdt-1"; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
| 		config-2 { | 		config-2 { | ||||||
| 			/* DT+SoM+board model */ | 			/* DT+SoM+board model */ | ||||||
| 			description = "dh,stm32mp15xx-dhcor-drc-compact_somrev0_boardrev0"; | 			description = "arrow,stm32mp15xx-avenger96_somrev0_boardrev1"; | ||||||
| 			firmware = "uboot"; | 			firmware = "uboot"; | ||||||
| 			fdt = "fdt-2"; | 			fdt = "fdt-2"; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
|  | 		config-3 { | ||||||
|  | 			/* DT+SoM+board model */ | ||||||
|  | 			description = "dh,stm32mp15xx-dhcor-drc-compact_somrev0_boardrev0"; | ||||||
|  | 			firmware = "uboot"; | ||||||
|  | 			fdt = "fdt-3"; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		/* Add 586-200..586-400 with fdt-2..fdt-4 here */ | 		/* Add 586-200..586-400 with fdt-2..fdt-4 here */ | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -8,3 +8,5 @@ obj-y += spl.o | |||||||
| else | else | ||||||
| obj-y += stm32mp1.o | obj-y += stm32mp1.o | ||||||
| endif | endif | ||||||
|  | 
 | ||||||
|  | obj-$(CONFIG_DEBUG_UART_BOARD_INIT) += ../../st/stm32mp1/debug_uart.o | ||||||
|  | |||||||
| @ -6,7 +6,6 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <common.h> | #include <common.h> | ||||||
| #include <asm/io.h> |  | ||||||
| 
 | 
 | ||||||
| /* board early initialisation in board_f: need to use global variable */ | /* board early initialisation in board_f: need to use global variable */ | ||||||
| static u32 opp_voltage_mv __section(".data"); | static u32 opp_voltage_mv __section(".data"); | ||||||
| @ -22,27 +21,3 @@ int board_early_init_f(void) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef CONFIG_DEBUG_UART_BOARD_INIT |  | ||||||
| void board_debug_uart_init(void) |  | ||||||
| { |  | ||||||
| #if (CONFIG_DEBUG_UART_BASE == STM32_UART4_BASE) |  | ||||||
| 
 |  | ||||||
| #define RCC_MP_APB1ENSETR (STM32_RCC_BASE + 0x0A00) |  | ||||||
| #define RCC_MP_AHB4ENSETR (STM32_RCC_BASE + 0x0A28) |  | ||||||
| 
 |  | ||||||
| 	/* UART4 clock enable */ |  | ||||||
| 	setbits_le32(RCC_MP_APB1ENSETR, BIT(16)); |  | ||||||
| 
 |  | ||||||
| #define GPIOG_BASE 0x50008000 |  | ||||||
| 	/* GPIOG clock enable */ |  | ||||||
| 	writel(BIT(6), RCC_MP_AHB4ENSETR); |  | ||||||
| 	/* GPIO configuration for ST boards: Uart4 TX = G11 */ |  | ||||||
| 	writel(0xffbfffff, GPIOG_BASE + 0x00); |  | ||||||
| 	writel(0x00006000, GPIOG_BASE + 0x24); |  | ||||||
| #else |  | ||||||
| 
 |  | ||||||
| #error("CONFIG_DEBUG_UART_BASE: not supported value") |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  | |||||||
| @ -8,3 +8,5 @@ obj-y += spl.o | |||||||
| else | else | ||||||
| obj-y += stm32mp1.o | obj-y += stm32mp1.o | ||||||
| endif | endif | ||||||
|  | 
 | ||||||
|  | obj-$(CONFIG_DEBUG_UART_BOARD_INIT) += debug_uart.o | ||||||
|  | |||||||
							
								
								
									
										29
									
								
								board/st/stm32mp1/debug_uart.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								board/st/stm32mp1/debug_uart.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | // SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause
 | ||||||
|  | /*
 | ||||||
|  |  * Copyright (C) 2022, STMicroelectronics - All Rights Reserved | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #include <config.h> | ||||||
|  | #include <debug_uart.h> | ||||||
|  | #include <asm/io.h> | ||||||
|  | #include <asm/arch/stm32.h> | ||||||
|  | #include <linux/bitops.h> | ||||||
|  | 
 | ||||||
|  | #define RCC_MP_APB1ENSETR (STM32_RCC_BASE + 0x0A00) | ||||||
|  | #define RCC_MP_AHB4ENSETR (STM32_RCC_BASE + 0x0A28) | ||||||
|  | 
 | ||||||
|  | #define GPIOG_BASE 0x50008000 | ||||||
|  | 
 | ||||||
|  | void board_debug_uart_init(void) | ||||||
|  | { | ||||||
|  | 	if (CONFIG_DEBUG_UART_BASE == STM32_UART4_BASE) { | ||||||
|  | 		/* UART4 clock enable */ | ||||||
|  | 		setbits_le32(RCC_MP_APB1ENSETR, BIT(16)); | ||||||
|  | 
 | ||||||
|  | 		/* GPIOG clock enable */ | ||||||
|  | 		writel(BIT(6), RCC_MP_AHB4ENSETR); | ||||||
|  | 		/* GPIO configuration for ST boards: Uart4 TX = G11 */ | ||||||
|  | 		writel(0xffbfffff, GPIOG_BASE + 0x00); | ||||||
|  | 		writel(0x00006000, GPIOG_BASE + 0x24); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -5,11 +5,7 @@ | |||||||
| 
 | 
 | ||||||
| #include <config.h> | #include <config.h> | ||||||
| #include <common.h> | #include <common.h> | ||||||
| #include <init.h> |  | ||||||
| #include <asm/io.h> |  | ||||||
| #include <asm/arch/sys_proto.h> | #include <asm/arch/sys_proto.h> | ||||||
| #include <linux/bitops.h> |  | ||||||
| #include <linux/delay.h> |  | ||||||
| #include "../common/stpmic1.h" | #include "../common/stpmic1.h" | ||||||
| 
 | 
 | ||||||
| /* board early initialisation in board_f: need to use global variable */ | /* board early initialisation in board_f: need to use global variable */ | ||||||
| @ -29,27 +25,3 @@ int board_early_init_f(void) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef CONFIG_DEBUG_UART_BOARD_INIT |  | ||||||
| void board_debug_uart_init(void) |  | ||||||
| { |  | ||||||
| #if (CONFIG_DEBUG_UART_BASE == STM32_UART4_BASE) |  | ||||||
| 
 |  | ||||||
| #define RCC_MP_APB1ENSETR (STM32_RCC_BASE + 0x0A00) |  | ||||||
| #define RCC_MP_AHB4ENSETR (STM32_RCC_BASE + 0x0A28) |  | ||||||
| 
 |  | ||||||
| 	/* UART4 clock enable */ |  | ||||||
| 	setbits_le32(RCC_MP_APB1ENSETR, BIT(16)); |  | ||||||
| 
 |  | ||||||
| #define GPIOG_BASE 0x50008000 |  | ||||||
| 	/* GPIOG clock enable */ |  | ||||||
| 	writel(BIT(6), RCC_MP_AHB4ENSETR); |  | ||||||
| 	/* GPIO configuration for ST boards: Uart4 TX = G11 */ |  | ||||||
| 	writel(0xffbfffff, GPIOG_BASE + 0x00); |  | ||||||
| 	writel(0x00006000, GPIOG_BASE + 0x24); |  | ||||||
| #else |  | ||||||
| 
 |  | ||||||
| #error("CONFIG_DEBUG_UART_BASE: not supported value") |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  | |||||||
| @ -79,6 +79,7 @@ CONFIG_CMD_TIME=y | |||||||
| CONFIG_CMD_TIMER=y | CONFIG_CMD_TIMER=y | ||||||
| CONFIG_CMD_PMIC=y | CONFIG_CMD_PMIC=y | ||||||
| CONFIG_CMD_REGULATOR=y | CONFIG_CMD_REGULATOR=y | ||||||
|  | CONFIG_CMD_BTRFS=y | ||||||
| CONFIG_CMD_EXT4_WRITE=y | CONFIG_CMD_EXT4_WRITE=y | ||||||
| CONFIG_CMD_MTDPARTS=y | CONFIG_CMD_MTDPARTS=y | ||||||
| CONFIG_MTDIDS_DEFAULT="nor0=nor0" | CONFIG_MTDIDS_DEFAULT="nor0=nor0" | ||||||
|  | |||||||
| @ -77,6 +77,7 @@ CONFIG_CMD_TIME=y | |||||||
| CONFIG_CMD_TIMER=y | CONFIG_CMD_TIMER=y | ||||||
| CONFIG_CMD_PMIC=y | CONFIG_CMD_PMIC=y | ||||||
| CONFIG_CMD_REGULATOR=y | CONFIG_CMD_REGULATOR=y | ||||||
|  | CONFIG_CMD_BTRFS=y | ||||||
| CONFIG_CMD_EXT4_WRITE=y | CONFIG_CMD_EXT4_WRITE=y | ||||||
| CONFIG_CMD_MTDPARTS=y | CONFIG_CMD_MTDPARTS=y | ||||||
| CONFIG_MTDIDS_DEFAULT="nor0=nor0" | CONFIG_MTDIDS_DEFAULT="nor0=nor0" | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user