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

📄 mmzone.h

📁 《嵌入式系统设计与实例开发实验教材二源码》Linux内核移植与编译实验
💻 H
字号:
/* * Written by Kanoj Sarcar (kanoj@sgi.com) Aug 99 * Adapted for the alpha wildfire architecture Jan 2001. */#ifndef _ASM_MMZONE_H_#define _ASM_MMZONE_H_#include <linux/config.h>#ifdef CONFIG_NUMA_SCHED#include <linux/numa_sched.h>#endif#ifdef NOTYET#include <asm/sn/types.h>#include <asm/sn/addrs.h>#include <asm/sn/arch.h>#include <asm/sn/klkernvars.h>#endif /* NOTYET */typedef struct plat_pglist_data {	pg_data_t	gendata;#ifdef NOTYET	kern_vars_t	kern_vars;#endif#if defined(CONFIG_NUMA) && defined(CONFIG_NUMA_SCHED)	struct numa_schedule_data schedule_data;#endif} plat_pg_data_t;struct bootmem_data_t; /* stupid forward decl. *//* * Following are macros that are specific to this numa platform. */extern plat_pg_data_t *plat_node_data[];#ifdef CONFIG_ALPHA_WILDFIRE# define ALPHA_PA_TO_NID(pa)	((pa) >> 36)	/* 16 nodes max due 43bit kseg */#define NODE_MAX_MEM_SIZE	(64L * 1024L * 1024L * 1024L) /* 64 GB */#define MAX_NUMNODES		WILDFIRE_MAX_QBB#else# define ALPHA_PA_TO_NID(pa)	(0)#define NODE_MAX_MEM_SIZE	(~0UL)#define MAX_NUMNODES		1#endif#define PHYSADDR_TO_NID(pa)		ALPHA_PA_TO_NID(pa)#define PLAT_NODE_DATA(n)		(plat_node_data[(n)])#define PLAT_NODE_DATA_STARTNR(n)	\	(PLAT_NODE_DATA(n)->gendata.node_start_mapnr)#define PLAT_NODE_DATA_SIZE(n)		(PLAT_NODE_DATA(n)->gendata.node_size)#if 1#define PLAT_NODE_DATA_LOCALNR(p, n)	\	(((p) - PLAT_NODE_DATA(n)->gendata.node_start_paddr) >> PAGE_SHIFT)#elsestatic inline unsigned longPLAT_NODE_DATA_LOCALNR(unsigned long p, int n){	unsigned long temp;	temp = p - PLAT_NODE_DATA(n)->gendata.node_start_paddr;	return (temp >> PAGE_SHIFT);}#endif#ifdef CONFIG_DISCONTIGMEM/* * Following are macros that each numa implmentation must define. *//* * Given a kernel address, find the home node of the underlying memory. */#define KVADDR_TO_NID(kaddr)	PHYSADDR_TO_NID(__pa(kaddr))/* * Return a pointer to the node data for node n. */#define NODE_DATA(n)	(&((PLAT_NODE_DATA(n))->gendata))/* * NODE_MEM_MAP gives the kaddr for the mem_map of the node. */#define NODE_MEM_MAP(nid)	(NODE_DATA(nid)->node_mem_map)/* * Given a kaddr, ADDR_TO_MAPBASE finds the owning node of the memory * and returns the the mem_map of that node. */#define ADDR_TO_MAPBASE(kaddr) \			NODE_MEM_MAP(KVADDR_TO_NID((unsigned long)(kaddr)))/* * Given a kaddr, LOCAL_BASE_ADDR finds the owning node of the memory * and returns the kaddr corresponding to first physical page in the * node's mem_map. */#define LOCAL_BASE_ADDR(kaddr)	((unsigned long)__va(NODE_DATA(KVADDR_TO_NID(kaddr))->node_start_paddr))#define LOCAL_MAP_NR(kvaddr) \	(((unsigned long)(kvaddr)-LOCAL_BASE_ADDR(kvaddr)) >> PAGE_SHIFT)#define kern_addr_valid(kaddr)	test_bit(LOCAL_MAP_NR(kaddr), \					 NODE_DATA(KVADDR_TO_NID(kaddr))->valid_addr_bitmap)#define virt_to_page(kaddr)	(ADDR_TO_MAPBASE(kaddr) + LOCAL_MAP_NR(kaddr))#define VALID_PAGE(page)	(((page) - mem_map) < max_mapnr)#ifdef CONFIG_NUMA#ifdef CONFIG_NUMA_SCHED#define NODE_SCHEDULE_DATA(nid)	(&((PLAT_NODE_DATA(nid))->schedule_data))#endif#ifdef CONFIG_ALPHA_WILDFIRE/* With wildfire assume 4 CPUs per node */#define cputonode(cpu)	((cpu) >> 2)#else#define cputonode(cpu)	0#endif /* CONFIG_ALPHA_WILDFIRE */#define numa_node_id()	cputonode(smp_processor_id())#endif /* CONFIG_NUMA */#endif /* CONFIG_DISCONTIGMEM */#endif /* _ASM_MMZONE_H_ */

⌨️ 快捷键说明

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