summaryrefslogtreecommitdiff
path: root/board/dhelectronics/common/dh_common.c
diff options
context:
space:
mode:
authorTom Rini <trini@konsulko.com>2025-09-17 09:06:53 -0600
committerTom Rini <trini@konsulko.com>2025-09-17 09:06:53 -0600
commitf28891d444631c91a6e090927486a2169b51b20f (patch)
tree675519131a778ab5ec57166cf56b18d043e4f41e /board/dhelectronics/common/dh_common.c
parenteea731b50c6155b9ec0ccd039590b9cefdafd024 (diff)
parent7cd9d2db2627ce65d3c03e4422607b7a86093e8a (diff)
Merge patch series "board: dhelectronics: Check pointer before access in dh_get_value_from_eeprom_buffer()"HEADmaster
This series from Marek Vasut <marek.vasut@mailbox.org> cleans up some of the common code between dhelectronics platforms. Link: https://lore.kernel.org/r/20250907010103.667681-1-marek.vasut@mailbox.org
Diffstat (limited to 'board/dhelectronics/common/dh_common.c')
-rw-r--r--board/dhelectronics/common/dh_common.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/board/dhelectronics/common/dh_common.c b/board/dhelectronics/common/dh_common.c
index 8c052c45007..6101ecc7ebc 100644
--- a/board/dhelectronics/common/dh_common.c
+++ b/board/dhelectronics/common/dh_common.c
@@ -88,9 +88,9 @@ int dh_read_eeprom_id_page(u8 *eeprom_buffer, const char *alias)
/* Validate header ID */
if (eip->hdr.id[0] != 'D' || eip->hdr.id[1] != 'H' || eip->hdr.id[2] != 'E') {
printf("%s: Error validating header ID! (got %c%c%c (0x%02x 0x%02x 0x%02x) != expected DHE)\n",
- __func__, isprint(eip->hdr.id[0]) ? eip->hdr.id[0] : '.',
- isprint(eip->hdr.id[1]) ? eip->hdr.id[1] : '.',
- isprint(eip->hdr.id[2]) ? eip->hdr.id[2] : '.',
+ __func__, (isascii(eip->hdr.id[0]) && isprint(eip->hdr.id[0])) ? eip->hdr.id[0] : '.',
+ (isascii(eip->hdr.id[1]) && isprint(eip->hdr.id[1])) ? eip->hdr.id[1] : '.',
+ (isascii(eip->hdr.id[2]) && isprint(eip->hdr.id[2])) ? eip->hdr.id[2] : '.',
eip->hdr.id[0], eip->hdr.id[1], eip->hdr.id[2]);
return -EINVAL;
}
@@ -131,14 +131,17 @@ int dh_read_eeprom_id_page(u8 *eeprom_buffer, const char *alias)
int dh_get_value_from_eeprom_buffer(enum eip_request_values request, u8 *data, int data_len,
struct eeprom_id_page *eip)
{
- const char fin_chr = (eip->pl.item_prefix & DH_ITEM_PREFIX_FIN_BIT) ?
- DH_ITEM_PREFIX_FIN_FLASHED_CHR : DH_ITEM_PREFIX_FIN_HALF_CHR;
- const u8 soc_coded = eip->pl.item_prefix & 0xf;
+ char fin_chr;
+ u8 soc_coded;
char soc_chr;
if (!eip)
return -EINVAL;
+ fin_chr = (eip->pl.item_prefix & DH_ITEM_PREFIX_FIN_BIT) ?
+ DH_ITEM_PREFIX_FIN_FLASHED_CHR : DH_ITEM_PREFIX_FIN_HALF_CHR;
+ soc_coded = eip->pl.item_prefix & 0xf;
+
/* Copy requested data */
switch (request) {
case DH_MAC0: