📄 init.c
字号:
/* * 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 prom\n"); 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("%02x\n", *(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;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -