summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhilip Molloy <[email protected]>2026-04-01 09:31:56 +0000
committerTom Rini <[email protected]>2026-04-22 14:22:33 -0600
commit1994e69d4e5b8b8bb01436b6b8e7ddf42d8e4785 (patch)
tree60556bc4d510dfa1f53d0fc2f9c07f646d5f3308
parent58e523fedf48a304b54c4e42e46fd88d072f8751 (diff)
board: adi: Fix exception when using standalone SoM
Although less common, ADSP SoM boards can be operated standalone without a carrier board. The SoM can be powered over USB-C by moving the jumper on JP1. The board configuration needs to be heavily refactored to reduce the number of defconfigs and leverage the devicetree. The TI DP83867 support, which is dependent on that configuration, needs to be removed. Until then this change allows the same U-Boot binary to work correctly both with carrier boards and the standalone SoM. The carrier board initialization code in somcrr_ezkit.c and somcrr_ezlite.c calls gpio_hog_lookup_name() to find ethernet control GPIOs, but does not check if the lookup succeeds before using the returned pointers. When running on a standalone SoM without a carrier board, these GPIO hogs do not exist in the device tree. The gpio_hog_lookup_name() function returns -ENODEV and sets the pointer to NULL, but the code continues to call dm_gpio_set_value() with uninitialized pointers, causing a synchronous abort exception: "Synchronous Abort" handler, esr 0x96000004 elr: 00000000960326c4 lr : 0000000096038d5c (reloc) Signed-off-by: Philip Molloy <[email protected]> Reviewed-by: Greg Malysa <[email protected]>
-rw-r--r--board/adi/carriers/somcrr_ezkit.c26
-rw-r--r--board/adi/carriers/somcrr_ezlite.c8
2 files changed, 16 insertions, 18 deletions
diff --git a/board/adi/carriers/somcrr_ezkit.c b/board/adi/carriers/somcrr_ezkit.c
index 8b4d6a96c18..3cd5a6cd10b 100644
--- a/board/adi/carriers/somcrr_ezkit.c
+++ b/board/adi/carriers/somcrr_ezkit.c
@@ -13,13 +13,12 @@ void adi_somcrr_enable_ethernet(void)
struct gpio_desc *eth1_reset;
struct gpio_desc *gige_reset;
- gpio_hog_lookup_name("eth1-en", &eth1);
- gpio_hog_lookup_name("eth1-reset", &eth1_reset);
- gpio_hog_lookup_name("gige-reset", &gige_reset);
-
- dm_gpio_set_value(eth1, 1);
- dm_gpio_set_value(eth1_reset, 0);
- dm_gpio_set_value(gige_reset, 0);
+ if (!gpio_hog_lookup_name("eth1-en", &eth1))
+ dm_gpio_set_value(eth1, 1);
+ if (!gpio_hog_lookup_name("eth1-reset", &eth1_reset))
+ dm_gpio_set_value(eth1_reset, 0);
+ if (!gpio_hog_lookup_name("gige-reset", &gige_reset))
+ dm_gpio_set_value(gige_reset, 0);
}
void adi_somcrr_disable_ethernet(void)
@@ -28,11 +27,10 @@ void adi_somcrr_disable_ethernet(void)
struct gpio_desc *eth1_reset;
struct gpio_desc *gige_reset;
- gpio_hog_lookup_name("eth1-en", &eth1);
- gpio_hog_lookup_name("eth1-reset", &eth1_reset);
- gpio_hog_lookup_name("gige-reset", &gige_reset);
-
- dm_gpio_set_value(eth1, 0);
- dm_gpio_set_value(eth1_reset, 1);
- dm_gpio_set_value(gige_reset, 1);
+ if (!gpio_hog_lookup_name("eth1-en", &eth1))
+ dm_gpio_set_value(eth1, 0);
+ if (!gpio_hog_lookup_name("eth1-reset", &eth1_reset))
+ dm_gpio_set_value(eth1_reset, 1);
+ if (!gpio_hog_lookup_name("gige-reset", &gige_reset))
+ dm_gpio_set_value(gige_reset, 1);
}
diff --git a/board/adi/carriers/somcrr_ezlite.c b/board/adi/carriers/somcrr_ezlite.c
index c0655574bab..1f1984cf912 100644
--- a/board/adi/carriers/somcrr_ezlite.c
+++ b/board/adi/carriers/somcrr_ezlite.c
@@ -11,14 +11,14 @@ void adi_somcrr_enable_ethernet(void)
{
struct gpio_desc *gige_reset;
- gpio_hog_lookup_name("eth0-reset", &gige_reset);
- dm_gpio_set_value(gige_reset, 0);
+ if (!gpio_hog_lookup_name("eth0-reset", &gige_reset))
+ dm_gpio_set_value(gige_reset, 0);
}
void adi_somcrr_disable_ethernet(void)
{
struct gpio_desc *gige_reset;
- gpio_hog_lookup_name("eth0-reset", &gige_reset);
- dm_gpio_set_value(gige_reset, 1);
+ if (!gpio_hog_lookup_name("eth0-reset", &gige_reset))
+ dm_gpio_set_value(gige_reset, 1);
}