mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-26 16:13:55 +01:00 
			
		
		
		
	relocation: fixup cmdtable
fixup_cmdtable() did all work for fixing up the cmdtable, if CONFIG_RELOC_FIXUP_WORKS is not defined. CONFIG_RELOC_FIXUP_WORKS is missing for i386! I talked with Graeme Russ, and he will fix this soon. Portions of this work were supported by funding from the CE Linux Forum. Signed-off-by: Heiko Schocher <hs@denx.de>
This commit is contained in:
		
				
					committed by
					
						 Wolfgang Denk
						Wolfgang Denk
					
				
			
			
				
	
			
			
			
						parent
						
							7e4a9e6dc8
						
					
				
				
					commit
					620f1f6a64
				
			| @@ -433,33 +433,14 @@ void board_init_r (gd_t *id, ulong dest_addr) | ||||
|  | ||||
| 	monitor_flash_len = (ulong)&__init_end - dest_addr; | ||||
|  | ||||
| #if !defined(CONFIG_RELOC_FIXUP_WORKS) | ||||
| 	/* | ||||
| 	 * We have to relocate the command table manually | ||||
| 	 */ | ||||
| 	for (cmdtp = &__u_boot_cmd_start; cmdtp !=  &__u_boot_cmd_end; cmdtp++) { | ||||
| 		ulong addr; | ||||
| 		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; | ||||
| 	fixup_cmdtable(&__u_boot_cmd_start, | ||||
| 		(ulong)(&__u_boot_cmd_end - &__u_boot_cmd_start)); | ||||
| #endif /* !defined(CONFIG_RELOC_FIXUP_WORKS) */ | ||||
|  | ||||
| 		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 */ | ||||
| #ifndef CONFIG_ENV_IS_NOWHERE | ||||
| 	env_name_spec += gd->reloc_off; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user