desc.h

来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 132 行

H
132
字号
#ifndef __ARCH_DESC_H#define __ARCH_DESC_H#include <asm/ldt.h>#include <asm/segment.h>#ifndef __ASSEMBLY__#include <linux/preempt.h>#include <linux/smp.h>#include <linux/percpu.h>#include <asm/mmu.h>extern struct desc_struct cpu_gdt_table[GDT_ENTRIES];DECLARE_PER_CPU(struct desc_struct, cpu_gdt_table[GDT_ENTRIES]);struct Xgt_desc_struct {	unsigned short size;	unsigned long address __attribute__((packed));	unsigned short pad;} __attribute__ ((packed));extern struct Xgt_desc_struct idt_descr, cpu_gdt_descr[NR_CPUS];#define load_TR_desc() __asm__ __volatile__("ltr %%ax"::"a" (GDT_ENTRY_TSS*8))#define load_LDT_desc() __asm__ __volatile__("lldt %%ax"::"a" (GDT_ENTRY_LDT*8))/* * This is the ldt that every process will get unless we need * something other than this. */extern struct desc_struct default_ldt[];extern void set_intr_gate(unsigned int irq, void * addr);#define _set_tssldt_desc(n,addr,limit,type) \__asm__ __volatile__ ("movw %w3,0(%2)\n\t" \	"movw %%ax,2(%2)\n\t" \	"rorl $16,%%eax\n\t" \	"movb %%al,4(%2)\n\t" \	"movb %4,5(%2)\n\t" \	"movb $0,6(%2)\n\t" \	"movb %%ah,7(%2)\n\t" \	"rorl $16,%%eax" \	: "=m"(*(n)) : "a" (addr), "r"(n), "ir"(limit), "i"(type))static inline void __set_tss_desc(unsigned int cpu, unsigned int entry, void *addr){	_set_tssldt_desc(&per_cpu(cpu_gdt_table, cpu)[entry], (int)addr,		offsetof(struct tss_struct, __cacheline_filler) - 1, 0x89);}#define set_tss_desc(cpu,addr) __set_tss_desc(cpu, GDT_ENTRY_TSS, addr)static inline void set_ldt_desc(unsigned int cpu, void *addr, unsigned int size){	_set_tssldt_desc(&per_cpu(cpu_gdt_table, cpu)[GDT_ENTRY_LDT], (int)addr, ((size << 3)-1), 0x82);}#define LDT_entry_a(info) \	((((info)->base_addr & 0x0000ffff) << 16) | ((info)->limit & 0x0ffff))#define LDT_entry_b(info) \	(((info)->base_addr & 0xff000000) | \	(((info)->base_addr & 0x00ff0000) >> 16) | \	((info)->limit & 0xf0000) | \	(((info)->read_exec_only ^ 1) << 9) | \	((info)->contents << 10) | \	(((info)->seg_not_present ^ 1) << 15) | \	((info)->seg_32bit << 22) | \	((info)->limit_in_pages << 23) | \	((info)->useable << 20) | \	0x7000)#define LDT_empty(info) (\	(info)->base_addr	== 0	&& \	(info)->limit		== 0	&& \	(info)->contents	== 0	&& \	(info)->read_exec_only	== 1	&& \	(info)->seg_32bit	== 0	&& \	(info)->limit_in_pages	== 0	&& \	(info)->seg_not_present	== 1	&& \	(info)->useable		== 0	)#if TLS_SIZE != 24# error update this code.#endifstatic inline void load_TLS(struct thread_struct *t, unsigned int cpu){#define C(i) per_cpu(cpu_gdt_table, cpu)[GDT_ENTRY_TLS_MIN + i] = t->tls_array[i]	C(0); C(1); C(2);#undef C}static inline void clear_LDT(void){	int cpu = get_cpu();	set_ldt_desc(cpu, &default_ldt[0], 5);	load_LDT_desc();	put_cpu();}/* * load one particular LDT into the current CPU */static inline void load_LDT_nolock(mm_context_t *pc, int cpu){	void *segments = pc->ldt;	int count = pc->size;	if (likely(!count)) {		segments = &default_ldt[0];		count = 5;	}			set_ldt_desc(cpu, segments, count);	load_LDT_desc();}static inline void load_LDT(mm_context_t *pc){	int cpu = get_cpu();	load_LDT_nolock(pc, cpu);	put_cpu();}#endif /* !__ASSEMBLY__ */#endif

⌨️ 快捷键说明

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