mirror of
https://github.com/armbian/build
synced 2025-09-24 19:47:06 +07:00
288 lines
7.0 KiB
Diff
288 lines
7.0 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Chiyuki Akatsuki <17957399+TheSnowfield@users.noreply.github.com>
|
|
Date: Fri, 12 Apr 2024 07:32:24 +0000
|
|
Subject: Add Sakura Pi RK3308B support
|
|
|
|
Signed-off-by: Chiyuki Akatsuki <17957399+TheSnowfield@users.noreply.github.com>
|
|
---
|
|
arch/arm/dts/rk3308-sakurapi-rk3308b-u-boot.dtsi | 18 ++
|
|
dts/upstream/src/arm64/rockchip/rk3308-sakurapi-rk3308b.dts | 167 ++++++++++++++++++++++
|
|
configs/sakurapi_rk3308b_defconfig | 105 ++++++++++++++
|
|
3 files changed, 290 insertions(+)
|
|
|
|
diff --git a/arch/arm/dts/rk3308-sakurapi-rk3308b-u-boot.dtsi b/arch/arm/dts/rk3308-sakurapi-rk3308b-u-boot.dtsi
|
|
new file mode 100644
|
|
index 0000000000..7ff0ce903a
|
|
--- /dev/null
|
|
+++ b/arch/arm/dts/rk3308-sakurapi-rk3308b-u-boot.dtsi
|
|
@@ -0,0 +1,18 @@
|
|
+// SPDX-License-Identifier: GPL-2.0+
|
|
+/*
|
|
+ * (C) Copyright 2018-2019 Rockchip Electronics Co., Ltd
|
|
+ * (C) Copyright 2024 Chiyuki Akatsuki
|
|
+ */
|
|
+#include "rk3308-u-boot.dtsi"
|
|
+
|
|
+/ {
|
|
+ chosen {
|
|
+ u-boot,spl-boot-order = "same-as-spl", &sdmmc, &emmc;
|
|
+ };
|
|
+};
|
|
+
|
|
+&uart2 {
|
|
+ u-boot,dm-pre-reloc;
|
|
+ clock-frequency = <24000000>;
|
|
+ status = "okay";
|
|
+};
|
|
diff --git a/dts/upstream/src/arm64/rockchip/rk3308-sakurapi-rk3308b.dts b/dts/upstream/src/arm64/rockchip/rk3308-sakurapi-rk3308b.dts
|
|
new file mode 100644
|
|
index 0000000000..2697f0b885
|
|
--- /dev/null
|
|
+++ b/dts/upstream/src/arm64/rockchip/rk3308-sakurapi-rk3308b.dts
|
|
@@ -0,0 +1,167 @@
|
|
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
|
+/*
|
|
+ * Copyright (c) 2019 Akash Gajjar <akash@openedev.com>
|
|
+ * Copyright (c) 2019 Jagan Teki <jagan@openedev.com>
|
|
+ * Copyright (c) 2024 Chiyuki Akatsuki
|
|
+ */
|
|
+
|
|
+/dts-v1/;
|
|
+#include "rk3308.dtsi"
|
|
+
|
|
+/ {
|
|
+ model = "Sakura Pi RK3308B";
|
|
+ compatible = "rockchip,rk3308";
|
|
+
|
|
+ chosen {
|
|
+ stdout-path = "serial2:1500000n8";
|
|
+ };
|
|
+
|
|
+ vcc5v0_sys: vcc5v0-sys {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc5v0_sys";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ regulator-min-microvolt = <5000000>;
|
|
+ regulator-max-microvolt = <5000000>;
|
|
+ };
|
|
+
|
|
+ vdd_core: vdd-core {
|
|
+ compatible = "pwm-regulator";
|
|
+ pwms = <&pwm0 0 5000 1>;
|
|
+ regulator-name = "vdd_core";
|
|
+ regulator-min-microvolt = <827000>;
|
|
+ regulator-max-microvolt = <1340000>;
|
|
+ regulator-init-microvolt = <1015000>;
|
|
+ regulator-settling-time-up-us = <250>;
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ pwm-supply = <&vcc5v0_sys>;
|
|
+ };
|
|
+
|
|
+ vdd_log: vdd-log {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vdd_log";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ regulator-min-microvolt = <1050000>;
|
|
+ regulator-max-microvolt = <1050000>;
|
|
+ vin-supply = <&vcc5v0_sys>;
|
|
+ };
|
|
+
|
|
+ vcc_ddr: vcc-ddr {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc_ddr";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ regulator-min-microvolt = <1500000>;
|
|
+ regulator-max-microvolt = <1500000>;
|
|
+ vin-supply = <&vcc5v0_sys>;
|
|
+ };
|
|
+
|
|
+ vcc_1v8: vcc-1v8 {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc_1v8";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ regulator-min-microvolt = <1800000>;
|
|
+ regulator-max-microvolt = <1800000>;
|
|
+ vin-supply = <&vcc_io>;
|
|
+ };
|
|
+
|
|
+ vcc_io: vcc-io {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc_io";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ regulator-min-microvolt = <3300000>;
|
|
+ regulator-max-microvolt = <3300000>;
|
|
+ vin-supply = <&vcc5v0_sys>;
|
|
+ };
|
|
+
|
|
+ vcc_phy: vcc-phy-regulator {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc_phy";
|
|
+ regulator-always-on;
|
|
+ regulator-boot-on;
|
|
+ };
|
|
+
|
|
+ vcc5v0_otg: vcc5v0-otg {
|
|
+ compatible = "regulator-fixed";
|
|
+ regulator-name = "vcc5v0_otg";
|
|
+ regulator-always-on;
|
|
+ gpio = <&gpio0 RK_PC5 GPIO_ACTIVE_HIGH>;
|
|
+ enable-active-high;
|
|
+ pinctrl-names = "default";
|
|
+ pinctrl-0 = <&otg_vbus_drv>;
|
|
+ vin-supply = <&vcc5v0_sys>;
|
|
+ };
|
|
+};
|
|
+
|
|
+&cpu0 {
|
|
+ cpu-supply = <&vdd_core>;
|
|
+};
|
|
+
|
|
+&emmc {
|
|
+ bus-width = <8>;
|
|
+ cap-mmc-highspeed;
|
|
+ mmc-hs200-1_8v;
|
|
+ /* supports-sd; */
|
|
+ /* disable-wp; */
|
|
+ non-removable;
|
|
+ /* num-slots = <1>; */
|
|
+ /* please provide actual vmmc and vqmmc supplies
|
|
+ vin is not a valid supply for emmcs */
|
|
+ vin-supply = <&vcc_io>;
|
|
+ status = "okay";
|
|
+};
|
|
+
|
|
+&i2c1 {
|
|
+ status = "okay";
|
|
+};
|
|
+
|
|
+&sdmmc {
|
|
+ bus-width = <4>;
|
|
+ cap-mmc-highspeed;
|
|
+ cap-sd-highspeed;
|
|
+ disable-wp;
|
|
+ max-frequency = <150000000>;
|
|
+ pinctrl-names = "default";
|
|
+ pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_det &sdmmc_bus4>;
|
|
+ sd-uhs-sdr12;
|
|
+ sd-uhs-sdr25;
|
|
+ sd-uhs-sdr50;
|
|
+ sd-uhs-sdr104;
|
|
+ status = "okay";
|
|
+};
|
|
+
|
|
+&spi2 {
|
|
+ status = "okay";
|
|
+ max-freq = <10000000>;
|
|
+};
|
|
+
|
|
+&pinctrl {
|
|
+ pinctrl-names = "default";
|
|
+ pinctrl-0 = <&rtc_32k>;
|
|
+
|
|
+ usb {
|
|
+ otg_vbus_drv: otg-vbus-drv {
|
|
+ rockchip,pins = <0 RK_PC5 RK_FUNC_GPIO &pcfg_pull_none>;
|
|
+ };
|
|
+ };
|
|
+};
|
|
+
|
|
+&pwm0 {
|
|
+ status = "okay";
|
|
+ pinctrl-0 = <&pwm0_pin_pull_down>;
|
|
+};
|
|
+
|
|
+&saradc {
|
|
+ vref-supply = <&vcc_1v8>;
|
|
+ status = "okay";
|
|
+};
|
|
+
|
|
+&uart2 {
|
|
+ pinctrl-names = "default";
|
|
+ pinctrl-0 = <&uart2m0_xfer>;
|
|
+ status = "okay";
|
|
+};
|
|
diff --git a/configs/sakurapi_rk3308b_defconfig b/configs/sakurapi_rk3308b_defconfig
|
|
new file mode 100644
|
|
index 0000000000..1ab8320fa7
|
|
--- /dev/null
|
|
+++ b/configs/sakurapi_rk3308b_defconfig
|
|
@@ -0,0 +1,72 @@
|
|
+CONFIG_ARM=y
|
|
+CONFIG_SKIP_LOWLEVEL_INIT=y
|
|
+CONFIG_COUNTER_FREQUENCY=24000000
|
|
+CONFIG_ARCH_ROCKCHIP=y
|
|
+CONFIG_DEFAULT_DEVICE_TREE="rockchip/rk3308-sakurapi-rk3308b"
|
|
+CONFIG_DM_RESET=y
|
|
+CONFIG_ROCKCHIP_RK3308=y
|
|
+CONFIG_TARGET_EVB_RK3308=y
|
|
+CONFIG_DEBUG_UART_BASE=0xFF0C0000
|
|
+CONFIG_DEBUG_UART_CLOCK=24000000
|
|
+# CONFIG_DEBUG_UART_BOARD_INIT is not set
|
|
+CONFIG_SYS_LOAD_ADDR=0x800800
|
|
+CONFIG_DEBUG_UART=y
|
|
+CONFIG_ANDROID_BOOT_IMAGE=y
|
|
+CONFIG_FIT=y
|
|
+CONFIG_FIT_VERBOSE=y
|
|
+CONFIG_DEFAULT_FDT_FILE="rockchip/rk3308-sakurapi-rk3308b.dtb"
|
|
+# CONFIG_DISPLAY_CPUINFO is not set
|
|
+CONFIG_SPL_MAX_SIZE=0x40000
|
|
+CONFIG_SPL_PAD_TO=0x7f8000
|
|
+# CONFIG_SPL_RAW_IMAGE_SUPPORT is not set
|
|
+CONFIG_CMD_GPIO=y
|
|
+CONFIG_CMD_GPT=y
|
|
+CONFIG_CMD_MMC=y
|
|
+CONFIG_CMD_USB=y
|
|
+CONFIG_CMD_ROCKUSB=y
|
|
+CONFIG_CMD_USB_MASS_STORAGE=y
|
|
+CONFIG_CMD_RNG=y
|
|
+CONFIG_CMD_KASLRSEED=y
|
|
+CONFIG_CMD_REGULATOR=y
|
|
+CONFIG_SPL_OF_CONTROL=y
|
|
+CONFIG_OF_LIVE=y
|
|
+CONFIG_OF_SPL_REMOVE_PROPS="clock-names interrupt-parent assigned-clocks assigned-clock-rates assigned-clock-parents"
|
|
+CONFIG_SYS_RELOC_GD_ENV_ADDR=y
|
|
+CONFIG_REGMAP=y
|
|
+CONFIG_SYSCON=y
|
|
+CONFIG_CLK=y
|
|
+# CONFIG_USB_FUNCTION_FASTBOOT is not set
|
|
+CONFIG_ROCKCHIP_GPIO=y
|
|
+CONFIG_SYS_I2C_ROCKCHIP=y
|
|
+CONFIG_LED=y
|
|
+CONFIG_LED_GPIO=y
|
|
+CONFIG_ROCKCHIP_IODOMAIN=y
|
|
+CONFIG_SUPPORT_EMMC_RPMB=y
|
|
+CONFIG_MMC_DW=y
|
|
+CONFIG_MMC_DW_ROCKCHIP=y
|
|
+CONFIG_PHY_REALTEK=y
|
|
+CONFIG_DM_MDIO=y
|
|
+CONFIG_DM_ETH_PHY=y
|
|
+CONFIG_ETH_DESIGNWARE=y
|
|
+CONFIG_GMAC_ROCKCHIP=y
|
|
+CONFIG_PHY_ROCKCHIP_INNO_USB2=y
|
|
+CONFIG_PINCTRL=y
|
|
+CONFIG_REGULATOR_PWM=y
|
|
+CONFIG_DM_REGULATOR_FIXED=y
|
|
+CONFIG_PWM_ROCKCHIP=y
|
|
+CONFIG_RAM=y
|
|
+CONFIG_BAUDRATE=1500000
|
|
+CONFIG_DEBUG_UART_SHIFT=2
|
|
+CONFIG_SYS_NS16550_MEM32=y
|
|
+CONFIG_SYSINFO=y
|
|
+CONFIG_SYSRESET=y
|
|
+CONFIG_USB=y
|
|
+CONFIG_DM_USB_GADGET=y
|
|
+CONFIG_USB_EHCI_HCD=y
|
|
+CONFIG_USB_EHCI_GENERIC=y
|
|
+CONFIG_USB_GADGET=y
|
|
+CONFIG_USB_GADGET_DWC2_OTG=y
|
|
+CONFIG_USB_GADGET_DOWNLOAD=y
|
|
+CONFIG_USB_FUNCTION_ROCKUSB=y
|
|
+CONFIG_LZO=y
|
|
+CONFIG_ERRNO_STR=y
|