init.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:5k
- /*
- * Carsten Langgaard, carstenl@mips.com
- * Copyright (C) 1999,2000 MIPS Technologies, Inc. All rights reserved.
- *
- * This program is free software; you can distribute it and/or modify it
- * under the terms of the GNU General Public License (Version 2) as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
- * for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
- *
- * PROM library initialisation code.
- */
- #include <linux/config.h>
- #include <linux/init.h>
- #include <linux/string.h>
- #include <linux/kernel.h>
- #include <asm/io.h>
- #include <asm/mips-boards/prom.h>
- #include <asm/mips-boards/generic.h>
- #include <asm/gt64120.h>
- #include <asm/mips-boards/malta.h>
- #include <asm/mips-boards/msc01_pci.h>
- #include <asm/mips-boards/bonito64.h>
- /* Environment variable */
- typedef struct
- {
- char *name;
- char *val;
- } t_env_var;
- int prom_argc;
- int *_prom_argv, *_prom_envp;
- /*
- * YAMON (32-bit PROM) pass arguments and environment as 32-bit pointer.
- * This macro take care of sign extension, if running in 64-bit mode.
- */
- #define prom_envp(index) ((char *)(((int *)(int)_prom_envp)[(index)]))
- int init_debug = 0;
- unsigned int mips_revision_corid;
- char *prom_getenv(char *envname)
- {
- /*
- * Return a pointer to the given environment variable.
- * In 64-bit mode: we're using 64-bit pointers, but all pointers
- * in the PROM structures are only 32-bit, so we need some
- * workarounds, if we are running in 64-bit mode.
- */
- int i, index=0;
- i = strlen(envname);
- while(prom_envp(index)) {
- if(strncmp(envname, prom_envp(index), i) == 0) {
- return(prom_envp(index+1));
- }
- index += 2;
- }
- return(NULL);
- }
- static inline unsigned char str2hexnum(unsigned char c)
- {
- if(c >= '0' && c <= '9')
- return c - '0';
- if(c >= 'a' && c <= 'f')
- return c - 'a' + 10;
- return 0; /* foo */
- }
- static inline void str2eaddr(unsigned char *ea, unsigned char *str)
- {
- int i;
- for(i = 0; i < 6; i++) {
- unsigned char num;
- if((*str == '.') || (*str == ':'))
- str++;
- num = str2hexnum(*str++) << 4;
- num |= (str2hexnum(*str++));
- ea[i] = num;
- }
- }
- int get_ethernet_addr(char *ethernet_addr)
- {
- char *ethaddr_str;
- ethaddr_str = prom_getenv("ethaddr");
- if (!ethaddr_str) {
- printk("ethaddr not set in boot promn");
- return -1;
- }
- str2eaddr(ethernet_addr, ethaddr_str);
- if (init_debug > 1) {
- int i;
- printk("get_ethernet_addr: ");
- for (i=0; i<5; i++)
- printk("%02x:", (unsigned char)*(ethernet_addr+i));
- printk("%02xn", *(ethernet_addr+i));
- }
- return 0;
- }
- int __init prom_init(int argc, char **argv, char **envp)
- {
- prom_argc = argc;
- _prom_argv = (int *)argv;
- _prom_envp = (int *)envp;
- mips_display_message("LINUX");
- #ifdef CONFIG_MIPS_SEAD
- set_io_port_base(KSEG1);
- #else
- mips_revision_corid = MIPS_REVISION_CORID;
- switch(mips_revision_corid) {
- case MIPS_REVISION_CORID_QED_RM5261:
- case MIPS_REVISION_CORID_CORE_LV:
- case MIPS_REVISION_CORID_CORE_FPGA:
- /*
- * Setup the North bridge to do Master byte-lane swapping
- * when running in bigendian.
- */
- #if defined(__MIPSEL__)
- GT_WRITE(GT_PCI0_CMD_OFS, GT_PCI0_CMD_MBYTESWAP_BIT |
- GT_PCI0_CMD_SBYTESWAP_BIT);
- #else
- GT_WRITE(GT_PCI0_CMD_OFS, 0);
- #endif
- #if defined(CONFIG_MIPS_MALTA)
- set_io_port_base(MALTA_GT_PORT_BASE);
- #else
- set_io_port_base(KSEG1);
- #endif
- break;
- case MIPS_REVISION_CORID_BONITO64:
- case MIPS_REVISION_CORID_CORE_20K:
- /*
- * Disable Bonito IOBC.
- */
- BONITO_PCIMEMBASECFG = BONITO_PCIMEMBASECFG &
- ~(BONITO_PCIMEMBASECFG_MEMBASE0_CACHED |
- BONITO_PCIMEMBASECFG_MEMBASE1_CACHED);
- /*
- * Setup the North bridge to do Master byte-lane swapping
- * when running in bigendian.
- */
- #if defined(__MIPSEL__)
- BONITO_BONGENCFG = BONITO_BONGENCFG &
- ~(BONITO_BONGENCFG_MSTRBYTESWAP |
- BONITO_BONGENCFG_BYTESWAP);
- #else
- BONITO_BONGENCFG = BONITO_BONGENCFG |
- BONITO_BONGENCFG_MSTRBYTESWAP |
- BONITO_BONGENCFG_BYTESWAP;
- #endif
- #if defined(CONFIG_MIPS_MALTA)
- set_io_port_base(MALTA_BONITO_PORT_BASE);
- #else
- set_io_port_base(KSEG1);
- #endif
- break;
- case MIPS_REVISION_CORID_CORE_MSC:
- set_io_port_base(MALTA_MSC_PORT_BASE);
- #if defined(__MIPSEL__)
- MSC_WRITE(MSC01_PCI_SWAP, MSC01_PCI_SWAP_NOSWAP);
- #else
- MSC_WRITE(MSC01_PCI_SWAP,
- MSC01_PCI_SWAP_BYTESWAP << MSC01_PCI_SWAP_IO_SHF |
- MSC01_PCI_SWAP_BYTESWAP << MSC01_PCI_SWAP_MEM_SHF |
- MSC01_PCI_SWAP_BYTESWAP << MSC01_PCI_SWAP_BAR0_SHF);
- #endif
- break;
- default:
- /* Unknown Core card */
- mips_display_message("CC Error");
- while(1); /* We die here... */
- }
- #endif
- setup_prom_printf(0);
- prom_printf("nLINUX started...n");
- prom_init_cmdline();
- prom_meminit();
- return 0;
- }