2
* GRUB -- GRand Unified Bootloader
3
* Copyright (C) 2009,2010 Free Software Foundation, Inc.
5
* GRUB is free software: you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License as published by
7
* the Free Software Foundation, either version 3 of the License, or
8
* (at your option) any later version.
10
* GRUB is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
19
#define CODE32_SEGMENT 0x18
20
#define CODE_SEGMENT 0x08
22
/* The data segment of the protected mode. */
23
#define DATA_SEGMENT 0x10
25
#include "relocator_common.S"
27
.p2align 4 /* force 16-byte alignment */
29
VARIABLE(grub_relocator64_start)
36
orl $(GRUB_MEMORY_CPU_CR4_PAE_ON | GRUB_MEMORY_CPU_CR4_PSE_ON), %eax
41
VARIABLE(grub_relocator64_cr3)
46
movl $GRUB_MEMORY_CPU_AMD64_MSR, %ecx
48
orl $GRUB_MEMORY_CPU_AMD64_MSR_ON, %eax
53
orl $GRUB_MEMORY_CPU_CR0_PAGING_ON, %eax
61
VARIABLE(grub_relocator64_cr3)
71
VARIABLE(grub_relocator64_rsp)
79
VARIABLE(grub_relocator64_rsi)
87
VARIABLE(grub_relocator64_rax)
93
VARIABLE(grub_relocator64_rbx)
99
VARIABLE(grub_relocator64_rcx)
102
/* mov imm64, %rdx */
105
VARIABLE(grub_relocator64_rdx)
108
/* Cleared direction flag is of no problem with any current
109
payload and makes this implementation easier. */
112
jmp *LOCAL(jump_addr) (%rip)
115
VARIABLE(grub_relocator64_rip)
122
.byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
124
/* 64-bit segment. */
125
.word 0xffff /* Limit xffff. */
126
.word 0x0000 /* Base xxxx0000. */
127
.byte 0x00 /* Base xx00xxxx. */
128
.byte (0x8 /* Type 8. */ | (1 << 4) /* Code. */ \
129
| (0 << 5) /* Ring 0. */ | (1 << 7) /* Present. */)
130
.byte (0xf /* Limit fxxxx. */ | (0 << 4) /* AVL flag. */ \
131
| (1 << 5) /* 64-bit. */ | (0 << 6) \
132
| (1 << 7) /* 4K granular. */)
133
.byte 0x00 /* Base 00xxxxxx. */
136
.word 0xffff /* Limit xffff. */
137
.word 0x0000 /* Base xxxx0000. */
138
.byte 0x00 /* Base xx00xxxx. */
139
.byte (0x0 /* Type 0. */ | (0 << 4) /* Data. */ \
140
| (0 << 5) /* Ring 0. */ | (1 << 7) /* Present. */)
141
.byte (0xf /* Limit fxxxx. */ | (0 << 4) /* AVL flag. */ \
142
| (0 << 5) /* Data. */ | (0 << 6) \
143
| (1 << 7) /* 4K granular. */)
144
.byte 0x00 /* Base 00xxxxxx. */
146
/* Compatibility segment. */
147
.word 0xffff /* Limit xffff. */
148
.word 0x0000 /* Base xxxx0000. */
149
.byte 0x00 /* Base xx00xxxx. */
150
.byte (0x8 /* Type 8. */ | (1 << 4) /* Code. */ \
151
| (0 << 5) /* Ring 0. */ | (1 << 7) /* Present. */)
152
.byte (0xf /* Limit fxxxx. */ | (0 << 4) /* AVL flag. */ \
153
| (0 << 5) /* 32-bit. */ | (1 << 6) /* 32-bit. */ \
154
| (1 << 7) /* 4K granular. */)
155
.byte 0x00 /* Base 00xxxxxx. */
160
VARIABLE(grub_relocator64_end)