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

📄 mmu_context.h

📁 自己做的交叉编译工具!gcc-3.4.5,glibc-2.3.6在ubuntu8.04上做的面向kernel-2.6.28的交叉编译工具
💻 H
字号:
/* *  linux/include/asm-arm/mmu_context.h * *  Copyright (C) 1996 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. * *  Changelog: *   27-06-1996	RMK	Created */#ifndef __ASM_ARM_MMU_CONTEXT_H#define __ASM_ARM_MMU_CONTEXT_H#if __LINUX_ARM_ARCH__ >= 6/* * On ARMv6, we have the following structure in the Context ID: * * 31                         7          0 * +-------------------------+-----------+ * |      process ID         |   ASID    | * +-------------------------+-----------+ * |              context ID             | * +-------------------------------------+ * * The ASID is used to tag entries in the CPU caches and TLBs. * The context ID is used by debuggers and trace logic, and * should be unique within all running processes. */#define ASID_BITS	8#define ASID_MASK	((~0) << ASID_BITS)extern unsigned int cpu_last_asid;void __init_new_context(struct task_struct *tsk, struct mm_struct *mm);void __new_context(struct mm_struct *mm);static inline void check_context(struct mm_struct *mm){	if (unlikely((mm->context.id ^ cpu_last_asid) >> ASID_BITS))		__new_context(mm);}#define init_new_context(tsk,mm)	(__init_new_context(tsk,mm),0)#else#define check_context(mm)		do { } while (0)#define init_new_context(tsk,mm)	0#endif#define destroy_context(mm)		do { } while(0)/* * This is called when "tsk" is about to enter lazy TLB mode. * * mm:  describes the currently active mm context * tsk: task which is entering lazy tlb * cpu: cpu number which is entering lazy tlb * * tsk->mm will be NULL */static inline voidenter_lazy_tlb(struct mm_struct *mm, struct task_struct *tsk){}/* * This is the actual mm switch as far as the scheduler * is concerned.  No registers are touched.  We avoid * calling the CPU specific function when the mm hasn't * actually changed. */static inline voidswitch_mm(struct mm_struct *prev, struct mm_struct *next,	  struct task_struct *tsk){	unsigned int cpu = smp_processor_id();	if (prev != next) {		cpu_set(cpu, next->cpu_vm_mask);		check_context(next);		cpu_switch_mm(next->pgd, next);		cpu_clear(cpu, prev->cpu_vm_mask);	}}#define deactivate_mm(tsk,mm)	do { } while (0)#define activate_mm(prev,next)	switch_mm(prev, next, NULL)#endif

⌨️ 快捷键说明

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