| 
									
										
										
										
											2008-10-22 22:26:29 -07:00
										 |  |  | #ifndef _ASM_X86_BOOTPARAM_H
 | 
					
						
							|  |  |  | #define _ASM_X86_BOOTPARAM_H
 | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-27 10:43:28 -08:00
										 |  |  | /* setup_data types */ | 
					
						
							|  |  |  | #define SETUP_NONE			0
 | 
					
						
							|  |  |  | #define SETUP_E820_EXT			1
 | 
					
						
							|  |  |  | #define SETUP_DTB			2
 | 
					
						
							|  |  |  | #define SETUP_PCI			3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ram_size flags */ | 
					
						
							|  |  |  | #define RAMDISK_IMAGE_START_MASK	0x07FF
 | 
					
						
							|  |  |  | #define RAMDISK_PROMPT_FLAG		0x8000
 | 
					
						
							|  |  |  | #define RAMDISK_LOAD_FLAG		0x4000
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* loadflags */ | 
					
						
							|  |  |  | #define LOADED_HIGH	(1<<0)
 | 
					
						
							|  |  |  | #define QUIET_FLAG	(1<<5)
 | 
					
						
							|  |  |  | #define KEEP_SEGMENTS	(1<<6)
 | 
					
						
							|  |  |  | #define CAN_USE_HEAP	(1<<7)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* xloadflags */ | 
					
						
							|  |  |  | #define XLF_KERNEL_64			(1<<0)
 | 
					
						
							|  |  |  | #define XLF_CAN_BE_LOADED_ABOVE_4G	(1<<1)
 | 
					
						
							|  |  |  | #define XLF_EFI_HANDOVER_32		(1<<2)
 | 
					
						
							|  |  |  | #define XLF_EFI_HANDOVER_64		(1<<3)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __ASSEMBLY__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | #include <linux/types.h>
 | 
					
						
							|  |  |  | #include <linux/screen_info.h>
 | 
					
						
							|  |  |  | #include <linux/apm_bios.h>
 | 
					
						
							|  |  |  | #include <linux/edd.h>
 | 
					
						
							| 
									
										
										
										
											2007-07-18 17:19:30 -07:00
										 |  |  | #include <asm/e820.h>
 | 
					
						
							|  |  |  | #include <asm/ist.h>
 | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | #include <video/edid.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-28 10:49:44 +08:00
										 |  |  | /* extensible setup data list node */ | 
					
						
							|  |  |  | struct setup_data { | 
					
						
							| 
									
										
										
										
											2008-05-02 21:14:20 +10:00
										 |  |  | 	__u64 next; | 
					
						
							|  |  |  | 	__u32 type; | 
					
						
							|  |  |  | 	__u32 len; | 
					
						
							|  |  |  | 	__u8 data[0]; | 
					
						
							| 
									
										
										
										
											2008-03-28 10:49:44 +08:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | struct setup_header { | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u8	setup_sects; | 
					
						
							|  |  |  | 	__u16	root_flags; | 
					
						
							|  |  |  | 	__u32	syssize; | 
					
						
							|  |  |  | 	__u16	ram_size; | 
					
						
							|  |  |  | 	__u16	vid_mode; | 
					
						
							|  |  |  | 	__u16	root_dev; | 
					
						
							|  |  |  | 	__u16	boot_flag; | 
					
						
							|  |  |  | 	__u16	jump; | 
					
						
							|  |  |  | 	__u32	header; | 
					
						
							|  |  |  | 	__u16	version; | 
					
						
							|  |  |  | 	__u32	realmode_swtch; | 
					
						
							|  |  |  | 	__u16	start_sys; | 
					
						
							|  |  |  | 	__u16	kernel_version; | 
					
						
							|  |  |  | 	__u8	type_of_loader; | 
					
						
							|  |  |  | 	__u8	loadflags; | 
					
						
							|  |  |  | 	__u16	setup_move_size; | 
					
						
							|  |  |  | 	__u32	code32_start; | 
					
						
							|  |  |  | 	__u32	ramdisk_image; | 
					
						
							|  |  |  | 	__u32	ramdisk_size; | 
					
						
							|  |  |  | 	__u32	bootsect_kludge; | 
					
						
							|  |  |  | 	__u16	heap_end_ptr; | 
					
						
							| 
									
										
										
										
											2009-05-07 16:54:11 -07:00
										 |  |  | 	__u8	ext_loader_ver; | 
					
						
							|  |  |  | 	__u8	ext_loader_type; | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u32	cmd_line_ptr; | 
					
						
							|  |  |  | 	__u32	initrd_addr_max; | 
					
						
							|  |  |  | 	__u32	kernel_alignment; | 
					
						
							|  |  |  | 	__u8	relocatable_kernel; | 
					
						
							| 
									
										
										
										
											2013-01-27 10:43:28 -08:00
										 |  |  | 	__u8	min_alignment; | 
					
						
							|  |  |  | 	__u16	xloadflags; | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u32	cmdline_size; | 
					
						
							|  |  |  | 	__u32	hardware_subarch; | 
					
						
							|  |  |  | 	__u64	hardware_subarch_data; | 
					
						
							| 
									
										
										
										
											2008-03-28 10:49:44 +08:00
										 |  |  | 	__u32	payload_offset; | 
					
						
							|  |  |  | 	__u32	payload_length; | 
					
						
							|  |  |  | 	__u64	setup_data; | 
					
						
							| 
									
										
										
										
											2011-08-27 09:35:45 +01:00
										 |  |  | 	__u64	pref_address; | 
					
						
							|  |  |  | 	__u32	init_size; | 
					
						
							| 
									
										
										
										
											2012-07-19 10:23:48 +01:00
										 |  |  | 	__u32	handover_offset; | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | } __attribute__((packed)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sys_desc_table { | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u16 length; | 
					
						
							|  |  |  | 	__u8  table[14]; | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-18 17:46:53 -04:00
										 |  |  | /* Gleaned from OFW's set-parameters in cpu/x86/pc/linux.fth */ | 
					
						
							|  |  |  | struct olpc_ofw_header { | 
					
						
							|  |  |  | 	__u32 ofw_magic;	/* OFW signature */ | 
					
						
							|  |  |  | 	__u32 ofw_version; | 
					
						
							|  |  |  | 	__u32 cif_handler;	/* callback into OFW */ | 
					
						
							|  |  |  | 	__u32 irq_desc_table; | 
					
						
							|  |  |  | } __attribute__((packed)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | struct efi_info { | 
					
						
							| 
									
										
										
										
											2008-01-30 13:31:19 +01:00
										 |  |  | 	__u32 efi_loader_signature; | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u32 efi_systab; | 
					
						
							|  |  |  | 	__u32 efi_memdesc_size; | 
					
						
							|  |  |  | 	__u32 efi_memdesc_version; | 
					
						
							|  |  |  | 	__u32 efi_memmap; | 
					
						
							|  |  |  | 	__u32 efi_memmap_size; | 
					
						
							| 
									
										
										
										
											2008-01-30 13:31:19 +01:00
										 |  |  | 	__u32 efi_systab_hi; | 
					
						
							|  |  |  | 	__u32 efi_memmap_hi; | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The so-called "zeropage" */ | 
					
						
							|  |  |  | struct boot_params { | 
					
						
							|  |  |  | 	struct screen_info screen_info;			/* 0x000 */ | 
					
						
							|  |  |  | 	struct apm_bios_info apm_bios_info;		/* 0x040 */ | 
					
						
							| 
									
										
											  
											
												x86, intel_txt: Intel TXT boot support
This patch adds kernel configuration and boot support for Intel Trusted
Execution Technology (Intel TXT).
Intel's technology for safer computing, Intel Trusted Execution
Technology (Intel TXT), defines platform-level enhancements that
provide the building blocks for creating trusted platforms.
Intel TXT was formerly known by the code name LaGrande Technology (LT).
Intel TXT in Brief:
o  Provides dynamic root of trust for measurement (DRTM)
o  Data protection in case of improper shutdown
o  Measurement and verification of launched environment
Intel TXT is part of the vPro(TM) brand and is also available some
non-vPro systems.  It is currently available on desktop systems based on
the Q35, X38, Q45, and Q43 Express chipsets (e.g. Dell Optiplex 755, HP
dc7800, etc.) and mobile systems based on the GM45, PM45, and GS45
Express chipsets.
For more information, see http://www.intel.com/technology/security/.
This site also has a link to the Intel TXT MLE Developers Manual, which
has been updated for the new released platforms.
A much more complete description of how these patches support TXT, how to
configure a system for it, etc. is in the Documentation/intel_txt.txt file
in this patch.
This patch provides the TXT support routines for complete functionality,
documentation for TXT support and for the changes to the boot_params structure,
and boot detection of a TXT launch.  Attempts to shutdown (reboot, Sx) the system
will result in platform resets; subsequent patches will support these shutdown modes
properly.
 Documentation/intel_txt.txt      |  210 +++++++++++++++++++++
 Documentation/x86/zero-page.txt  |    1
 arch/x86/include/asm/bootparam.h |    3
 arch/x86/include/asm/fixmap.h    |    3
 arch/x86/include/asm/tboot.h     |  197 ++++++++++++++++++++
 arch/x86/kernel/Makefile         |    1
 arch/x86/kernel/setup.c          |    4
 arch/x86/kernel/tboot.c          |  379 +++++++++++++++++++++++++++++++++++++++
 security/Kconfig                 |   30 +++
 9 files changed, 827 insertions(+), 1 deletion(-)
Signed-off-by: Joseph Cihula <joseph.cihula@intel.com>
Signed-off-by: Shane Wang <shane.wang@intel.com>
Signed-off-by: Gang Wei <gang.wei@intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
											
										 
											2009-06-30 19:30:59 -07:00
										 |  |  | 	__u8  _pad2[4];					/* 0x054 */ | 
					
						
							|  |  |  | 	__u64  tboot_addr;				/* 0x058 */ | 
					
						
							| 
									
										
										
										
											2007-07-18 17:19:30 -07:00
										 |  |  | 	struct ist_info ist_info;			/* 0x060 */ | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u8  _pad3[16];				/* 0x070 */ | 
					
						
							|  |  |  | 	__u8  hd0_info[16];	/* obsolete! */		/* 0x080 */ | 
					
						
							|  |  |  | 	__u8  hd1_info[16];	/* obsolete! */		/* 0x090 */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 	struct sys_desc_table sys_desc_table;		/* 0x0a0 */ | 
					
						
							| 
									
										
										
										
											2010-06-18 17:46:53 -04:00
										 |  |  | 	struct olpc_ofw_header olpc_ofw_header;		/* 0x0b0 */ | 
					
						
							| 
									
										
										
										
											2013-01-27 10:43:28 -08:00
										 |  |  | 	__u32 ext_ramdisk_image;			/* 0x0c0 */ | 
					
						
							|  |  |  | 	__u32 ext_ramdisk_size;				/* 0x0c4 */ | 
					
						
							|  |  |  | 	__u32 ext_cmd_line_ptr;				/* 0x0c8 */ | 
					
						
							|  |  |  | 	__u8  _pad4[116];				/* 0x0cc */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 	struct edid_info edid_info;			/* 0x140 */ | 
					
						
							|  |  |  | 	struct efi_info efi_info;			/* 0x1c0 */ | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u32 alt_mem_k;				/* 0x1e0 */ | 
					
						
							|  |  |  | 	__u32 scratch;		/* Scratch field! */	/* 0x1e4 */ | 
					
						
							|  |  |  | 	__u8  e820_entries;				/* 0x1e8 */ | 
					
						
							|  |  |  | 	__u8  eddbuf_entries;				/* 0x1e9 */ | 
					
						
							|  |  |  | 	__u8  edd_mbr_sig_buf_entries;			/* 0x1ea */ | 
					
						
							| 
									
										
										
										
											2012-04-13 21:08:26 +02:00
										 |  |  | 	__u8  kbd_status;				/* 0x1eb */ | 
					
						
							| 
									
										
										
										
											2013-01-27 10:43:28 -08:00
										 |  |  | 	__u8  _pad5[3];					/* 0x1ec */ | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * The sentinel is set to a nonzero value (0xff) in header.S. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * A bootloader is supposed to only take setup_header and put | 
					
						
							|  |  |  | 	 * it into a clean boot_params buffer. If it turns out that | 
					
						
							|  |  |  | 	 * it is clumsy or too generous with the buffer, it most | 
					
						
							|  |  |  | 	 * probably will pick up the sentinel variable too. The fact | 
					
						
							|  |  |  | 	 * that this variable then is still 0xff will let kernel | 
					
						
							|  |  |  | 	 * know that some variables in boot_params are invalid and | 
					
						
							|  |  |  | 	 * kernel should zero out certain portions of boot_params. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	__u8  sentinel;					/* 0x1ef */ | 
					
						
							|  |  |  | 	__u8  _pad6[1];					/* 0x1f0 */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 	struct setup_header hdr;    /* setup header */	/* 0x1f1 */ | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u8  _pad7[0x290-0x1f1-sizeof(struct setup_header)]; | 
					
						
							|  |  |  | 	__u32 edd_mbr_sig_buffer[EDD_MBR_SIG_MAX];	/* 0x290 */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 	struct e820entry e820_map[E820MAX];		/* 0x2d0 */ | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u8  _pad8[48];				/* 0xcd0 */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | 	struct edd_info eddbuf[EDDMAXNR];		/* 0xd00 */ | 
					
						
							| 
									
										
										
										
											2007-10-22 10:56:19 +10:00
										 |  |  | 	__u8  _pad9[276];				/* 0xeec */ | 
					
						
							| 
									
										
										
										
											2007-07-11 12:18:35 -07:00
										 |  |  | } __attribute__((packed)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 14:52:47 -07:00
										 |  |  | enum { | 
					
						
							|  |  |  | 	X86_SUBARCH_PC = 0, | 
					
						
							|  |  |  | 	X86_SUBARCH_LGUEST, | 
					
						
							|  |  |  | 	X86_SUBARCH_XEN, | 
					
						
							|  |  |  | 	X86_SUBARCH_MRST, | 
					
						
							| 
									
										
										
										
											2010-11-09 12:08:04 -08:00
										 |  |  | 	X86_SUBARCH_CE4100, | 
					
						
							| 
									
										
										
										
											2009-08-28 14:52:47 -07:00
										 |  |  | 	X86_NR_SUBARCHS, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-27 10:43:28 -08:00
										 |  |  | #endif /* __ASSEMBLY__ */
 | 
					
						
							| 
									
										
										
										
											2009-08-28 14:52:47 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:26:29 -07:00
										 |  |  | #endif /* _ASM_X86_BOOTPARAM_H */
 |