From: Rafal Czubak Date: Wed, 8 Oct 2008 11:41:30 +0000 (+0200) Subject: FSL: Fix get_cpu_board_revision() return value. X-Git-Tag: v2025.01-rc5-pxa1908~21786^2~33^2~1^2~1^2~2 X-Git-Url: http://git.dujemihanovic.xyz/?a=commitdiff_plain;h=e46c7bfb8bc3c304cedd20f7a365d6e78d7eaf17;p=u-boot.git FSL: Fix get_cpu_board_revision() return value. get_cpu_board_revision() returned board revision based on information stored in global static struct eeprom. It should instead use one from local struct board_eeprom, to which the data is actually read from EEPROM. The bug led to system hang after printing L1 cache information on U-Boot startup. The problem was observed on MPC8555CDS system and possibly affects other Freescale MPC85xx boards using CFG_I2C_EEPROM_CCID. The change has been successfully tested on MPC8555CDS system. Signed-off-by: Rafal Czubak --- diff --git a/board/freescale/common/sys_eeprom.c b/board/freescale/common/sys_eeprom.c index e53ead04fd..9bef92e815 100644 --- a/board/freescale/common/sys_eeprom.c +++ b/board/freescale/common/sys_eeprom.c @@ -463,6 +463,6 @@ unsigned int get_cpu_board_revision(void) if ((be.major == 0xff) && (be.minor == 0xff)) return MPC85XX_CPU_BOARD_REV(0, 0); - return MPC85XX_CPU_BOARD_REV(e.major, e.minor); + return MPC85XX_CPU_BOARD_REV(be.major, be.minor); } #endif