1#ifndef __ARCH_DESC_H
2#define __ARCH_DESC_H
3
4#include <asm/ldt.h>
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37#define __FIRST_TSS_ENTRY 12
38#define __FIRST_LDT_ENTRY (__FIRST_TSS_ENTRY+1)
39
40#define __TSS(n) (((n)<<2) + __FIRST_TSS_ENTRY)
41#define __LDT(n) (((n)<<2) + __FIRST_LDT_ENTRY)
42
43#ifndef __ASSEMBLY__
44struct desc_struct {
45 unsigned long a,b;
46};
47
48extern struct desc_struct gdt_table[];
49extern struct desc_struct *idt, *gdt;
50
51struct Xgt_desc_struct {
52 unsigned short size;
53 unsigned long address __attribute__((packed));
54};
55
56#define idt_descr (*(struct Xgt_desc_struct *)((char *)&idt - 2))
57#define gdt_descr (*(struct Xgt_desc_struct *)((char *)&gdt - 2))
58
59#define load_TR(n) __asm__ __volatile__("ltr %%ax"::"a" (__TSS(n)<<3))
60
61#define __load_LDT(n) __asm__ __volatile__("lldt %%ax"::"a" (__LDT(n)<<3))
62
63
64
65
66
67extern struct desc_struct default_ldt[];
68extern void set_intr_gate(unsigned int irq, void * addr);
69extern void set_ldt_desc(unsigned int n, void *addr, unsigned int size);
70extern void set_tss_desc(unsigned int n, void *addr);
71
72static inline void clear_LDT(void)
73{
74 int cpu = smp_processor_id();
75 set_ldt_desc(cpu, &default_ldt[0], 5);
76 __load_LDT(cpu);
77}
78
79
80
81
82static inline void load_LDT (struct mm_struct *mm)
83{
84 int cpu = smp_processor_id();
85 void *segments = mm->context.segments;
86 int count = LDT_ENTRIES;
87
88 if (!segments) {
89 segments = &default_ldt[0];
90 count = 5;
91 }
92
93 set_ldt_desc(cpu, segments, count);
94 __load_LDT(cpu);
95}
96
97#endif
98
99#endif
100