blob: b2988c0ed82961c043b682d44b829c6db00a1e46 [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
Andy Lutomirski5ff3e2c2016-08-10 02:29:16 -070061static inline size_t real_mode_size_needed(void)
62{
63 if (real_mode_header)
64 return 0; /* already allocated. */
65
66 return ALIGN(real_mode_blob_end - real_mode_blob, PAGE_SIZE);
67}
68
69void set_real_mode_mem(phys_addr_t mem, size_t size);
Yinghai Lu4f7b92262013-01-24 12:19:51 -080070void reserve_real_mode(void);
Jarkko Sakkinen084ee1c62012-05-08 21:22:26 +030071
72#endif /* _ARCH_X86_REALMODE_H */