3 # Created on: Nov 19, 2009
10 .align 4 # The config variables are passed here...
20 .short 0x1000 # 0x08: small CS selector
24 .short 0x1000 # 0x10: small DS selector
28 .short 0xffff # 0x18: 4GB CS selector
32 .short 0xffff # 0x20: 4GB DS selector
42 mov
%cs
, %ax
# Find out where the code resides
45 leal gdt
(%eax
), %ebx
# Load physical address of 32-bit gdt
46 movl
%ebx
, gdtr+
2 # Set up 32-bit gdt address
47 leal kick
(%eax
), %ebx
# Load physical address of flat-mode code
48 movl
%ebx
, target
# Set up entry address
49 movw
%ax
, gdt+
10 # Set base address of 32-bit code segment (bits 0:15)
50 movw
%ax
, gdt+
18 # Set base address of 32-bit data segment (bits 0:15)
52 movb
%al
, gdt+
12 # Set base address of 32-bit code segment (bits 16:23)
53 movb
%al
, gdt+
20 # Set base address of 32-bit data segment (bits 16:23)
54 ADDR32 DATA32 lgdt gdtr
# Load gdt
55 movl
%cr0, %eax
# Enter protected mode
58 ljmp $
0x8, $boot32
# Please note that the %cs segment selector has to have it's base address properly adjusted
61 boot32
: movw $
0x10, %ax
# Setup the temporary 32-bit data selector
63 movw $
0x20, %ax
# Set stack to large 32-bit data segment
65 movl sp
, %esp
# Load stack pointer
66 movl arg3
, %ebx
# Prepare arguments for the C entry point
72 movl ip
, %ebx
# Prepare entry address
75 kick
: mov
%ax
, %ds
# Switch to large data segments
78 call
*%ebx
# Jump to the C entry point