|
@@ -304,34 +304,14 @@ void board_init_r (gd_t *id, ulong dest_addr)
|
|
|
|
|
|
monitor_flash_len = (ulong)&uboot_end_data - dest_addr;
|
|
monitor_flash_len = (ulong)&uboot_end_data - dest_addr;
|
|
|
|
|
|
|
|
+#if !defined(CONFIG_RELOC_FIXUP_WORKS)
|
|
/*
|
|
/*
|
|
* We have to relocate the command table manually
|
|
* We have to relocate the command table manually
|
|
*/
|
|
*/
|
|
- for (cmdtp = &__u_boot_cmd_start; cmdtp != &__u_boot_cmd_end; cmdtp++) {
|
|
|
|
- ulong addr;
|
|
|
|
|
|
+ fixup_cmdtable(&__u_boot_cmd_start,
|
|
|
|
+ (ulong)(&__u_boot_cmd_end - &__u_boot_cmd_start));
|
|
|
|
+#endif /* !defined(CONFIG_RELOC_FIXUP_WORKS) */
|
|
|
|
|
|
- addr = (ulong) (cmdtp->cmd) + gd->reloc_off;
|
|
|
|
-#if 0
|
|
|
|
- printf ("Command \"%s\": 0x%08lx => 0x%08lx\n",
|
|
|
|
- cmdtp->name, (ulong) (cmdtp->cmd), addr);
|
|
|
|
-#endif
|
|
|
|
- cmdtp->cmd =
|
|
|
|
- (int (*)(struct cmd_tbl_s *, int, int, char *[]))addr;
|
|
|
|
-
|
|
|
|
- addr = (ulong)(cmdtp->name) + gd->reloc_off;
|
|
|
|
- cmdtp->name = (char *)addr;
|
|
|
|
-
|
|
|
|
- if (cmdtp->usage) {
|
|
|
|
- addr = (ulong)(cmdtp->usage) + gd->reloc_off;
|
|
|
|
- cmdtp->usage = (char *)addr;
|
|
|
|
- }
|
|
|
|
-#ifdef CONFIG_SYS_LONGHELP
|
|
|
|
- if (cmdtp->help) {
|
|
|
|
- addr = (ulong)(cmdtp->help) + gd->reloc_off;
|
|
|
|
- cmdtp->help = (char *)addr;
|
|
|
|
- }
|
|
|
|
-#endif
|
|
|
|
- }
|
|
|
|
/* there are some other pointer constants we must deal with */
|
|
/* there are some other pointer constants we must deal with */
|
|
#ifndef CONFIG_ENV_IS_NOWHERE
|
|
#ifndef CONFIG_ENV_IS_NOWHERE
|
|
env_name_spec += gd->reloc_off;
|
|
env_name_spec += gd->reloc_off;
|