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

📄 page.h

📁 讲述linux的初始化过程
💻 H
字号:
#ifndef _I386_PAGE_H#define _I386_PAGE_H/* PAGE_SHIFT determines the page size */#define PAGE_SHIFT	12#define PAGE_SIZE	(1UL << PAGE_SHIFT)#define PAGE_MASK	(~(PAGE_SIZE-1))#ifdef __KERNEL__#ifndef __ASSEMBLY__#include <linux/config.h>#ifdef CONFIG_X86_USE_3DNOW#include <asm/mmx.h>#define clear_page(page)	mmx_clear_page(page)#define copy_page(to,from)	mmx_copy_page(to,from)#else/* *	On older X86 processors its not a win to use MMX here it seems. *	Maybe the K6-III ? */ #define clear_page(page)	memset((void *)(page), 0, PAGE_SIZE)#define copy_page(to,from)	memcpy((void *)(to), (void *)(from), PAGE_SIZE)#endif#define clear_user_page(page, vaddr)	clear_page(page)#define copy_user_page(to, from, vaddr)	copy_page(to, from)/* * These are used to make use of C type-checking.. */#if CONFIG_X86_PAEtypedef struct { unsigned long pte_low, pte_high; } pte_t;typedef struct { unsigned long long pmd; } pmd_t;typedef struct { unsigned long long pgd; } pgd_t;#define pte_val(x)	((x).pte_low | ((unsigned long long)(x).pte_high << 32))#elsetypedef struct { unsigned long pte_low; } pte_t;typedef struct { unsigned long pmd; } pmd_t;typedef struct { unsigned long pgd; } pgd_t;#define pte_val(x)	((x).pte_low)#endif#define PTE_MASK	PAGE_MASKtypedef struct { unsigned long pgprot; } pgprot_t;#define pmd_val(x)	((x).pmd)#define pgd_val(x)	((x).pgd)#define pgprot_val(x)	((x).pgprot)#define __pte(x) ((pte_t) { (x) } )#define __pmd(x) ((pmd_t) { (x) } )#define __pgd(x) ((pgd_t) { (x) } )#define __pgprot(x)	((pgprot_t) { (x) } )#endif /* !__ASSEMBLY__ *//* to align the pointer to the (next) page boundary */#define PAGE_ALIGN(addr)	(((addr)+PAGE_SIZE-1)&PAGE_MASK)/* * This handles the memory map.. We could make this a config * option, but too many people screw it up, and too few need * it. * * A __PAGE_OFFSET of 0xC0000000 means that the kernel has * a virtual address space of one gigabyte, which limits the * amount of physical memory you can use to about 950MB.  * * If you want more physical memory than this then see the CONFIG_HIGHMEM4G * and CONFIG_HIGHMEM64G options in the kernel configuration. */#define __PAGE_OFFSET		(0xC0000000)#ifndef __ASSEMBLY__/* * Tell the user there is some problem. Beep too, so we can * see^H^H^Hhear bugs in early bootup as well! */#define BUG() do { \	printk("kernel BUG at %s:%d!\n", __FILE__, __LINE__); \	__asm__ __volatile__(".byte 0x0f,0x0b"); \} while (0)#define PAGE_BUG(page) do { \	BUG(); \} while (0)/* Pure 2^n version of get_order */extern __inline__ int get_order(unsigned long size){	int order;	size = (size-1) >> (PAGE_SHIFT-1);	order = -1;	do {		size >>= 1;		order++;	} while (size);	return order;}#endif /* __ASSEMBLY__ */#define PAGE_OFFSET		((unsigned long)__PAGE_OFFSET)#define __pa(x)			((unsigned long)(x)-PAGE_OFFSET)#define __va(x)			((void *)((unsigned long)(x)+PAGE_OFFSET))#define virt_to_page(kaddr)	(mem_map + (__pa(kaddr) >> PAGE_SHIFT))#define VALID_PAGE(page)	((page - mem_map) < max_mapnr)#endif /* __KERNEL__ */#endif /* _I386_PAGE_H */

⌨️ 快捷键说明

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