blob: 9c6b890d5e7a0733ed7e92f1d3f1b1aa81bd349f [file] [log] [blame]
Jarkko Sakkinen084ee1c62012-05-08 21:22:26 +03001#ifndef _ARCH_X86_REALMODE_H
2#define _ARCH_X86_REALMODE_H
3
4#include <linux/types.h>
5#include <asm/io.h>
6
7/* This must match data at realmode.S */
8struct real_mode_header {
9 u32 text_start;
10 u32 ro_end;
Jarkko Sakkinen48927bb2012-05-08 21:22:28 +030011 /* SMP trampoline */
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030012 u32 trampoline_start;
Jarkko Sakkinen48927bb2012-05-08 21:22:28 +030013 u32 trampoline_status;
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030014 u32 trampoline_header;
15#ifdef CONFIG_X86_64
16 u32 trampoline_pgd;
Jarkko Sakkinen48927bb2012-05-08 21:22:28 +030017#endif
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030018 /* ACPI S3 wakeup */
Jarkko Sakkinenc9b77cc2012-05-08 21:22:29 +030019#ifdef CONFIG_ACPI_SLEEP
20 u32 wakeup_start;
21 u32 wakeup_header;
22#endif
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030023 /* APM/BIOS reboot */
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030024 u32 machine_real_restart_asm;
H. Peter Anvin65051392012-06-16 21:47:37 -070025#ifdef CONFIG_X86_64
26 u32 machine_real_restart_seg;
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030027#endif
Jarkko Sakkinencda846f2012-05-08 21:22:46 +030028};
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030029
30/* This must match data at trampoline_32/64.S */
31struct trampoline_header {
32#ifdef CONFIG_X86_32
33 u32 start;
Jarkko Sakkinencda846f2012-05-08 21:22:46 +030034 u16 gdt_pad;
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030035 u16 gdt_limit;
36 u32 gdt_base;
37#else
38 u64 start;
H. Peter Anvin638d9572012-05-16 14:02:05 -070039 u64 efer;
Jarkko Sakkinencda846f2012-05-08 21:22:46 +030040 u32 cr4;
Jarkko Sakkinenf37240f2012-05-08 21:22:43 +030041#endif
Jarkko Sakkinencda846f2012-05-08 21:22:46 +030042};
Jarkko Sakkinen084ee1c62012-05-08 21:22:26 +030043
Jarkko Sakkinenb429dbf2012-05-08 21:22:41 +030044extern struct real_mode_header *real_mode_header;
45extern unsigned char real_mode_blob_end[];
Jarkko Sakkinen084ee1c62012-05-08 21:22:26 +030046
47extern unsigned long init_rsp;
48extern unsigned long initial_code;
49extern unsigned long initial_gs;
50
51extern unsigned char real_mode_blob[];
52extern unsigned char real_mode_relocs[];
53
Jarkko Sakkinen48927bb2012-05-08 21:22:28 +030054#ifdef CONFIG_X86_32
55extern unsigned char startup_32_smp[];
56extern unsigned char boot_gdt[];
57#else
58extern unsigned char secondary_startup_64[];
59#endif
60
Yinghai Lu4f7b92262013-01-24 12:19:51 -080061void reserve_real_mode(void);
62void setup_real_mode(void);
Jarkko Sakkinen084ee1c62012-05-08 21:22:26 +030063
64#endif /* _ARCH_X86_REALMODE_H */