diff options
author | Enric Balletbo i Serra <eballetbo@iseebcn.com> | 2010-10-19 11:13:22 +0200 |
---|---|---|
committer | Wolfgang Denk <wd@denx.de> | 2010-10-23 22:55:47 +0200 |
commit | cdb1d4f97e7e3599549852b89f2fd56cbf1e5322 (patch) | |
tree | 81a151813c598d605be6b3ddb2921b7792965e13 | |
parent | 116ef54d6804e3140ff4fc383ff8b6b7c7cf9f7b (diff) | |
download | bootable_bootloader_goldelico_gta04-cdb1d4f97e7e3599549852b89f2fd56cbf1e5322.zip bootable_bootloader_goldelico_gta04-cdb1d4f97e7e3599549852b89f2fd56cbf1e5322.tar.gz bootable_bootloader_goldelico_gta04-cdb1d4f97e7e3599549852b89f2fd56cbf1e5322.tar.bz2 |
ARM: fix relocation support for onenand device.
We also have to relocate the onenand command table manually, otherwise
onenand command don't work.
Signed-off-by: Enric Balletbo i Serra <eballetbo@iseebcn.com>
-rw-r--r-- | arch/arm/lib/board.c | 3 | ||||
-rw-r--r-- | common/cmd_onenand.c | 6 |
2 files changed, 9 insertions, 0 deletions
diff --git a/arch/arm/lib/board.c b/arch/arm/lib/board.c index ffe261b..af9a414 100644 --- a/arch/arm/lib/board.c +++ b/arch/arm/lib/board.c @@ -716,6 +716,9 @@ void board_init_r (gd_t *id, ulong dest_addr) #if defined(CONFIG_CMD_I2C) i2c_reloc(); #endif +#if defined(CONFIG_CMD_ONENAND) + onenand_reloc(); +#endif #endif /* !defined(CONFIG_RELOC_FIXUP_WORKS) */ #ifdef CONFIG_LOGBUFFER diff --git a/common/cmd_onenand.c b/common/cmd_onenand.c index 83d967b..fe84c3b 100644 --- a/common/cmd_onenand.c +++ b/common/cmd_onenand.c @@ -525,6 +525,12 @@ static cmd_tbl_t cmd_onenand_sub[] = { U_BOOT_CMD_MKENT(markbad, CONFIG_SYS_MAXARGS, 0, do_onenand_markbad, "", ""), }; +#ifndef CONFIG_RELOC_FIXUP_WORKS +void onenand_reloc(void) { + fixup_cmdtable(cmd_onenand_sub, ARRAY_SIZE(cmd_onenand_sub)); +} +#endif + static int do_onenand(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[]) { cmd_tbl_t *c; |