亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? init.c

?? 是關于linux2.5.1的完全源碼
?? C
字號:
/* *  linux/arch/x86_64/mm/init.c * *  Copyright (C) 1995  Linus Torvalds *  Copyright (C) 2000  Pavel Machek <pavel@suse.cz> *  Copyright (C) 2002  Andi Kleen <ak@suse.de> */#include <linux/config.h>#include <linux/signal.h>#include <linux/sched.h>#include <linux/kernel.h>#include <linux/errno.h>#include <linux/string.h>#include <linux/types.h>#include <linux/ptrace.h>#include <linux/mman.h>#include <linux/mm.h>#include <linux/swap.h>#include <linux/smp.h>#include <linux/init.h>#ifdef CONFIG_BLK_DEV_INITRD#include <linux/blk.h>#endif#include <linux/pagemap.h>#include <linux/bootmem.h>#include <asm/processor.h>#include <asm/system.h>#include <asm/uaccess.h>#include <asm/pgtable.h>#include <asm/pgalloc.h>#include <asm/dma.h>#include <asm/fixmap.h>#include <asm/e820.h>#include <asm/apic.h>#include <asm/tlb.h>#include <asm/mmu_context.h>mmu_gather_t mmu_gathers[NR_CPUS];static unsigned long totalram_pages;/* * NOTE: pagetable_init alloc all the fixmap pagetables contiguous on the * physical space so we can cache the place of the first one and move * around without checking the pgd every time. */void show_mem(void){	int i, total = 0, reserved = 0;	int shared = 0, cached = 0;	printk("Mem-info:\n");	show_free_areas();	printk("Free swap:       %6dkB\n",nr_swap_pages<<(PAGE_SHIFT-10));	i = max_mapnr;	while (i-- > 0) {		total++;		if (PageReserved(mem_map+i))			reserved++;		else if (PageSwapCache(mem_map+i))			cached++;		else if (page_count(mem_map+i))			shared += page_count(mem_map+i) - 1;	}	printk("%d pages of RAM\n", total);	printk("%d reserved pages\n",reserved);	printk("%d pages shared\n",shared);	printk("%d pages swap cached\n",cached);	show_buffers();}/* References to section boundaries */extern char _text, _etext, _edata, __bss_start, _end;extern char __init_begin, __init_end;int after_bootmem;static void *spp_getpage(void){ 	void *ptr;	if (after_bootmem)		ptr = (void *) get_free_page(GFP_ATOMIC); 	else		ptr = alloc_bootmem_low(PAGE_SIZE); 	if (!ptr)		panic("set_pte_phys: cannot allocate page data %s\n", after_bootmem?"after bootmem":"");	return ptr;} static void set_pte_phys(unsigned long vaddr,			 unsigned long phys, pgprot_t prot){	pml4_t *level4;	pgd_t *pgd;	pmd_t *pmd;	pte_t *pte;	level4 = pml4_offset_k(vaddr);	if (pml4_none(*level4)) {		printk("PML4 FIXMAP MISSING, it should be setup in head.S!\n");		return;	}	pgd = level3_offset_k(level4, vaddr);	if (pgd_none(*pgd)) {		pmd = (pmd_t *) spp_getpage(); 		set_pgd(pgd, __pgd(__pa(pmd) | _KERNPG_TABLE | _PAGE_USER));		if (pmd != pmd_offset(pgd, 0)) {			printk("PAGETABLE BUG #01!\n");			return;		}	}	pmd = pmd_offset(pgd, vaddr);	if (pmd_none(*pmd)) {		pte = (pte_t *) spp_getpage();		set_pmd(pmd, __pmd(__pa(pte) | _KERNPG_TABLE | _PAGE_USER));		if (pte != pte_offset_kernel(pmd, 0)) {			printk("PAGETABLE BUG #02!\n");			return;		}	}	pte = pte_offset_kernel(pmd, vaddr);	if (pte_val(*pte))		pte_ERROR(*pte);	set_pte(pte, mk_pte_phys(phys, prot));	/*	 * It's enough to flush this one mapping.	 * (PGE mappings get flushed as well)	 */	__flush_tlb_one(vaddr);}/* NOTE: this is meant to be run only at boot */void __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t prot){	unsigned long address = __fix_to_virt(idx);	if (idx >= __end_of_fixed_addresses) {		printk("Invalid __set_fixmap\n");		return;	}	set_pte_phys(address, phys, prot);}extern unsigned long start_pfn, end_pfn; extern pmd_t temp_boot_pmds[]; static  struct temp_map { 	pmd_t *pmd;	void  *address; 	int    allocated; } temp_mappings[] __initdata = { 	{ &temp_boot_pmds[0], (void *)(40UL * 1024 * 1024) },	{ &temp_boot_pmds[1], (void *)(42UL * 1024 * 1024) }, 	{}}; static __init void *alloc_low_page(int *index, unsigned long *phys) { 	struct temp_map *ti;	int i; 	unsigned long pfn = start_pfn++, paddr; 	void *adr;	if (pfn >= end_pfn) 		panic("alloc_low_page: ran out of memory"); 	for (i = 0; temp_mappings[i].allocated; i++) {		if (!temp_mappings[i].pmd) 			panic("alloc_low_page: ran out of temp mappings"); 	} 	ti = &temp_mappings[i];	paddr = (pfn & (~511)) << PAGE_SHIFT; 	set_pmd(ti->pmd, __pmd(paddr | _KERNPG_TABLE | _PAGE_PSE)); 	ti->allocated = 1; 	__flush_tlb(); 	       	adr = ti->address + (pfn & 511)*PAGE_SIZE; 	*index = i; 	*phys  = pfn * PAGE_SIZE;  	return adr; } static __init void unmap_low_page(int i){ 	struct temp_map *ti = &temp_mappings[i];	set_pmd(ti->pmd, __pmd(0));	ti->allocated = 0; } static void __init phys_pgd_init(pgd_t *pgd, unsigned long address, unsigned long end){ 	long i, j; 	i = pgd_index(address);	pgd = pgd + i;	for (; i < PTRS_PER_PGD; pgd++, i++) {		int map; 		unsigned long paddr = i*PGDIR_SIZE, pmd_phys;		pmd_t *pmd;		if (paddr >= end) { 			for (; i < PTRS_PER_PGD; i++, pgd++) 				set_pgd(pgd, __pgd(0)); 			break;		} 		pmd = alloc_low_page(&map, &pmd_phys);		set_pgd(pgd, __pgd(pmd_phys | _KERNPG_TABLE));		for (j = 0; j < PTRS_PER_PMD; pmd++, j++) {			unsigned long pe;			paddr = i*PGDIR_SIZE + j*PMD_SIZE;			if (paddr >= end) { 				for (; j < PTRS_PER_PMD; j++, pmd++)					set_pmd(pmd,  __pmd(0)); 				break;		}			pe = _PAGE_PSE | _KERNPG_TABLE | _PAGE_GLOBAL | paddr;			set_pmd(pmd, __pmd(pe));		}		unmap_low_page(map);	}	__flush_tlb();} /* Setup the direct mapping of the physical memory at PAGE_OFFSET.   This runs before bootmem is initialized and gets pages directly from the    physical memory. To access them they are temporarily mapped. */void __init init_memory_mapping(void) { 	unsigned long adr;	       	unsigned long end;	unsigned long next; 	end = PAGE_OFFSET + (end_pfn * PAGE_SIZE); 	for (adr = PAGE_OFFSET; adr < end; adr = next) { 		int map;		unsigned long pgd_phys; 		pgd_t *pgd = alloc_low_page(&map, &pgd_phys);		next = adr + (512UL * 1024 * 1024 * 1024);		if (next > end) 			next = end; 		phys_pgd_init(pgd, adr-PAGE_OFFSET, next-PAGE_OFFSET); 		set_pml4(init_level4_pgt + pml4_index(adr), mk_kernel_pml4(pgd_phys));		unmap_low_page(map);   	} 	asm volatile("movq %%cr4,%0" : "=r" (mmu_cr4_features));	__flush_tlb_all();}extern struct x8664_pda cpu_pda[NR_CPUS];void __init zap_low_mappings (void){	int i;	for (i = 0; i < NR_CPUS; i++) {		if (cpu_pda[i].level4_pgt) 			cpu_pda[i].level4_pgt[0] = 0; 	}	flush_tlb_all();}void __init paging_init(void){	{		unsigned long zones_size[MAX_NR_ZONES] = {0, 0, 0};		unsigned int max_dma, low;		max_dma = virt_to_phys((char *)MAX_DMA_ADDRESS) >> PAGE_SHIFT;		low = max_low_pfn;		if (low < max_dma)			zones_size[ZONE_DMA] = low;		else {			zones_size[ZONE_DMA] = max_dma;			zones_size[ZONE_NORMAL] = low - max_dma;		}		free_area_init(zones_size);	}	return;}static inline int page_is_ram (unsigned long pagenr){	int i;	for (i = 0; i < e820.nr_map; i++) {		unsigned long addr, end;		if (e820.map[i].type != E820_RAM)	/* not usable memory */			continue;		/*		 *	!!!FIXME!!! Some BIOSen report areas as RAM that		 *	are not. Notably the 640->1Mb area. We need a sanity		 *	check here.		 */		addr = (e820.map[i].addr+PAGE_SIZE-1) >> PAGE_SHIFT;		end = (e820.map[i].addr+e820.map[i].size) >> PAGE_SHIFT;		if  ((pagenr >= addr) && (pagenr < end))			return 1;	}	return 0;}void __init mem_init(void){	int codesize, reservedpages, datasize, initsize;	int tmp;	if (!mem_map)		BUG();	max_mapnr = num_physpages = max_low_pfn;	high_memory = (void *) __va(max_low_pfn * PAGE_SIZE);	/* clear the zero-page */	memset(empty_zero_page, 0, PAGE_SIZE);	/* this will put all low memory onto the freelists */	totalram_pages += free_all_bootmem();	after_bootmem = 1;	reservedpages = 0;	for (tmp = 0; tmp < max_low_pfn; tmp++)		/*		 * Only count reserved RAM pages		 */		if (page_is_ram(tmp) && PageReserved(mem_map+tmp))			reservedpages++;	codesize =  (unsigned long) &_etext - (unsigned long) &_text;	datasize =  (unsigned long) &_edata - (unsigned long) &_etext;	initsize =  (unsigned long) &__init_end - (unsigned long) &__init_begin;	printk("Memory: %luk/%luk available (%dk kernel code, %dk reserved, %dk data, %dk init)\n",		(unsigned long) nr_free_pages() << (PAGE_SHIFT-10),		max_mapnr << (PAGE_SHIFT-10),		codesize >> 10,		reservedpages << (PAGE_SHIFT-10),		datasize >> 10,		initsize >> 10);	/*	 * Subtle. SMP is doing its boot stuff late (because it has to	 * fork idle threads) - but it also needs low mappings for the	 * protected-mode entry to work. We zap these entries only after	 * the WP-bit has been tested.	 */#ifndef CONFIG_SMP	zap_low_mappings();#endif}void free_initmem(void){	unsigned long addr;	addr = (unsigned long)(&__init_begin);	for (; addr < (unsigned long)(&__init_end); addr += PAGE_SIZE) {		ClearPageReserved(virt_to_page(addr));		set_page_count(virt_to_page(addr), 1);#ifdef CONFIG_INIT_DEBUG		memset(addr & ~(PAGE_SIZE-1), 0xcc, PAGE_SIZE); #endif		free_page(addr);		totalram_pages++;	}	printk ("Freeing unused kernel memory: %luk freed\n", (&__init_end - &__init_begin) >> 10);}#ifdef CONFIG_BLK_DEV_INITRDvoid free_initrd_mem(unsigned long start, unsigned long end){	if (start < (unsigned long)&_end)		return;	printk ("Freeing initrd memory: %ldk freed\n", (end - start) >> 10);	for (; start < end; start += PAGE_SIZE) {		ClearPageReserved(virt_to_page(start));		set_page_count(virt_to_page(start), 1);		free_page(start);		totalram_pages++;	}}#endifvoid si_meminfo(struct sysinfo *val){	val->totalram = totalram_pages;	val->sharedram = 0;	val->freeram = nr_free_pages();	val->bufferram = atomic_read(&buffermem_pages);	val->totalhigh = 0;	val->freehigh = nr_free_highpages();	val->mem_unit = PAGE_SIZE;	return;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩三级.com| 成人av网址在线| 亚洲一区二区三区视频在线| 国产精品久久精品日日| 久久精品在线观看| 国产亚洲一区二区三区在线观看| 精品国产一区二区三区久久久蜜月 | 国产精品18久久久| 久久99日本精品| 国产一区二区美女| 丁香六月综合激情| 91欧美激情一区二区三区成人| www.欧美色图| 在线观看日韩电影| 欧美亚洲丝袜传媒另类| 欧美美女激情18p| 91精品国产手机| 欧美精品一区视频| 国产精品免费视频网站| 一区二区三区在线观看欧美| 一区二区理论电影在线观看| 天天色综合天天| 国产自产高清不卡| 福利一区福利二区| 色94色欧美sute亚洲线路一久| 欧日韩精品视频| 欧美成人一区二区三区片免费| 欧美α欧美αv大片| 欧美高清在线一区| 一区二区三区精品久久久| 视频一区国产视频| 国产精品资源站在线| 日本丶国产丶欧美色综合| 欧美福利视频一区| 中文字幕av不卡| 午夜精品久久久久久久久久久| 六月婷婷色综合| 在线免费视频一区二区| 日韩女优电影在线观看| 亚洲欧美日韩国产手机在线 | 国产成人av电影在线| 色久优优欧美色久优优| 欧美丰满高潮xxxx喷水动漫| 国产亚洲欧美激情| 亚洲精品乱码久久久久久黑人| 日韩中文字幕亚洲一区二区va在线| 国产乱码精品一品二品| 欧美性色综合网| 欧美国产在线观看| 蜜桃视频一区二区三区| 色综合久久久网| 久久综合色一综合色88| 亚洲成av人片www| 成人18视频日本| 欧美精品一区男女天堂| 亚洲国产成人精品视频| 97久久超碰精品国产| 欧美精品一区二区三区高清aⅴ| 亚洲综合男人的天堂| 国产91精品露脸国语对白| 91精品国产色综合久久久蜜香臀| 亚洲欧美日韩在线| 成人午夜电影久久影院| 精品国产乱码91久久久久久网站| 亚洲观看高清完整版在线观看 | 亚洲成a人片在线观看中文| 成人午夜电影网站| 国产欧美一区二区精品婷婷| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美伊人精品成人久久综合97| 国产精品嫩草影院av蜜臀| 国内精品国产成人国产三级粉色| 欧美精品一级二级| 亚洲二区视频在线| 欧美图片一区二区三区| 亚洲人成网站精品片在线观看| 成人高清视频在线观看| 亚洲人成亚洲人成在线观看图片 | 4438亚洲最大| 视频在线观看一区| 欧美日本国产视频| 日韩高清电影一区| 制服丝袜av成人在线看| 秋霞av亚洲一区二区三| 欧美一区二区福利视频| 奇米四色…亚洲| 欧美成人伊人久久综合网| 国产乱淫av一区二区三区| wwwwxxxxx欧美| 丁香婷婷综合激情五月色| 国产精品久久久久久久午夜片| 99免费精品在线观看| 亚洲欧美日韩电影| 欧美日韩一区不卡| 美女视频黄 久久| 久久九九国产精品| 91国在线观看| 天堂在线亚洲视频| 精品处破学生在线二十三| 国产精品 欧美精品| 亚洲免费av高清| 69堂国产成人免费视频| 精品综合久久久久久8888| 国产午夜精品久久久久久免费视| heyzo一本久久综合| 亚洲动漫第一页| 精品成人免费观看| 91最新地址在线播放| 婷婷久久综合九色综合绿巨人| 精品成人在线观看| 色婷婷狠狠综合| 热久久免费视频| 中文字幕一区二区三区乱码在线| 欧美性xxxxxx少妇| 国产一区二区三区四区五区美女 | 久久午夜色播影院免费高清| 日韩午夜在线影院| 国产91丝袜在线播放0| 香蕉久久一区二区不卡无毒影院 | 国产做a爰片久久毛片| 国产精品美女久久久久高潮| 欧美日韩精品一区二区三区蜜桃| 国内精品久久久久影院一蜜桃| 最新国产精品久久精品| 日韩三级视频在线观看| 色综合天天天天做夜夜夜夜做| 蜜臀av性久久久久av蜜臀妖精 | 欧美日韩另类国产亚洲欧美一级| 韩国av一区二区三区| 一二三区精品视频| 中文字幕av不卡| 久久亚洲综合色| 91精品国产综合久久久久久漫画 | 成人永久免费视频| 美日韩黄色大片| 伊人性伊人情综合网| 国产日韩欧美激情| 精品国精品国产尤物美女| 欧美色图12p| 99国产精品国产精品毛片| 国产毛片精品国产一区二区三区| 性做久久久久久久久| 日韩美女视频一区| 国产精品欧美一区二区三区| 久久综合九色综合欧美就去吻| 欧美一区二区三区婷婷月色| 欧美r级在线观看| 欧美精品日日鲁夜夜添| 欧洲精品在线观看| 色综合欧美在线| 97se亚洲国产综合在线| 成人一级片在线观看| 国产精品系列在线观看| 精品一区二区在线观看| 日本不卡高清视频| 欧美aaaaaa午夜精品| 蜜桃一区二区三区在线| 蜜臀av在线播放一区二区三区| 婷婷夜色潮精品综合在线| 视频精品一区二区| 日本美女一区二区三区视频| 日韩1区2区日韩1区2区| 免费不卡在线视频| 韩国视频一区二区| 国产成人精品一区二区三区四区| 国产精品自拍毛片| 99国产精品国产精品毛片| 色噜噜偷拍精品综合在线| 欧美日韩三级一区二区| 91精品午夜视频| 欧美精品一区在线观看| 欧美国产成人精品| 亚洲伦理在线精品| 日本在线不卡一区| 国产麻豆91精品| av不卡在线播放| 欧美日韩欧美一区二区| 欧美大片一区二区| 欧美激情一区二区三区| 亚洲线精品一区二区三区| 日本sm残虐另类| 岛国一区二区在线观看| 日本韩国欧美在线| 日韩精品中文字幕在线一区| 日本一区二区电影| 亚洲风情在线资源站| 久久www免费人成看片高清| 成人听书哪个软件好| 日本韩国欧美国产| 欧美精品一区二| 一区二区在线免费观看| 久久99国产精品免费网站| 99re这里都是精品| 精品国精品国产尤物美女| 亚洲精品老司机| 国产一区二区三区电影在线观看| 色狠狠色狠狠综合| 久久精品人人爽人人爽| 亚洲二区在线观看| a级精品国产片在线观看|