1
2
3
4
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
|
/* arch/i386/gdt.c */
.set SEG_r0code, 1
.set SEG_r3code, 3
.set SEG_r3data, 4
.set IA32_SYSENTER_CS, 0x174
.section .text
.global sysexit
.type sysexit, @function
sysexit:
pop %ecx
pop %edx
mov $(SEG_r3data << 3 | 3), %ax
mov %ax, %ds
mov %ax, %es
mov %ax, %fs
mov %ax, %gs
// enable paging
mov %cr0, %eax
or $0x80000000, %eax
mov %eax, %cr0
sysexit
.global sysenter_setup
.type sysenter_setup, @function
sysenter_setup:
xor %edx, %edx
mov $(SEG_r0code << 3), %eax
mov $IA32_SYSENTER_CS, %ecx
wrmsr
ret
|