mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-31 12:08:19 +00:00 
			
		
		
		
	Rather than calling do_source directly (which is not officially exported from cmd_source.c) call 'source' which is exported and requires a little less code to do so as well. Signed-off-by: Tom Rini <trini@ti.com>
		
			
				
	
	
		
			108 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2005-2008
 | |
|  * Matthias Fuchs, esd GmbH Germany, matthias.fuchs@esd-electronics.com
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <command.h>
 | |
| #if !defined(CONFIG_440)
 | |
| #include <asm/4xx_pci.h>
 | |
| #endif
 | |
| 
 | |
| #if defined(CONFIG_CMD_BSP)
 | |
| #define ADDRMASK 0xfffff000
 | |
| 
 | |
| /*
 | |
|  * Command loadpci: wait for signal from host and boot image.
 | |
|  */
 | |
| int do_loadpci(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
 | |
| {
 | |
| 	u32 *ptr = 0;
 | |
| 	int count = 0;
 | |
| 	int count2 = 0;
 | |
| 	char addr[16];
 | |
| 	char str[] = "\\|/-";
 | |
| 	u32 la, ptm1la;
 | |
| 
 | |
| #if defined(CONFIG_440)
 | |
| 	ptm1la = in32r(PCIL0_PTM1LA);
 | |
| #else
 | |
| 	ptm1la = in32r(PTM1LA);
 | |
| #endif
 | |
| 	while(1) {
 | |
| 		/*
 | |
| 		 * Mark sync address
 | |
| 		 */
 | |
| 		ptr = (u32 *)ptm1la;
 | |
| 		memset(ptr, 0, 0x20);
 | |
| 
 | |
| 		*ptr = 0xffffffff;
 | |
| 		puts("\nWaiting for action from pci host -");
 | |
| 
 | |
| 		/*
 | |
| 		 * Wait for host to write the start address
 | |
| 		 */
 | |
| 		while (*ptr == 0xffffffff) {
 | |
| 			count++;
 | |
| 			if (!(count % 100)) {
 | |
| 				count2++;
 | |
| 				putc(0x08); /* backspace */
 | |
| 				putc(str[count2 % 4]);
 | |
| 			}
 | |
| 
 | |
| 			/* Abort if ctrl-c was pressed */
 | |
| 			if (ctrlc()) {
 | |
| 				puts("\nAbort\n");
 | |
| 				return 0;
 | |
| 			}
 | |
| 
 | |
| 			udelay(1000);
 | |
| 		}
 | |
| 
 | |
| 		printf("\nGot bootcode %08x: ", *ptr);
 | |
| 		la = ptm1la + (*ptr & ADDRMASK);
 | |
| 		sprintf(addr, "%08x", la);
 | |
| 
 | |
| 		switch (*ptr & ~ADDRMASK) {
 | |
| 		case 0:
 | |
| 			/*
 | |
| 			 * Boot image via bootm
 | |
| 			 */
 | |
| 			printf("booting image at addr 0x%s ...\n", addr);
 | |
| 			setenv("loadaddr", addr);
 | |
| 			do_bootm(cmdtp, 0, 0, NULL);
 | |
| 			break;
 | |
| 
 | |
| 		case 1:
 | |
| 			/*
 | |
| 			 * Boot image via "source" command
 | |
| 			 */
 | |
| 			printf("executing script at addr 0x%s ...\n", addr);
 | |
| 			source(la, NULL);
 | |
| 			break;
 | |
| 
 | |
| 		case 2:
 | |
| 			/*
 | |
| 			 * Call run_cmd
 | |
| 			 */
 | |
| 			printf("running command at addr 0x%s ...\n", addr);
 | |
| 			run_command((char *)la, 0);
 | |
| 			break;
 | |
| 
 | |
| 		default:
 | |
| 			printf("unhandled boot method\n");
 | |
| 			break;
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| U_BOOT_CMD(
 | |
| 	loadpci,	1,	1,	do_loadpci,
 | |
| 	"Wait for pci bootcmd and boot it",
 | |
| 	""
 | |
| );
 | |
| 
 | |
| #endif
 |