⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 setup.c

📁 优龙2410linux2.6.8内核源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
        /*         * print what head.S has found out about the machine          */#ifndef CONFIG_ARCH_S390X	printk((MACHINE_IS_VM) ?	       "We are running under VM (31 bit mode)\n" :	       "We are running native (31 bit mode)\n");	printk((MACHINE_HAS_IEEE) ?	       "This machine has an IEEE fpu\n" :	       "This machine has no IEEE fpu\n");#else /* CONFIG_ARCH_S390X */	printk((MACHINE_IS_VM) ?	       "We are running under VM (64 bit mode)\n" :	       "We are running native (64 bit mode)\n");#endif /* CONFIG_ARCH_S390X */        ROOT_DEV = Root_RAM0;        memory_start = (unsigned long) &_end;    /* fixit if use $CODELO etc*/#ifndef CONFIG_ARCH_S390X	memory_end = memory_size & ~0x400000UL;  /* align memory end to 4MB */        /*         * We need some free virtual space to be able to do vmalloc.         * On a machine with 2GB memory we make sure that we have at         * least 128 MB free space for vmalloc.         */        if (memory_end > 1920*1024*1024)                memory_end = 1920*1024*1024;#else /* CONFIG_ARCH_S390X */	memory_end = memory_size & ~0x200000UL;  /* detected in head.s */#endif /* CONFIG_ARCH_S390X */        init_mm.start_code = PAGE_OFFSET;        init_mm.end_code = (unsigned long) &_etext;        init_mm.end_data = (unsigned long) &_edata;        init_mm.brk = (unsigned long) &_end;	code_resource.start = (unsigned long) &_text;	code_resource.end = (unsigned long) &_etext - 1;	data_resource.start = (unsigned long) &_etext;	data_resource.end = (unsigned long) &_edata - 1;        /* Save unparsed command line copy for /proc/cmdline */        memcpy(saved_command_line, COMMAND_LINE, COMMAND_LINE_SIZE);        saved_command_line[COMMAND_LINE_SIZE-1] = '\0';        for (;;) {                /*                 * "mem=XXX[kKmM]" sets memsize                  */                if (c == ' ' && strncmp(from, "mem=", 4) == 0) {                        memory_end = simple_strtoul(from+4, &from, 0);                        if ( *from == 'K' || *from == 'k' ) {                                memory_end = memory_end << 10;                                from++;                        } else if ( *from == 'M' || *from == 'm' ) {                                memory_end = memory_end << 20;                                from++;                        }                }                /*                 * "ipldelay=XXX[sm]" sets ipl delay in seconds or minutes                 */                if (c == ' ' && strncmp(from, "ipldelay=", 9) == 0) {                        delay = simple_strtoul(from+9, &from, 0);			if (*from == 's' || *from == 'S') {				delay = delay*1000000;				from++;			} else if (*from == 'm' || *from == 'M') {				delay = delay*60*1000000;				from++;			}			/* now wait for the requested amount of time */			udelay(delay);                }                cn = *(from++);                if (!cn)                        break;                if (cn == '\n')                        cn = ' ';  /* replace newlines with space */		if (cn == 0x0d)			cn = ' ';  /* replace 0x0d with space */                if (cn == ' ' && c == ' ')                        continue;  /* remove additional spaces */                c = cn;                if (to - command_line >= COMMAND_LINE_SIZE)                        break;                *(to++) = c;        }        if (c == ' ' && to > command_line) to--;        *to = '\0';        *cmdline_p = command_line;	/*	 * partially used pages are not usable - thus	 * we are rounding upwards:	 */	start_pfn = (__pa(&_end) + PAGE_SIZE - 1) >> PAGE_SHIFT;	end_pfn = max_pfn = memory_end >> PAGE_SHIFT;	/*	 * Initialize the boot-time allocator (with low memory only):	 */	bootmap_size = init_bootmem(start_pfn, end_pfn);	/*	 * Register RAM areas with the bootmem allocator.	 */	for (i = 0; i < 16 && memory_chunk[i].size > 0; i++) {		unsigned long start_chunk, end_chunk;		if (memory_chunk[i].type != CHUNK_READ_WRITE)			continue;		start_chunk = (memory_chunk[i].addr + PAGE_SIZE - 1);		start_chunk >>= PAGE_SHIFT;		end_chunk = (memory_chunk[i].addr + memory_chunk[i].size);		end_chunk >>= PAGE_SHIFT;		if (start_chunk < start_pfn)			start_chunk = start_pfn;		if (end_chunk > end_pfn)			end_chunk = end_pfn;		if (start_chunk < end_chunk)			free_bootmem(start_chunk << PAGE_SHIFT,				     (end_chunk - start_chunk) << PAGE_SHIFT);	}        /*         * Reserve the bootmem bitmap itself as well. We do this in two         * steps (first step was init_bootmem()) because this catches         * the (very unlikely) case of us accidentally initializing the         * bootmem allocator with an invalid RAM area.         */        reserve_bootmem(start_pfn << PAGE_SHIFT, bootmap_size);#ifdef CONFIG_BLK_DEV_INITRD        if (INITRD_START) {		if (INITRD_START + INITRD_SIZE <= memory_end) {			reserve_bootmem(INITRD_START, INITRD_SIZE);			initrd_start = INITRD_START;			initrd_end = initrd_start + INITRD_SIZE;		} else {                        printk("initrd extends beyond end of memory "                               "(0x%08lx > 0x%08lx)\ndisabling initrd\n",                               initrd_start + INITRD_SIZE, memory_end);                        initrd_start = initrd_end = 0;		}        }#endif        /*         * Setup lowcore for boot cpu         */#ifndef CONFIG_ARCH_S390X	lc = (struct _lowcore *) __alloc_bootmem(PAGE_SIZE, PAGE_SIZE, 0);	memset(lc, 0, PAGE_SIZE);#else /* CONFIG_ARCH_S390X */	lc = (struct _lowcore *) __alloc_bootmem(2*PAGE_SIZE, 2*PAGE_SIZE, 0);	memset(lc, 0, 2*PAGE_SIZE);#endif /* CONFIG_ARCH_S390X */	lc->restart_psw.mask = PSW_BASE_BITS;	lc->restart_psw.addr =		PSW_ADDR_AMODE | (unsigned long) restart_int_handler;	lc->external_new_psw.mask = PSW_KERNEL_BITS;	lc->external_new_psw.addr =		PSW_ADDR_AMODE | (unsigned long) ext_int_handler;	lc->svc_new_psw.mask = PSW_KERNEL_BITS | PSW_MASK_IO | PSW_MASK_EXT;	lc->svc_new_psw.addr = PSW_ADDR_AMODE | (unsigned long) system_call;	lc->program_new_psw.mask = PSW_KERNEL_BITS;	lc->program_new_psw.addr =		PSW_ADDR_AMODE | (unsigned long)pgm_check_handler;	lc->mcck_new_psw.mask = PSW_KERNEL_BITS;	lc->mcck_new_psw.addr =		PSW_ADDR_AMODE | (unsigned long) mcck_int_handler;	lc->io_new_psw.mask = PSW_KERNEL_BITS;	lc->io_new_psw.addr = PSW_ADDR_AMODE | (unsigned long) io_int_handler;	lc->ipl_device = S390_lowcore.ipl_device;	lc->jiffy_timer = -1LL;	lc->kernel_stack = ((unsigned long) &init_thread_union) + THREAD_SIZE;	lc->async_stack = (unsigned long)		__alloc_bootmem(ASYNC_SIZE, ASYNC_SIZE, 0) + ASYNC_SIZE;	lc->current_task = (unsigned long) init_thread_union.thread_info.task;	lc->thread_info = (unsigned long) &init_thread_union;#ifdef CONFIG_ARCH_S390X	if (MACHINE_HAS_DIAG44)		lc->diag44_opcode = 0x83000044;	else		lc->diag44_opcode = 0x07000700;#endif /* CONFIG_ARCH_S390X */	set_prefix((u32)(unsigned long) lc);        cpu_init();        __cpu_logical_map[0] = S390_lowcore.cpu_data.cpu_addr;	/*	 * Create kernel page tables and switch to virtual addressing.	 */        paging_init();	res = alloc_bootmem_low(sizeof(struct resource));	res->start = 0;	res->end = memory_end;	res->flags = IORESOURCE_MEM | IORESOURCE_BUSY;	request_resource(&iomem_resource, res);	request_resource(res, &code_resource);	request_resource(res, &data_resource);        /* Setup default console */	conmode_default();}void print_cpu_info(struct cpuinfo_S390 *cpuinfo){   printk("cpu %d "#ifdef CONFIG_SMP           "phys_idx=%d "#endif           "vers=%02X ident=%06X machine=%04X unused=%04X\n",           cpuinfo->cpu_nr,#ifdef CONFIG_SMP           cpuinfo->cpu_addr,#endif           cpuinfo->cpu_id.version,           cpuinfo->cpu_id.ident,           cpuinfo->cpu_id.machine,           cpuinfo->cpu_id.unused);}/* * show_cpuinfo - Get information on one CPU for use by procfs. */static int show_cpuinfo(struct seq_file *m, void *v){        struct cpuinfo_S390 *cpuinfo;	unsigned long n = (unsigned long) v - 1;	if (!n) {		seq_printf(m, "vendor_id       : IBM/S390\n"			       "# processors    : %i\n"			       "bogomips per cpu: %lu.%02lu\n",			       num_online_cpus(), loops_per_jiffy/(500000/HZ),			       (loops_per_jiffy/(5000/HZ))%100);	}	if (cpu_online(n)) {#ifdef CONFIG_SMP		if (smp_processor_id() == n)			cpuinfo = &S390_lowcore.cpu_data;		else			cpuinfo = &lowcore_ptr[n]->cpu_data;#else		cpuinfo = &S390_lowcore.cpu_data;#endif		seq_printf(m, "processor %li: "			       "version = %02X,  "			       "identification = %06X,  "			       "machine = %04X\n",			       n, cpuinfo->cpu_id.version,			       cpuinfo->cpu_id.ident,			       cpuinfo->cpu_id.machine);	}        return 0;}static void *c_start(struct seq_file *m, loff_t *pos){	return *pos < NR_CPUS ? (void *)((unsigned long) *pos + 1) : NULL;}static void *c_next(struct seq_file *m, void *v, loff_t *pos){	++*pos;	return c_start(m, pos);}static void c_stop(struct seq_file *m, void *v){}struct seq_operations cpuinfo_op = {	.start	= c_start,	.next	= c_next,	.stop	= c_stop,	.show	= show_cpuinfo,};/* * show_interrupts is needed by /proc/interrupts. */static const char *intrclass_names[] = {	"EXT",	"I/O",};int show_interrupts(struct seq_file *p, void *v){        int i = *(loff_t *) v, j;		if (i == 0) {		seq_puts(p, "           ");		for (j=0; j<NR_CPUS; j++)			if (cpu_online(j))				seq_printf(p, "CPU%d       ",j);		seq_putc(p, '\n');	}		if (i < NR_IRQS) {		seq_printf(p, "%s: ", intrclass_names[i]);#ifndef CONFIG_SMP		seq_printf(p, "%10u ", kstat_irqs(i));#else		for (j = 0; j < NR_CPUS; j++)			if (cpu_online(j))				seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]);#endif                seq_putc(p, '\n');		        }	        return 0;}/* * For compatibilty only. S/390 specific setup of interrupts et al. is done * much later in init_channel_subsystem(). */void __initinit_IRQ(void){	/* nothing... */}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -