page.h

来自「此工具是arm-linux-GCC交叉编译工具(cross-3.4.4)」· C头文件 代码 · 共 178 行

H
178
字号
/* *  linux/include/asm-arm/page.h * *  Copyright (C) 1995-2003 Russell King * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#ifndef _ASMARM_PAGE_H#define _ASMARM_PAGE_H#include <linux/config.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__/* to align the pointer to the (next) page boundary */#define PAGE_ALIGN(addr)	(((addr)+PAGE_SIZE-1)&PAGE_MASK)#ifndef __ASSEMBLY__#include <asm/glue.h>/* *	User Space Model *	================ * *	This section selects the correct set of functions for dealing with *	page-based copying and clearing for user space for the particular *	processor(s) we're building for. * *	We have the following to choose from: *	  v3		- ARMv3 *	  v4wt		- ARMv4 with writethrough cache, without minicache *	  v4wb		- ARMv4 with writeback cache, without minicache *	  v4_mc		- ARMv4 with minicache *	  xscale	- Xscale */#undef _USER#undef MULTI_USER#ifdef CONFIG_CPU_COPY_V3# ifdef _USER#  define MULTI_USER 1# else#  define _USER v3# endif#endif#ifdef CONFIG_CPU_COPY_V4WT# ifdef _USER#  define MULTI_USER 1# else#  define _USER v4wt# endif#endif#ifdef CONFIG_CPU_COPY_V4WB# ifdef _USER#  define MULTI_USER 1# else#  define _USER v4wb# endif#endif#ifdef CONFIG_CPU_SA1100# ifdef _USER#  define MULTI_USER 1# else#  define _USER v4_mc# endif#endif#ifdef CONFIG_CPU_XSCALE# ifdef _USER#  define MULTI_USER 1# else#  define _USER xscale_mc# endif#endif#ifdef CONFIG_CPU_COPY_V6# define MULTI_USER 1#endif#if !defined(_USER) && !defined(MULTI_USER)#error Unknown user operations model#endifstruct cpu_user_fns {	void (*cpu_clear_user_page)(void *p, unsigned long user);	void (*cpu_copy_user_page)(void *to, const void *from,				   unsigned long user);};#ifdef MULTI_USERextern struct cpu_user_fns cpu_user;#define __cpu_clear_user_page	cpu_user.cpu_clear_user_page#define __cpu_copy_user_page	cpu_user.cpu_copy_user_page#else#define __cpu_clear_user_page	__glue(_USER,_clear_user_page)#define __cpu_copy_user_page	__glue(_USER,_copy_user_page)extern void __cpu_clear_user_page(void *p, unsigned long user);extern void __cpu_copy_user_page(void *to, const void *from,				 unsigned long user);#endif#define clear_user_page(addr,vaddr,pg)	 __cpu_clear_user_page(addr, vaddr)#define copy_user_page(to,from,vaddr,pg) __cpu_copy_user_page(to, from, vaddr)#define clear_page(page)	memzero((void *)(page), PAGE_SIZE)extern void copy_page(void *to, const void *from);#undef STRICT_MM_TYPECHECKS#ifdef STRICT_MM_TYPECHECKS/* * These are used to make use of C type-checking.. */typedef struct { unsigned long pte; } pte_t;typedef struct { unsigned long pmd; } pmd_t;typedef struct { unsigned long pgd[2]; } pgd_t;typedef struct { unsigned long pgprot; } pgprot_t;#define pte_val(x)      ((x).pte)#define pmd_val(x)      ((x).pmd)#define pgd_val(x)	((x).pgd[0])#define pgprot_val(x)   ((x).pgprot)#define __pte(x)        ((pte_t) { (x) } )#define __pmd(x)        ((pmd_t) { (x) } )#define __pgprot(x)     ((pgprot_t) { (x) } )#else/* * .. while these make it easier on the compiler */typedef unsigned long pte_t;typedef unsigned long pmd_t;typedef unsigned long pgd_t[2];typedef unsigned long pgprot_t;#define pte_val(x)      (x)#define pmd_val(x)      (x)#define pgd_val(x)	((x)[0])#define pgprot_val(x)   (x)#define __pte(x)        (x)#define __pmd(x)        (x)#define __pgprot(x)     (x)#endif /* STRICT_MM_TYPECHECKS *//* the upper-most page table pointer */extern pmd_t *top_pmd;#include <asm/memory.h>#endif /* !__ASSEMBLY__ */#define VM_DATA_DEFAULT_FLAGS	(VM_READ | VM_WRITE | VM_EXEC | \				 VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC)#endif /* __KERNEL__ */#include <asm-generic/page.h>#endif

⌨️ 快捷键说明

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