mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-23 02:15:12 +00:00
6cf6fe2537
The Anbernic RGxx3 is a "pseudo-device" that encompasses the following devices: - Anbernic RG353M - Anbernic RG353P - Anbernic RG353V - Anbernic RG353VS - Anbernic RG503 The rk3566-anbernic-rgxx3.dtsi is synced with upstream Linux, but rk3566-anbernic-rgxx3.dts is a U-Boot specific devicetree that is used for all RGxx3 devices. Via the board.c file, the bootloader automatically sets the correct fdtfile, board, and board_name environment variables so that the correct devicetree can be passed to Linux. It is also possible to simply hard-code a single devicetree in the boot.scr file and use that to load Linux as well. The common specifications for each device are: - Rockchip RK3566 SoC - 2 external SDMMC slots - 1 USB-C host port, 1 USB-C peripheral port - 1 mini-HDMI output - MIPI-DSI based display panel - ADC controlled joysticks with a GPIO mux - GPIO buttons - A PWM controlled vibrator - An ADC controlled button All of the common features are defined in the devicetree synced from upstream Linux. TODO: DSI panel auto-detection for the RG353 devices (requires porting of DSI controller driver and DSI-DPHY driver to send DSI commands to the panel). Signed-off-by: Chris Morgan <macromorgan@hotmail.com> Reviewed-by: Kever Yang <kever.yang@rock-chips.com>
86 lines
1.9 KiB
Text
86 lines
1.9 KiB
Text
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
|
|
|
#include "rk356x-u-boot.dtsi"
|
|
|
|
/ {
|
|
chosen {
|
|
stdout-path = &uart2;
|
|
u-boot,spl-boot-order = "same-as-spl", &sdmmc1, &sdmmc0;
|
|
};
|
|
|
|
rng: rng@fe388000 {
|
|
compatible = "rockchip,cryptov2-rng";
|
|
reg = <0x0 0xfe388000 0x0 0x2000>;
|
|
status = "okay";
|
|
};
|
|
};
|
|
|
|
&cru {
|
|
assigned-clocks =
|
|
<&pmucru CLK_RTC_32K>,
|
|
<&pmucru PLL_PPLL>,
|
|
<&pmucru PCLK_PMU>, <&cru PLL_CPLL>,
|
|
<&cru PLL_GPLL>,
|
|
<&cru ACLK_BUS>, <&cru PCLK_BUS>,
|
|
<&cru ACLK_TOP_HIGH>, <&cru ACLK_TOP_LOW>,
|
|
<&cru HCLK_TOP>, <&cru PCLK_TOP>,
|
|
<&cru ACLK_PERIMID>, <&cru HCLK_PERIMID>,
|
|
<&cru CPLL_500M>, <&cru CPLL_333M>,
|
|
<&cru CPLL_250M>, <&cru CPLL_125M>,
|
|
<&cru CPLL_100M>, <&cru CPLL_62P5M>,
|
|
<&cru CPLL_50M>, <&cru CPLL_25M>;
|
|
assigned-clock-rates =
|
|
<32768>,
|
|
<200000000>,
|
|
<100000000>, <1000000000>,
|
|
<1188000000>,
|
|
<150000000>, <100000000>,
|
|
<500000000>, <400000000>,
|
|
<150000000>, <100000000>,
|
|
<300000000>, <150000000>,
|
|
<500000000>, <333333333>,
|
|
<250000000>, <125000000>,
|
|
<100000000>, <62500000>,
|
|
<50000000>, <25000000>;
|
|
assigned-clock-parents =
|
|
<&pmucru CLK_RTC32K_FRAC>;
|
|
};
|
|
|
|
&i2c2 {
|
|
status = "okay";
|
|
};
|
|
|
|
&pmucru {
|
|
assigned-clocks = <&pmucru SCLK_32K_IOE>;
|
|
assigned-clock-parents = <&pmucru CLK_RTC_32K>;
|
|
};
|
|
|
|
/*
|
|
* We don't need the clocks, but if they are present they may cause
|
|
* probing to fail so we remove them for U-Boot.
|
|
*/
|
|
&rk817 {
|
|
/delete-property/ assigned-clocks;
|
|
/delete-property/ assigned-clock-parents;
|
|
/delete-property/ clocks;
|
|
/delete-property/ clock-names;
|
|
};
|
|
|
|
&sdhci {
|
|
pinctrl-0 = <&emmc_bus8>, <&emmc_clk>, <&emmc_cmd>,
|
|
<&emmc_datastrobe>, <&emmc_rstnout>;
|
|
pinctrl-names = "default";
|
|
bus-width = <8>;
|
|
max-frequency = <200000000>;
|
|
mmc-hs200-1_8v;
|
|
non-removable;
|
|
vmmc-supply = <&vcc_3v3>;
|
|
vqmmc-supply = <&vcc_1v8>;
|
|
status = "okay";
|
|
};
|
|
|
|
&uart2 {
|
|
clock-frequency = <24000000>;
|
|
bootph-all;
|
|
status = "okay";
|
|
};
|