Skip to content
Snippets Groups Projects
board.c 31.5 KiB
Newer Older
  • Learn to ignore specific revisions
  • Wolfgang Denk's avatar
    Wolfgang Denk committed
    	/* Initialize devices */
    	devices_init ();
    
    
    	/* Initialize the jump table for applications */
    	jumptable_init ();
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    
    
    #if defined(CONFIG_API)
    	/* Initialize API */
    	api_init ();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	/* Initialize the console (after the relocation and devices init) */
    	console_init_r ();
    
    #if defined(CONFIG_CCM)		|| \
        defined(CONFIG_COGENT)	|| \
        defined(CONFIG_CPCI405)	|| \
        defined(CONFIG_EVB64260)	|| \
    
        defined(CONFIG_KUP4X)	|| \
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
        defined(CONFIG_LWMON)	|| \
        defined(CONFIG_PCU_E)	|| \
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
        defined(CONFIG_W7O)		|| \
        defined(CONFIG_MISC_INIT_R)
    	/* miscellaneous platform dependent initialisations */
    	misc_init_r ();
    #endif
    
    #ifdef	CONFIG_HERMES
    	if (bd->bi_ethspeed != 0xFFFF)
    		hermes_start_lxt980 ((int) bd->bi_ethspeed);
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	puts ("KGDB:  ");
    	kgdb_init ();
    #endif
    
    
    	debug ("U-Boot relocated to %08lx\n", dest_addr);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    
    	/*
    	 * Enable Interrupts
    	 */
    	interrupt_init ();
    
    	/* Must happen after interrupts are initialized since
    	 * an irq handler gets installed
    	 */
    
    #ifdef CONFIG_SERIAL_SOFTWARE_FIFO
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	serial_buffered_init();
    #endif
    
    
    #if defined(CONFIG_STATUS_LED) && defined(STATUS_LED_BOOT)
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	status_led_set (STATUS_LED_BOOT, STATUS_LED_BLINKING);
    #endif
    
    	udelay (20);
    
    	set_timer (0);
    
    	/* Initialize from environment */
    	if ((s = getenv ("loadaddr")) != NULL) {
    		load_addr = simple_strtoul (s, NULL, 16);
    	}
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	if ((s = getenv ("bootfile")) != NULL) {
    		copy_filename (BootFile, s, sizeof (BootFile));
    	}
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    
    	WATCHDOG_RESET ();
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	puts ("SCSI:  ");
    	scsi_init ();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	puts ("DOC:   ");
    	doc_init ();
    #endif
    
    
    #if defined(CONFIG_NET_MULTI)
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	puts ("Net:   ");
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	eth_initialize (bd);
    #endif
    
    
        defined(CONFIG_CCM)		|| \
        defined(CONFIG_ELPT860)	|| \
        defined(CONFIG_EP8260)	|| \
        defined(CONFIG_IP860)	|| \
        defined(CONFIG_IVML24)	|| \
        defined(CONFIG_IVMS8)	|| \
        defined(CONFIG_MPC8260ADS)	|| \
        defined(CONFIG_MPC8266ADS)	|| \
        defined(CONFIG_MPC8560ADS)	|| \
        defined(CONFIG_PCU_E)	|| \
        defined(CONFIG_RPXSUPER)	|| \
        defined(CONFIG_STXGP3)	|| \
        defined(CONFIG_SPD823TS)	|| \
        defined(CONFIG_RESET_PHY_R)	)
    
    	WATCHDOG_RESET ();
    	debug ("Reset Ethernet PHY\n");
    	reset_phy ();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #ifdef CONFIG_POST
    
    	post_run (NULL, POST_RAM | post_bootmode_get(0));
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #endif
    
    
    #if defined(CONFIG_CMD_PCMCIA) \
        && !defined(CONFIG_CMD_IDE)
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	puts ("PCMCIA:");
    	pcmcia_init ();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    # ifdef	CONFIG_IDE_8xx_PCCARD
    	puts ("PCMCIA:");
    # else
    	puts ("IDE:   ");
    #endif
    
    #if defined(CONFIG_START_IDE)
    	if (board_start_ide())
    		ide_init ();
    #else
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	ide_init ();
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    
    #ifdef CONFIG_LAST_STAGE_INIT
    	WATCHDOG_RESET ();
    	/*
    	 * Some parts can be only initialized if all others (like
    	 * Interrupts) are up and running (i.e. the PC-style ISA
    	 * keyboard).
    	 */
    	last_stage_init ();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	WATCHDOG_RESET ();
    	bedbug_init ();
    #endif
    
    
    #if defined(CONFIG_PRAM) || defined(CONFIG_LOGBUFFER)
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	/*
    	 * Export available size of memory for Linux,
    	 * taking into account the protected RAM at top of memory
    	 */
    	{
    		ulong pram;
    		uchar memsz[32];
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    
    		if ((s = getenv ("pram")) != NULL) {
    			pram = simple_strtoul (s, NULL, 10);
    		} else {
    			pram = CONFIG_PRAM;
    		}
    
    		/* Also take the logbuffer into account (pram is in kB) */
    		pram += (LOGBUFF_LEN+LOGBUFF_OVERHEAD)/1024;
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    		sprintf ((char *)memsz, "%ldk", (bd->bi_memsize / 1024) - pram);
    		setenv ("mem", (char *)memsz);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	}
    #endif
    
    
    #ifdef CONFIG_PS2KBD
    	puts ("PS/2:  ");
    	kbd_init();
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #ifdef CONFIG_MODEM_SUPPORT
     {
    	 extern int do_mdm_init;
    	 do_mdm_init = gd->do_mdm_init;
     }
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	/* Initialization complete - start the monitor */
    
    	/* main_loop() can return to retry autoboot, if so just run it again. */
    	for (;;) {
    		WATCHDOG_RESET ();
    		main_loop ();
    	}
    
    	/* NOTREACHED - no way out of command loop except booting */
    }
    
    void hang (void)
    {
    	puts ("### ERROR ### Please RESET the board ###\n");
    
    	show_boot_progress(-30);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    	for (;;);
    }
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #ifdef CONFIG_MODEM_SUPPORT
    /* called from main loop (common/main.c) */
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    /* 'inline' - We have to do it fast */
    static inline void mdm_readline(char *buf, int bufsiz)
    {
    	char c;
    	char *p;
    	int n;
    
    	n = 0;
    	p = buf;
    	for(;;) {
    		c = serial_getc();
    
    		/*		dbg("(%c)", c); */
    
    		switch(c) {
    		case '\r':
    			break;
    		case '\n':
    			*p = '\0';
    			return;
    
    		default:
    			if(n++ > bufsiz) {
    				*p = '\0';
    				return; /* sanity check */
    			}
    			*p = c;
    			p++;
    			break;
    		}
    	}
    }
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    extern void  dbg(const char *fmt, ...);
    int mdm_init (void)
    {
    	char env_str[16];
    	char *init_str;
    	int i;
    	extern char console_buffer[];
    	extern void enable_putc(void);
    	extern int hwflow_onoff(int);
    
    	enable_putc(); /* enable serial_putc() */
    
    #ifdef CONFIG_HWFLOW
    	init_str = getenv("mdm_flow_control");
    	if (init_str && (strcmp(init_str, "rts/cts") == 0))
    		hwflow_onoff (1);
    	else
    		hwflow_onoff(-1);
    #endif
    
    	for (i = 1;;i++) {
    		sprintf(env_str, "mdm_init%d", i);
    		if ((init_str = getenv(env_str)) != NULL) {
    			serial_puts(init_str);
    			serial_puts("\n");
    			for(;;) {
    
    				mdm_readline(console_buffer, CONFIG_SYS_CBSIZE);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    				dbg("ini%d: [%s]", i, console_buffer);
    
    				if ((strcmp(console_buffer, "OK") == 0) ||
    					(strcmp(console_buffer, "ERROR") == 0)) {
    					dbg("ini%d: cmd done", i);
    					break;
    				} else /* in case we are originating call ... */
    					if (strncmp(console_buffer, "CONNECT", 7) == 0) {
    						dbg("ini%d: connect", i);
    						return 0;
    					}
    			}
    		} else
    			break; /* no init string - stop modem init */
    
    		udelay(100000);
    	}
    
    	udelay(100000);
    
    	/* final stage - wait for connect */
    	for(;i > 1;) { /* if 'i' > 1 - wait for connection
    				  message from modem */
    
    		mdm_readline(console_buffer, CONFIG_SYS_CBSIZE);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    		dbg("ini_f: [%s]", console_buffer);
    		if (strncmp(console_buffer, "CONNECT", 7) == 0) {
    			dbg("ini_f: connected");
    			return 0;
    		}
    	}
    
    	return 0;
    }
    
    #endif
    
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #if 0 /* We could use plain global data, but the resulting code is bigger */
    /*
     * Pointer to initial global data area
     *
     * Here we initialize it.
     */
    #undef	XTRN_DECLARE_GLOBAL_DATA_PTR
    #define XTRN_DECLARE_GLOBAL_DATA_PTR	/* empty = allocate here */
    
    DECLARE_GLOBAL_DATA_PTR = (gd_t *) (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_GBL_DATA_OFFSET);
    
    Wolfgang Denk's avatar
    Wolfgang Denk committed
    #endif  /* 0 */
    
    /************************************************************************/