aboutsummaryrefslogtreecommitdiff
path: root/board
diff options
context:
space:
mode:
authorHaaland Chen <haaland@milkv.io>2023-11-29 15:37:33 +0800
committerHan Gao/Revy/Rabenda <rabenda.cn@gmail.com>2023-12-03 11:32:41 +0800
commit985e884b0b938ec9da6173f569ce5fb6c7f1e2fb (patch)
tree4c3764c5e67e188d2535309b1161bb2930140530 /board
parent918a8c89e056e3462031d6a498bb4fcc0c3526ce (diff)
add Milk-V Meles board
Signed-off-by: Haaland Chen <haaland@milkv.io>
Diffstat (limited to 'board')
-rw-r--r--board/thead/light-c910/Kconfig4
-rw-r--r--board/thead/light-c910/clock_config.c4
-rw-r--r--board/thead/light-c910/light.c199
-rw-r--r--board/thead/light-c910/lpddr-regu/ddr_regu.c4
4 files changed, 207 insertions, 4 deletions
diff --git a/board/thead/light-c910/Kconfig b/board/thead/light-c910/Kconfig
index 5dd65f43..abac54f3 100644
--- a/board/thead/light-c910/Kconfig
+++ b/board/thead/light-c910/Kconfig
@@ -126,6 +126,10 @@ config TARGET_LIGHT_FM_C910_B_POWER
bool "light fullmask for light-b-power board "
default n
+config TARGET_LIGHT_FM_C910_MILKV_MELES
+ bool "light fullmask for Milk-V Meles board "
+ default n
+
config SYS_TEXT_BASE
default 0xc0000000 if RISCV_MMODE
default 0x00200000 if RISCV_SMODE
diff --git a/board/thead/light-c910/clock_config.c b/board/thead/light-c910/clock_config.c
index 50036fb4..f3ea3836 100644
--- a/board/thead/light-c910/clock_config.c
+++ b/board/thead/light-c910/clock_config.c
@@ -1146,7 +1146,7 @@ void ap_mipi_dsi1_clk_endisable(bool en)
writel(cfg1, (void __iomem *)AP_DPU1_PLL_CFG1);
}
-#if defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_DISCRETE) || defined (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_POWER) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_B) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A)
+#if defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_DISCRETE) || defined (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_POWER) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_B) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A) || defined (CONFIG_TARGET_LIGHT_FM_C910_MILKV_MELES)
static void ap_multimedia_div_num_set(enum multimedia_div_type type, unsigned int div_num)
{
unsigned long div_reg;
@@ -1304,7 +1304,7 @@ int clk_config(void)
/* The boards other than the LightA board perform the bus down-speed operation */
-#if defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_DISCRETE) || defined (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_POWER) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_B) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A)
+#if defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_DISCRETE) || defined (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_POWER) || defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_B) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A) || defined (CONFIG_TARGET_LIGHT_FM_C910_MILKV_MELES)
ap_multimedia_div_num_set(VI_MIPI_CSI0_DIV, 12); /* Input frquency: 2376MHZ */
ap_multimedia_div_num_set(VI_ISP0_CORE_DIV, 15); /* Input frquency: 2376MHZ */
ap_multimedia_div_num_set(VI_ISP1_CORE_DIV, 12); /* Input frquency: 2376MHZ */
diff --git a/board/thead/light-c910/light.c b/board/thead/light-c910/light.c
index 1fa88a89..2ce5b5f4 100644
--- a/board/thead/light-c910/light.c
+++ b/board/thead/light-c910/light.c
@@ -2048,6 +2048,205 @@ static void light_iopin_init(void)
}
+#elif defined (CONFIG_TARGET_LIGHT_FM_C910_MILKV_MELES)
+static void light_iopin_init(void)
+{
+ /* aon-padmux config */
+ light_pin_cfg(I2C_AON_SCL,PIN_SPEED_NORMAL,PIN_PN,8);
+ light_pin_cfg(I2C_AON_SDA,PIN_SPEED_NORMAL,PIN_PN,8);
+ light_pin_cfg(AOGPIO_7,PIN_SPEED_NORMAL,PIN_PN,2); ///NC
+ light_pin_cfg(AOGPIO_8,PIN_SPEED_NORMAL,PIN_PN,2); ///NC
+ light_pin_cfg(AOGPIO_9,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(AOGPIO_10,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(AOGPIO_11,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(AOGPIO_14,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(AOGPIO_15,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_mux(AOGPIO_7,3);
+ light_pin_mux(AOGPIO_8,3);
+ light_pin_mux(AOGPIO_9,3);
+ light_pin_mux(AOGPIO_10,3);
+ light_pin_mux(AOGPIO_11,0);
+ light_pin_mux(AOGPIO_12,1);
+ light_pin_mux(AOGPIO_13,1);
+ light_pin_mux(AOGPIO_14,0);
+ light_pin_mux(AOGPIO_15,0);
+
+ light_pin_mux(AUDIO_PA9,3); ///AUDIO-PA-RESET
+ light_pin_cfg(AUDIO_PA9,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_mux(AUDIO_PA10,3); /// AUD-3V3-EN
+ light_pin_cfg(AUDIO_PA10,PIN_SPEED_NORMAL,PIN_PU,2);
+ light_pin_mux(AUDIO_PA12,3); /// AUD-1V8-EN
+ light_pin_cfg(AUDIO_PA12,PIN_SPEED_NORMAL,PIN_PU,2);
+ light_pin_mux(AUDIO_PA13,0);
+
+ /*ap-padmux on left/top */
+ light_pin_mux(QSPI1_CSN0,3);
+ light_pin_mux(QSPI1_D2_WP,1);
+ light_pin_cfg(QSPI1_CSN0,PIN_SPEED_NORMAL,PIN_PN,8); ///se-spi
+ light_pin_cfg(QSPI1_SCLK,PIN_SPEED_NORMAL,PIN_PN,8); ///se-spi
+ light_pin_cfg(QSPI1_D0_MOSI,PIN_SPEED_NORMAL,PIN_PU,8); ///se-spi
+ light_pin_cfg(QSPI1_D1_MISO,PIN_SPEED_NORMAL,PIN_PU,8); ///se-spi
+ light_pin_cfg(QSPI1_D2_WP,PIN_SPEED_NORMAL,PIN_PN,0xF); ///PWM5
+ light_pin_cfg(QSPI1_D3_HOLD,PIN_SPEED_NORMAL,PIN_PN,8); ///NC
+
+ light_pin_mux(I2C0_SCL,3);
+ light_pin_mux(I2C0_SDA,3);
+
+ light_pin_cfg(I2C0_SCL,PIN_SPEED_NORMAL,PIN_PU,4);
+ light_pin_cfg(I2C0_SDA,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(I2C1_SCL,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(I2C1_SDA,PIN_SPEED_NORMAL,PIN_PN,4);
+
+ light_pin_mux(UART3_TXD,1);
+ light_pin_mux(UART3_RXD,1);
+ light_pin_cfg(UART3_TXD,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(UART3_RXD,PIN_SPEED_NORMAL,PIN_PN,2);
+
+ light_pin_mux(GPIO0_18,1);
+ light_pin_mux(GPIO0_19,1);
+ light_pin_cfg(GPIO0_18,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(GPIO0_19,PIN_SPEED_NORMAL,PIN_PN,4);
+
+ light_pin_mux(GPIO0_20,0);
+ light_pin_mux(GPIO0_21,0);
+ light_pin_mux(GPIO0_22,1);
+ light_pin_mux(GPIO0_23,1);
+ light_pin_mux(GPIO0_24,1);
+ light_pin_mux(GPIO0_25,1);
+ light_pin_mux(GPIO0_26,1);
+ light_pin_mux(GPIO0_27,0);
+ light_pin_mux(GPIO0_28,0);
+ light_pin_mux(GPIO0_29,0);
+ light_pin_mux(GPIO0_30,0);
+ light_pin_cfg(GPIO0_20,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO0_21,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO0_27,PIN_SPEED_NORMAL,PIN_PN,2); ///< NC(not used)
+ light_pin_cfg(GPIO0_28,PIN_SPEED_NORMAL,PIN_PN,2); ///< AVDD25_IR_EN
+ light_pin_cfg(GPIO0_29,PIN_SPEED_NORMAL,PIN_PN,2); ///< DVDD12_IR_EN
+ light_pin_cfg(GPIO0_30,PIN_SPEED_NORMAL,PIN_PU,2); ///< gmac,uart,led
+
+ light_pin_mux(GPIO1_0,1);
+ light_pin_mux(GPIO1_1,1);
+ light_pin_mux(GPIO1_2,1);
+ light_pin_mux(GPIO1_3,1);
+ light_pin_mux(GPIO1_4,1);
+ light_pin_mux(GPIO1_9,0);
+ light_pin_mux(GPIO1_10,0);
+ light_pin_mux(GPIO1_11,0);
+ light_pin_mux(GPIO1_12,0);
+ light_pin_mux(GPIO1_13,0);
+ light_pin_mux(GPIO1_14,0);
+ light_pin_mux(GPIO1_15,0);
+ light_pin_mux(GPIO1_16,0);
+ light_pin_mux(GPIO1_21,3);
+ light_pin_mux(GPIO1_22,3);
+ light_pin_mux(GPIO1_23,3);
+ light_pin_mux(GPIO1_24,3);
+ light_pin_mux(GPIO1_25,3);
+ light_pin_cfg(GPIO1_0,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_1,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_2,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_3,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_4,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_9,PIN_SPEED_NORMAL,PIN_PN,2); ///<VDD18_LCD0_EN
+ light_pin_cfg(GPIO1_10,PIN_SPEED_NORMAL,PIN_PN,2); ///<LCD0_BIAS_EN
+ light_pin_cfg(GPIO1_11,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_12,PIN_SPEED_NORMAL,PIN_PN,2); ///<TOUCH-PANNEL VDD28_TP0_EN
+ light_pin_cfg(GPIO1_13,PIN_SPEED_NORMAL,PIN_PN,2); ///<DOVDD18_RGB_EN
+ light_pin_cfg(GPIO1_14,PIN_SPEED_NORMAL,PIN_PN,2); ///<DVDD12_RGB_EN
+ light_pin_cfg(GPIO1_15,PIN_SPEED_NORMAL,PIN_PN,2); ///<AVDD28_RGB_EN
+ light_pin_cfg(GPIO1_16,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_21,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_22,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_23,PIN_SPEED_NORMAL,PIN_PN,2); ///<LED_PDN
+ light_pin_cfg(GPIO1_24,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_25,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO1_26,PIN_SPEED_NORMAL,PIN_PN,2); ///<DBB2LEDDRIVER_EN
+
+ light_pin_mux(CLK_OUT_0,1);
+ light_pin_mux(CLK_OUT_1,1);
+ light_pin_mux(CLK_OUT_3,1);
+ light_pin_mux(CLK_OUT_2,3);
+ light_pin_cfg(CLK_OUT_2,PIN_SPEED_NORMAL,PIN_PU,2); ///volume key "-"
+
+ /*ap-pdmux on righ/top*/
+ light_pin_mux(QSPI0_SCLK,3); ///NC
+ light_pin_mux(QSPI0_CSN0,3); ///NC
+ light_pin_mux(QSPI0_CSN1,3); ///NC
+ light_pin_mux(QSPI0_D0_MOSI,3); ///NC
+ light_pin_mux(QSPI0_D1_MISO,3); ///NC
+ light_pin_mux(QSPI0_D2_WP,3); ///NC
+ light_pin_mux(QSPI0_D3_HOLD,3); ///NC
+
+ light_pin_cfg(I2C2_SCL,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(I2C2_SDA,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(I2C3_SCL,PIN_SPEED_NORMAL,PIN_PN,4);
+ light_pin_cfg(I2C3_SDA,PIN_SPEED_NORMAL,PIN_PN,4);
+
+ light_pin_mux(SPI_CSN,3); /// W_DISABLE_CATE1
+ light_pin_mux(SPI_MOSI,3); /// NC
+ light_pin_mux(SPI_MISO,3); /// RERST1_N_CAT1
+ light_pin_mux(SPI_SCLK,3);
+ light_pin_cfg(SPI_SCLK,PIN_SPEED_NORMAL,PIN_PN,2); /// NC
+
+ light_pin_mux(GPIO2_18,0);
+ light_pin_mux(GPIO2_19,0);
+ light_pin_mux(GPIO2_20,0);
+ light_pin_mux(GPIO2_21,0);
+ light_pin_mux(GPIO2_22,0);
+ light_pin_mux(GPIO2_23,0);
+ light_pin_mux(GPIO2_24,0);
+ light_pin_mux(GPIO2_25,0);
+
+ light_pin_cfg(GPIO2_18,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO2_19,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO2_20,PIN_SPEED_NORMAL,PIN_PN,2);
+ light_pin_cfg(GPIO2_21,PIN_SPEED_NORMAL,PIN_PN,2); ///<NC
+ light_pin_cfg(GPIO2_22,PIN_SPEED_NORMAL,PIN_PN,2); ///<WIFI_BT_GPIO2
+ light_pin_cfg(GPIO2_23,PIN_SPEED_NORMAL,PIN_PN,2); ///<WIFI_BT_GPIO3
+ light_pin_cfg(GPIO2_24,PIN_SPEED_NORMAL,PIN_PN,2); ///<WIFI_BT_RST_N
+ light_pin_cfg(GPIO2_25,PIN_SPEED_NORMAL,PIN_PU,2); ///KEY1
+
+ light_pin_mux(SDIO0_WPRTN,3);
+ light_pin_cfg(SDIO0_WPRTN,PIN_SPEED_NORMAL,PIN_PN,2); ///< NC
+ light_pin_mux(SDIO1_WPRTN,3);
+ light_pin_cfg(SDIO1_WPRTN,PIN_SPEED_NORMAL,PIN_PU,2); ///VBUS_EN
+ light_pin_mux(SDIO1_DETN,3);
+ light_pin_cfg(SDIO1_DETN,PIN_SPEED_NORMAL,PIN_PN,2); ///WCN_33_EN
+
+ light_pin_mux(GPIO2_30,0);
+ light_pin_mux(GPIO2_31,0);
+ light_pin_mux(GPIO3_0,0);
+ light_pin_mux(GPIO3_1,0);
+ light_pin_mux(GPIO3_2,1);
+ light_pin_mux(GPIO3_3,0);
+ light_pin_cfg(GPIO2_30, PIN_SPEED_NORMAL, PIN_PN, 0x2); ///NC
+ light_pin_cfg(GPIO2_31, PIN_SPEED_NORMAL, PIN_PN, 0x2); ///NC
+ light_pin_cfg(GPIO3_0, PIN_SPEED_NORMAL, PIN_PN, 0x2); ///NC
+ light_pin_cfg(GPIO3_1, PIN_SPEED_NORMAL, PIN_PN, 0x2);
+ light_pin_cfg(GPIO3_2, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GPIO3_3, PIN_SPEED_NORMAL, PIN_PN, 0x2);
+
+ light_pin_mux(GMAC0_COL,3);
+ light_pin_mux(GMAC0_CRS,3);
+ light_pin_cfg(GMAC0_COL,PIN_SPEED_NORMAL,PIN_PU,2);
+ light_pin_cfg(GMAC0_CRS,PIN_SPEED_NORMAL,PIN_PU,2);
+
+ /* GMAC0 pad drive strength configurate to 0xF */
+ light_pin_cfg(GMAC0_TX_CLK, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RX_CLK, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_TXEN, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_TXD0, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_TXD1, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_TXD2, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_TXD3, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RXDV, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RXD0, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RXD1, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RXD2, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+ light_pin_cfg(GMAC0_RXD3, PIN_SPEED_NORMAL, PIN_PN, 0xF);
+}
+
#else
static void light_iopin_init(void)
{
diff --git a/board/thead/light-c910/lpddr-regu/ddr_regu.c b/board/thead/light-c910/lpddr-regu/ddr_regu.c
index 72d1f815..1f5a8b6a 100644
--- a/board/thead/light-c910/lpddr-regu/ddr_regu.c
+++ b/board/thead/light-c910/lpddr-regu/ddr_regu.c
@@ -136,7 +136,7 @@ static const struct regulator_t g_apcpu_regu_id_list[] = {
REGU_ID_DEF(IIC_IDX_AONIIC,APCPU_REGU_VDDM,0x31,0x39,0,1,800000,600000,3500000,12500,1),
},
};
-#elif defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_A_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A)
+#elif defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_A_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF) || (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A) || defined (CONFIG_TARGET_LIGHT_FM_C910_MILKV_MELES)
/**
* board for ant-ref
*
@@ -955,7 +955,7 @@ int pmic_reset_apcpu_voltage(void)
return ret;
return 0;
}
-#elif defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_A_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF)|| (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A)
+#elif defined (CONFIG_TARGET_LIGHT_FM_C910_VAL_ANT_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_A_REF) || defined (CONFIG_TARGET_LIGHT_FM_C910_B_REF)|| (CONFIG_TARGET_LIGHT_FM_C910_BEAGLE) || defined (CONFIG_TARGET_LIGHT_FM_C910_LPI4A) || defined (CONFIG_TARGET_LIGHT_FM_C910_MILKV_MELES)
int pmic_reset_apcpu_voltage(void)
{
int ret = -1;