Re: [PATCH V2 08/12] board: ti: j721s2: Add board_init and support for selecting DT based on EEPROM

2022-12-23 Thread Tom Rini
On Wed, Dec 21, 2022 at 07:22:15PM +0530, Sinthu Raja wrote:

> From: Sinthu Raja 
> 
> Add the board_init_f API for SPL and run the platform-required SoC 
> initialization.
> 
> Add the functionality for board name-based DTB selection from FIT within SPL. 
> This
> will make it easier to utilise one defconfig for both the EVM and the SK.
> 
> Signed-off-by: Sinthu Raja 
[snip]
> +#ifdef CONFIG_SPL_OF_LIST
> +void do_dt_magic(void)
> +{
> +int ret, rescan, mmc_dev = -1;
> +static struct mmc *mmc;
> +
> +if (IS_ENABLED(CONFIG_TI_I2C_BOARD_DETECT))
> +do_board_detect();

I think we should rework this slightly for clarity about mini-U-Boot vs
EVM and family support to be:

/* Support for the various EVM / SK families */
#if defined(CONFIG_SPL_OF_LIST) && defined(CONFIG_TI_I2C_BOARD_DETECT)
void do_dt_magic(void)
{
...

Instead. Or does that not work because of how we handle the R5 support
here? If we so, then please just add the comment.

-- 
Tom


signature.asc
Description: PGP signature


[PATCH V2 08/12] board: ti: j721s2: Add board_init and support for selecting DT based on EEPROM

2022-12-21 Thread Sinthu Raja
From: Sinthu Raja 

Add the board_init_f API for SPL and run the platform-required SoC 
initialization.

Add the functionality for board name-based DTB selection from FIT within SPL. 
This
will make it easier to utilise one defconfig for both the EVM and the SK.

Signed-off-by: Sinthu Raja 
---

Changes in V2:
=
Address review comments:
- Move board_init and board detection API to board specific file.

 board/ti/j721s2/evm.c | 66 +++
 1 file changed, 66 insertions(+)

diff --git a/board/ti/j721s2/evm.c b/board/ti/j721s2/evm.c
index 7e448bd51c..7f0ad38b91 100644
--- a/board/ti/j721s2/evm.c
+++ b/board/ti/j721s2/evm.c
@@ -23,6 +23,7 @@
 #include 
 #include 
 #include 
+#include 
 
 #include "../common/board_detect.h"
 
@@ -202,3 +203,68 @@ int board_late_init(void)
 void spl_board_init(void)
 {
 }
+
+#ifdef CONFIG_SPL_OF_LIST
+void do_dt_magic(void)
+{
+int ret, rescan, mmc_dev = -1;
+static struct mmc *mmc;
+
+if (IS_ENABLED(CONFIG_TI_I2C_BOARD_DETECT))
+do_board_detect();
+
+/*
+ * Board detection has been done.
+ * Let us see if another dtb wouldn't be a better match
+ * for our board
+ */
+if (IS_ENABLED(CONFIG_CPU_V7R)) {
+ret = fdtdec_resetup(&rescan);
+if (!ret && rescan) {
+dm_uninit();
+dm_init_and_scan(true);
+}
+}
+
+/*
+ * Because of multi DTB configuration, the MMC device has
+ * to be re-initialized after reconfiguring FDT inorder to
+ * boot from MMC. Do this when boot mode is MMC and ROM has
+ * not loaded SYSFW.
+ */
+switch (spl_boot_device()) {
+case BOOT_DEVICE_MMC1:
+mmc_dev = 0;
+break;
+case BOOT_DEVICE_MMC2:
+case BOOT_DEVICE_MMC2_2:
+mmc_dev = 1;
+break;
+}
+
+if (mmc_dev > 0 && !check_rom_loaded_sysfw()) {
+ret = mmc_init_device(mmc_dev);
+if (!ret) {
+mmc = find_mmc_device(mmc_dev);
+if (mmc) {
+ret = mmc_init(mmc);
+if (ret) {
+printf("mmc init failed with error: 
%d\n", ret);
+}
+}
+}
+}
+}
+#endif
+
+#ifdef CONFIG_SPL_BUILD
+void board_init_f(ulong dummy)
+{
+   k3_spl_init();
+#ifdef CONFIG_SPL_OF_LIST
+   do_dt_magic();
+#endif
+   k3_mem_init();
+
+}
+#endif
-- 
2.36.1