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

📄 page.h

📁 嵌入式系统设计与实例开发实验教材二源码 多线程应用程序设计 串行端口程序设计 AD接口实验 CAN总线通信实验 GPS通信实验 Linux内核移植与编译实验 IC卡读写实验 SD驱动使
💻 H
字号:
#ifndef _CRIS_PAGE_H#define _CRIS_PAGE_H#include <linux/config.h>#include <asm/mmu.h>/* PAGE_SHIFT determines the page size */#define PAGE_SHIFT	13#define PAGE_SIZE	(1UL << PAGE_SHIFT)#define PAGE_MASK	(~(PAGE_SIZE-1))#ifdef __KERNEL__#define clear_page(page)        memset((void *)(page), 0, PAGE_SIZE)#define copy_page(to,from)      memcpy((void *)(to), (void *)(from), PAGE_SIZE)#define clear_user_page(page, vaddr)    clear_page(page)#define copy_user_page(to, from, vaddr) copy_page(to, from)#define 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; } 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)#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) } )#else/* * .. while these make it easier on the compiler */typedef unsigned long pte_t;typedef unsigned long pmd_t;typedef unsigned long pgd_t;typedef unsigned long pgprot_t;#define pte_val(x)	(x)#define pmd_val(x)	(x)#define pgd_val(x)	(x)#define pgprot_val(x)	(x)#define __pte(x)	(x)#define __pmd(x)	(x)#define __pgd(x)	(x)#define __pgprot(x)	(x)#endif/* to align the pointer to the (next) page boundary */#define PAGE_ALIGN(addr)	(((addr)+PAGE_SIZE-1)&PAGE_MASK)/* This handles the memory map.. */#ifdef CONFIG_CRIS_LOW_MAP#define PAGE_OFFSET		KSEG_6   /* kseg_6 is mapped to physical ram */#else#define PAGE_OFFSET		KSEG_C   /* kseg_c is mapped to physical ram */#endif#ifndef __ASSEMBLY__#define BUG() do { \  printk("kernel BUG at %s:%d!\n", __FILE__, __LINE__); \} while (0)#define PAGE_BUG(page) do { \         BUG(); \} while (0)#endif /* __ASSEMBLY__ *//* macros to convert between really physical and virtual addresses * by stripping a selected bit, we can convert between KSEG_x and 0x40000000 where * the DRAM really resides */#ifdef CONFIG_CRIS_LOW_MAP/* we have DRAM virtually at 0x6 */#define __pa(x)                 ((unsigned long)(x) & 0xdfffffff)#define __va(x)                 ((void *)((unsigned long)(x) | 0x20000000))#else/* we have DRAM virtually at 0xc */#define __pa(x)                 ((unsigned long)(x) & 0x7fffffff)#define __va(x)                 ((void *)((unsigned long)(x) | 0x80000000))#endif/* to index into the page map. our pages all start at physical addr PAGE_OFFSET so * we can let the map start there. notice that we subtract PAGE_OFFSET because * we start our mem_map there - in other ports they map mem_map physically and * use __pa instead. in our system both the physical and virtual address of DRAM * is too high to let mem_map start at 0, so we do it this way instead (similar * to arm and m68k I think) */ #define virt_to_page(kaddr)    (mem_map + (((unsigned long)kaddr - PAGE_OFFSET) >> PAGE_SHIFT))#define VALID_PAGE(page)       ((page - mem_map) < max_mapnr)/* from linker script */extern unsigned long dram_start, dram_end;#endif /* __KERNEL__ */#endif /* _CRIS_PAGE_H */

⌨️ 快捷键说明

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