| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _LINUX_EFI_H | 
|  | 2 | #define _LINUX_EFI_H | 
|  | 3 |  | 
|  | 4 | /* | 
|  | 5 | * Extensible Firmware Interface | 
|  | 6 | * Based on 'Extensible Firmware Interface Specification' version 0.9, April 30, 1999 | 
|  | 7 | * | 
|  | 8 | * Copyright (C) 1999 VA Linux Systems | 
|  | 9 | * Copyright (C) 1999 Walt Drummond <drummond@valinux.com> | 
|  | 10 | * Copyright (C) 1999, 2002-2003 Hewlett-Packard Co. | 
|  | 11 | *	David Mosberger-Tang <davidm@hpl.hp.com> | 
|  | 12 | *	Stephane Eranian <eranian@hpl.hp.com> | 
|  | 13 | */ | 
|  | 14 | #include <linux/init.h> | 
|  | 15 | #include <linux/string.h> | 
|  | 16 | #include <linux/time.h> | 
|  | 17 | #include <linux/types.h> | 
|  | 18 | #include <linux/proc_fs.h> | 
|  | 19 | #include <linux/rtc.h> | 
|  | 20 | #include <linux/ioport.h> | 
| Huang, Ying | 4a3575f | 2008-02-25 15:18:37 +0800 | [diff] [blame] | 21 | #include <linux/pfn.h> | 
| Matthew Garrett | 5ee9c19 | 2011-07-21 16:57:56 -0400 | [diff] [blame] | 22 | #include <linux/pstore.h> | 
| Matt Fleming | 60863c0 | 2016-02-29 20:30:39 +0000 | [diff] [blame] | 23 | #include <linux/range.h> | 
| Matt Fleming | 8562c99 | 2014-06-13 12:22:22 +0100 | [diff] [blame] | 24 | #include <linux/reboot.h> | 
| Andy Shevchenko | ba7e34b | 2016-05-20 17:01:18 -0700 | [diff] [blame] | 25 | #include <linux/uuid.h> | 
| Ard Biesheuvel | 2c23b73 | 2016-04-25 21:06:48 +0100 | [diff] [blame] | 26 | #include <linux/screen_info.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 |  | 
|  | 28 | #include <asm/page.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 29 |  | 
|  | 30 | #define EFI_SUCCESS		0 | 
|  | 31 | #define EFI_LOAD_ERROR          ( 1 | (1UL << (BITS_PER_LONG-1))) | 
|  | 32 | #define EFI_INVALID_PARAMETER	( 2 | (1UL << (BITS_PER_LONG-1))) | 
|  | 33 | #define EFI_UNSUPPORTED		( 3 | (1UL << (BITS_PER_LONG-1))) | 
|  | 34 | #define EFI_BAD_BUFFER_SIZE     ( 4 | (1UL << (BITS_PER_LONG-1))) | 
|  | 35 | #define EFI_BUFFER_TOO_SMALL	( 5 | (1UL << (BITS_PER_LONG-1))) | 
| Matthew Garrett | 5d9db88 | 2012-10-05 13:54:56 +0800 | [diff] [blame] | 36 | #define EFI_NOT_READY		( 6 | (1UL << (BITS_PER_LONG-1))) | 
|  | 37 | #define EFI_DEVICE_ERROR	( 7 | (1UL << (BITS_PER_LONG-1))) | 
|  | 38 | #define EFI_WRITE_PROTECTED	( 8 | (1UL << (BITS_PER_LONG-1))) | 
|  | 39 | #define EFI_OUT_OF_RESOURCES	( 9 | (1UL << (BITS_PER_LONG-1))) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | #define EFI_NOT_FOUND		(14 | (1UL << (BITS_PER_LONG-1))) | 
| Ard Biesheuvel | dce48e3 | 2016-07-15 21:36:31 +0200 | [diff] [blame] | 41 | #define EFI_ABORTED		(21 | (1UL << (BITS_PER_LONG-1))) | 
| Matthew Garrett | 5d9db88 | 2012-10-05 13:54:56 +0800 | [diff] [blame] | 42 | #define EFI_SECURITY_VIOLATION	(26 | (1UL << (BITS_PER_LONG-1))) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 |  | 
|  | 44 | typedef unsigned long efi_status_t; | 
|  | 45 | typedef u8 efi_bool_t; | 
|  | 46 | typedef u16 efi_char16_t;		/* UNICODE character */ | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 47 | typedef u64 efi_physical_addr_t; | 
|  | 48 | typedef void *efi_handle_t; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 49 |  | 
| Andy Shevchenko | ba7e34b | 2016-05-20 17:01:18 -0700 | [diff] [blame] | 50 | typedef uuid_le efi_guid_t; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 |  | 
|  | 52 | #define EFI_GUID(a,b,c,d0,d1,d2,d3,d4,d5,d6,d7) \ | 
| Andy Shevchenko | ba7e34b | 2016-05-20 17:01:18 -0700 | [diff] [blame] | 53 | UUID_LE(a, b, c, d0, d1, d2, d3, d4, d5, d6, d7) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 |  | 
|  | 55 | /* | 
|  | 56 | * Generic EFI table header | 
|  | 57 | */ | 
|  | 58 | typedef	struct { | 
|  | 59 | u64 signature; | 
|  | 60 | u32 revision; | 
|  | 61 | u32 headersize; | 
|  | 62 | u32 crc32; | 
|  | 63 | u32 reserved; | 
|  | 64 | } efi_table_hdr_t; | 
|  | 65 |  | 
|  | 66 | /* | 
|  | 67 | * Memory map descriptor: | 
|  | 68 | */ | 
|  | 69 |  | 
|  | 70 | /* Memory types: */ | 
|  | 71 | #define EFI_RESERVED_TYPE		 0 | 
|  | 72 | #define EFI_LOADER_CODE			 1 | 
|  | 73 | #define EFI_LOADER_DATA			 2 | 
|  | 74 | #define EFI_BOOT_SERVICES_CODE		 3 | 
|  | 75 | #define EFI_BOOT_SERVICES_DATA		 4 | 
|  | 76 | #define EFI_RUNTIME_SERVICES_CODE	 5 | 
|  | 77 | #define EFI_RUNTIME_SERVICES_DATA	 6 | 
|  | 78 | #define EFI_CONVENTIONAL_MEMORY		 7 | 
|  | 79 | #define EFI_UNUSABLE_MEMORY		 8 | 
|  | 80 | #define EFI_ACPI_RECLAIM_MEMORY		 9 | 
|  | 81 | #define EFI_ACPI_MEMORY_NVS		10 | 
|  | 82 | #define EFI_MEMORY_MAPPED_IO		11 | 
|  | 83 | #define EFI_MEMORY_MAPPED_IO_PORT_SPACE	12 | 
|  | 84 | #define EFI_PAL_CODE			13 | 
| Dan Williams | ad5fb87 | 2015-04-03 12:05:28 -0400 | [diff] [blame] | 85 | #define EFI_PERSISTENT_MEMORY		14 | 
|  | 86 | #define EFI_MAX_MEMORY_TYPE		15 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 87 |  | 
|  | 88 | /* Attribute values: */ | 
|  | 89 | #define EFI_MEMORY_UC		((u64)0x0000000000000001ULL)	/* uncached */ | 
|  | 90 | #define EFI_MEMORY_WC		((u64)0x0000000000000002ULL)	/* write-coalescing */ | 
|  | 91 | #define EFI_MEMORY_WT		((u64)0x0000000000000004ULL)	/* write-through */ | 
|  | 92 | #define EFI_MEMORY_WB		((u64)0x0000000000000008ULL)	/* write-back */ | 
| Laszlo Ersek | 9c97e0b | 2014-09-03 13:32:19 +0200 | [diff] [blame] | 93 | #define EFI_MEMORY_UCE		((u64)0x0000000000000010ULL)	/* uncached, exported */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | #define EFI_MEMORY_WP		((u64)0x0000000000001000ULL)	/* write-protect */ | 
|  | 95 | #define EFI_MEMORY_RP		((u64)0x0000000000002000ULL)	/* read-protect */ | 
|  | 96 | #define EFI_MEMORY_XP		((u64)0x0000000000004000ULL)	/* execute-protect */ | 
| Robert Elliott | c016ca0 | 2016-02-01 22:07:06 +0000 | [diff] [blame] | 97 | #define EFI_MEMORY_NV		((u64)0x0000000000008000ULL)	/* non-volatile */ | 
| Tony Luck | b05b9f5 | 2015-06-24 16:58:15 -0700 | [diff] [blame] | 98 | #define EFI_MEMORY_MORE_RELIABLE \ | 
|  | 99 | ((u64)0x0000000000010000ULL)	/* higher reliability */ | 
| Ard Biesheuvel | 87db73ae | 2015-08-07 09:36:54 +0100 | [diff] [blame] | 100 | #define EFI_MEMORY_RO		((u64)0x0000000000020000ULL)	/* read-only */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 101 | #define EFI_MEMORY_RUNTIME	((u64)0x8000000000000000ULL)	/* range requires runtime mapping */ | 
|  | 102 | #define EFI_MEMORY_DESCRIPTOR_VERSION	1 | 
|  | 103 |  | 
|  | 104 | #define EFI_PAGE_SHIFT		12 | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 105 | #define EFI_PAGE_SIZE		(1UL << EFI_PAGE_SHIFT) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 106 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 107 | typedef struct { | 
|  | 108 | u32 type; | 
|  | 109 | u32 pad; | 
|  | 110 | u64 phys_addr; | 
|  | 111 | u64 virt_addr; | 
|  | 112 | u64 num_pages; | 
|  | 113 | u64 attribute; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 114 | } efi_memory_desc_t; | 
|  | 115 |  | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 116 | typedef struct { | 
|  | 117 | efi_guid_t guid; | 
|  | 118 | u32 headersize; | 
|  | 119 | u32 flags; | 
|  | 120 | u32 imagesize; | 
|  | 121 | } efi_capsule_header_t; | 
|  | 122 |  | 
| Jeffrey Hugo | dadb57a | 2016-08-29 14:38:51 -0600 | [diff] [blame] | 123 | struct efi_boot_memmap { | 
|  | 124 | efi_memory_desc_t	**map; | 
|  | 125 | unsigned long		*map_size; | 
|  | 126 | unsigned long		*desc_size; | 
|  | 127 | u32			*desc_ver; | 
|  | 128 | unsigned long		*key_ptr; | 
|  | 129 | unsigned long		*buff_size; | 
|  | 130 | }; | 
|  | 131 |  | 
| Matt Fleming | bb05e4b | 2011-11-15 12:57:03 +0000 | [diff] [blame] | 132 | /* | 
| Matt Fleming | f0133f3 | 2016-04-25 21:06:59 +0100 | [diff] [blame] | 133 | * EFI capsule flags | 
|  | 134 | */ | 
|  | 135 | #define EFI_CAPSULE_PERSIST_ACROSS_RESET	0x00010000 | 
|  | 136 | #define EFI_CAPSULE_POPULATE_SYSTEM_TABLE	0x00020000 | 
|  | 137 | #define EFI_CAPSULE_INITIATE_RESET		0x00040000 | 
|  | 138 |  | 
|  | 139 | /* | 
| Matt Fleming | bb05e4b | 2011-11-15 12:57:03 +0000 | [diff] [blame] | 140 | * Allocation types for calls to boottime->allocate_pages. | 
|  | 141 | */ | 
|  | 142 | #define EFI_ALLOCATE_ANY_PAGES		0 | 
|  | 143 | #define EFI_ALLOCATE_MAX_ADDRESS	1 | 
|  | 144 | #define EFI_ALLOCATE_ADDRESS		2 | 
|  | 145 | #define EFI_MAX_ALLOCATE_TYPE		3 | 
|  | 146 |  | 
| Matthew Wilcox | e088a4a | 2009-05-22 13:49:49 -0700 | [diff] [blame] | 147 | typedef int (*efi_freemem_callback_t) (u64 start, u64 end, void *arg); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 148 |  | 
|  | 149 | /* | 
|  | 150 | * Types and defines for Time Services | 
|  | 151 | */ | 
|  | 152 | #define EFI_TIME_ADJUST_DAYLIGHT 0x1 | 
|  | 153 | #define EFI_TIME_IN_DAYLIGHT     0x2 | 
|  | 154 | #define EFI_UNSPECIFIED_TIMEZONE 0x07ff | 
|  | 155 |  | 
|  | 156 | typedef struct { | 
|  | 157 | u16 year; | 
|  | 158 | u8 month; | 
|  | 159 | u8 day; | 
|  | 160 | u8 hour; | 
|  | 161 | u8 minute; | 
|  | 162 | u8 second; | 
|  | 163 | u8 pad1; | 
|  | 164 | u32 nanosecond; | 
|  | 165 | s16 timezone; | 
|  | 166 | u8 daylight; | 
|  | 167 | u8 pad2; | 
|  | 168 | } efi_time_t; | 
|  | 169 |  | 
|  | 170 | typedef struct { | 
|  | 171 | u32 resolution; | 
|  | 172 | u32 accuracy; | 
|  | 173 | u8 sets_to_zero; | 
|  | 174 | } efi_time_cap_t; | 
|  | 175 |  | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 176 | typedef struct { | 
|  | 177 | efi_table_hdr_t hdr; | 
|  | 178 | u32 raise_tpl; | 
|  | 179 | u32 restore_tpl; | 
|  | 180 | u32 allocate_pages; | 
|  | 181 | u32 free_pages; | 
|  | 182 | u32 get_memory_map; | 
|  | 183 | u32 allocate_pool; | 
|  | 184 | u32 free_pool; | 
|  | 185 | u32 create_event; | 
|  | 186 | u32 set_timer; | 
|  | 187 | u32 wait_for_event; | 
|  | 188 | u32 signal_event; | 
|  | 189 | u32 close_event; | 
|  | 190 | u32 check_event; | 
|  | 191 | u32 install_protocol_interface; | 
|  | 192 | u32 reinstall_protocol_interface; | 
|  | 193 | u32 uninstall_protocol_interface; | 
|  | 194 | u32 handle_protocol; | 
|  | 195 | u32 __reserved; | 
|  | 196 | u32 register_protocol_notify; | 
|  | 197 | u32 locate_handle; | 
|  | 198 | u32 locate_device_path; | 
|  | 199 | u32 install_configuration_table; | 
|  | 200 | u32 load_image; | 
|  | 201 | u32 start_image; | 
|  | 202 | u32 exit; | 
|  | 203 | u32 unload_image; | 
|  | 204 | u32 exit_boot_services; | 
|  | 205 | u32 get_next_monotonic_count; | 
|  | 206 | u32 stall; | 
|  | 207 | u32 set_watchdog_timer; | 
|  | 208 | u32 connect_controller; | 
|  | 209 | u32 disconnect_controller; | 
|  | 210 | u32 open_protocol; | 
|  | 211 | u32 close_protocol; | 
|  | 212 | u32 open_protocol_information; | 
|  | 213 | u32 protocols_per_handle; | 
|  | 214 | u32 locate_handle_buffer; | 
|  | 215 | u32 locate_protocol; | 
|  | 216 | u32 install_multiple_protocol_interfaces; | 
|  | 217 | u32 uninstall_multiple_protocol_interfaces; | 
|  | 218 | u32 calculate_crc32; | 
|  | 219 | u32 copy_mem; | 
|  | 220 | u32 set_mem; | 
|  | 221 | u32 create_event_ex; | 
|  | 222 | } __packed efi_boot_services_32_t; | 
|  | 223 |  | 
|  | 224 | typedef struct { | 
|  | 225 | efi_table_hdr_t hdr; | 
|  | 226 | u64 raise_tpl; | 
|  | 227 | u64 restore_tpl; | 
|  | 228 | u64 allocate_pages; | 
|  | 229 | u64 free_pages; | 
|  | 230 | u64 get_memory_map; | 
|  | 231 | u64 allocate_pool; | 
|  | 232 | u64 free_pool; | 
|  | 233 | u64 create_event; | 
|  | 234 | u64 set_timer; | 
|  | 235 | u64 wait_for_event; | 
|  | 236 | u64 signal_event; | 
|  | 237 | u64 close_event; | 
|  | 238 | u64 check_event; | 
|  | 239 | u64 install_protocol_interface; | 
|  | 240 | u64 reinstall_protocol_interface; | 
|  | 241 | u64 uninstall_protocol_interface; | 
|  | 242 | u64 handle_protocol; | 
|  | 243 | u64 __reserved; | 
|  | 244 | u64 register_protocol_notify; | 
|  | 245 | u64 locate_handle; | 
|  | 246 | u64 locate_device_path; | 
|  | 247 | u64 install_configuration_table; | 
|  | 248 | u64 load_image; | 
|  | 249 | u64 start_image; | 
|  | 250 | u64 exit; | 
|  | 251 | u64 unload_image; | 
|  | 252 | u64 exit_boot_services; | 
|  | 253 | u64 get_next_monotonic_count; | 
|  | 254 | u64 stall; | 
|  | 255 | u64 set_watchdog_timer; | 
|  | 256 | u64 connect_controller; | 
|  | 257 | u64 disconnect_controller; | 
|  | 258 | u64 open_protocol; | 
|  | 259 | u64 close_protocol; | 
|  | 260 | u64 open_protocol_information; | 
|  | 261 | u64 protocols_per_handle; | 
|  | 262 | u64 locate_handle_buffer; | 
|  | 263 | u64 locate_protocol; | 
|  | 264 | u64 install_multiple_protocol_interfaces; | 
|  | 265 | u64 uninstall_multiple_protocol_interfaces; | 
|  | 266 | u64 calculate_crc32; | 
|  | 267 | u64 copy_mem; | 
|  | 268 | u64 set_mem; | 
|  | 269 | u64 create_event_ex; | 
|  | 270 | } __packed efi_boot_services_64_t; | 
|  | 271 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 272 | /* | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 273 | * EFI Boot Services table | 
|  | 274 | */ | 
|  | 275 | typedef struct { | 
|  | 276 | efi_table_hdr_t hdr; | 
|  | 277 | void *raise_tpl; | 
|  | 278 | void *restore_tpl; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 279 | efi_status_t (*allocate_pages)(int, int, unsigned long, | 
|  | 280 | efi_physical_addr_t *); | 
|  | 281 | efi_status_t (*free_pages)(efi_physical_addr_t, unsigned long); | 
|  | 282 | efi_status_t (*get_memory_map)(unsigned long *, void *, unsigned long *, | 
|  | 283 | unsigned long *, u32 *); | 
|  | 284 | efi_status_t (*allocate_pool)(int, unsigned long, void **); | 
|  | 285 | efi_status_t (*free_pool)(void *); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 286 | void *create_event; | 
|  | 287 | void *set_timer; | 
|  | 288 | void *wait_for_event; | 
|  | 289 | void *signal_event; | 
|  | 290 | void *close_event; | 
|  | 291 | void *check_event; | 
|  | 292 | void *install_protocol_interface; | 
|  | 293 | void *reinstall_protocol_interface; | 
|  | 294 | void *uninstall_protocol_interface; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 295 | efi_status_t (*handle_protocol)(efi_handle_t, efi_guid_t *, void **); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 296 | void *__reserved; | 
|  | 297 | void *register_protocol_notify; | 
| Ard Biesheuvel | fc37206 | 2016-04-25 21:06:49 +0100 | [diff] [blame] | 298 | efi_status_t (*locate_handle)(int, efi_guid_t *, void *, | 
|  | 299 | unsigned long *, efi_handle_t *); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 300 | void *locate_device_path; | 
| Ard Biesheuvel | 801820b | 2016-04-25 21:06:53 +0100 | [diff] [blame] | 301 | efi_status_t (*install_configuration_table)(efi_guid_t *, void *); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 302 | void *load_image; | 
|  | 303 | void *start_image; | 
|  | 304 | void *exit; | 
|  | 305 | void *unload_image; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 306 | efi_status_t (*exit_boot_services)(efi_handle_t, unsigned long); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 307 | void *get_next_monotonic_count; | 
|  | 308 | void *stall; | 
|  | 309 | void *set_watchdog_timer; | 
|  | 310 | void *connect_controller; | 
|  | 311 | void *disconnect_controller; | 
|  | 312 | void *open_protocol; | 
|  | 313 | void *close_protocol; | 
|  | 314 | void *open_protocol_information; | 
|  | 315 | void *protocols_per_handle; | 
|  | 316 | void *locate_handle_buffer; | 
| Ard Biesheuvel | e4fbf47 | 2016-01-10 11:29:07 +0100 | [diff] [blame] | 317 | efi_status_t (*locate_protocol)(efi_guid_t *, void *, void **); | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 318 | void *install_multiple_protocol_interfaces; | 
|  | 319 | void *uninstall_multiple_protocol_interfaces; | 
|  | 320 | void *calculate_crc32; | 
|  | 321 | void *copy_mem; | 
|  | 322 | void *set_mem; | 
|  | 323 | void *create_event_ex; | 
|  | 324 | } efi_boot_services_t; | 
|  | 325 |  | 
| Matthew Garrett | dd5fc85 | 2012-12-05 14:33:26 -0700 | [diff] [blame] | 326 | typedef enum { | 
|  | 327 | EfiPciIoWidthUint8, | 
|  | 328 | EfiPciIoWidthUint16, | 
|  | 329 | EfiPciIoWidthUint32, | 
|  | 330 | EfiPciIoWidthUint64, | 
|  | 331 | EfiPciIoWidthFifoUint8, | 
|  | 332 | EfiPciIoWidthFifoUint16, | 
|  | 333 | EfiPciIoWidthFifoUint32, | 
|  | 334 | EfiPciIoWidthFifoUint64, | 
|  | 335 | EfiPciIoWidthFillUint8, | 
|  | 336 | EfiPciIoWidthFillUint16, | 
|  | 337 | EfiPciIoWidthFillUint32, | 
|  | 338 | EfiPciIoWidthFillUint64, | 
|  | 339 | EfiPciIoWidthMaximum | 
|  | 340 | } EFI_PCI_IO_PROTOCOL_WIDTH; | 
|  | 341 |  | 
|  | 342 | typedef enum { | 
|  | 343 | EfiPciIoAttributeOperationGet, | 
|  | 344 | EfiPciIoAttributeOperationSet, | 
|  | 345 | EfiPciIoAttributeOperationEnable, | 
|  | 346 | EfiPciIoAttributeOperationDisable, | 
|  | 347 | EfiPciIoAttributeOperationSupported, | 
|  | 348 | EfiPciIoAttributeOperationMaximum | 
|  | 349 | } EFI_PCI_IO_PROTOCOL_ATTRIBUTE_OPERATION; | 
|  | 350 |  | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 351 | typedef struct { | 
|  | 352 | u32 read; | 
|  | 353 | u32 write; | 
|  | 354 | } efi_pci_io_protocol_access_32_t; | 
|  | 355 |  | 
|  | 356 | typedef struct { | 
|  | 357 | u64 read; | 
|  | 358 | u64 write; | 
|  | 359 | } efi_pci_io_protocol_access_64_t; | 
| Matthew Garrett | dd5fc85 | 2012-12-05 14:33:26 -0700 | [diff] [blame] | 360 |  | 
|  | 361 | typedef struct { | 
|  | 362 | void *read; | 
|  | 363 | void *write; | 
|  | 364 | } efi_pci_io_protocol_access_t; | 
|  | 365 |  | 
|  | 366 | typedef struct { | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 367 | u32 poll_mem; | 
|  | 368 | u32 poll_io; | 
|  | 369 | efi_pci_io_protocol_access_32_t mem; | 
|  | 370 | efi_pci_io_protocol_access_32_t io; | 
|  | 371 | efi_pci_io_protocol_access_32_t pci; | 
|  | 372 | u32 copy_mem; | 
|  | 373 | u32 map; | 
|  | 374 | u32 unmap; | 
|  | 375 | u32 allocate_buffer; | 
|  | 376 | u32 free_buffer; | 
|  | 377 | u32 flush; | 
|  | 378 | u32 get_location; | 
|  | 379 | u32 attributes; | 
|  | 380 | u32 get_bar_attributes; | 
|  | 381 | u32 set_bar_attributes; | 
|  | 382 | uint64_t romsize; | 
|  | 383 | void *romimage; | 
|  | 384 | } efi_pci_io_protocol_32; | 
|  | 385 |  | 
|  | 386 | typedef struct { | 
|  | 387 | u64 poll_mem; | 
|  | 388 | u64 poll_io; | 
|  | 389 | efi_pci_io_protocol_access_64_t mem; | 
|  | 390 | efi_pci_io_protocol_access_64_t io; | 
|  | 391 | efi_pci_io_protocol_access_64_t pci; | 
|  | 392 | u64 copy_mem; | 
|  | 393 | u64 map; | 
|  | 394 | u64 unmap; | 
|  | 395 | u64 allocate_buffer; | 
|  | 396 | u64 free_buffer; | 
|  | 397 | u64 flush; | 
|  | 398 | u64 get_location; | 
|  | 399 | u64 attributes; | 
|  | 400 | u64 get_bar_attributes; | 
|  | 401 | u64 set_bar_attributes; | 
|  | 402 | uint64_t romsize; | 
|  | 403 | void *romimage; | 
|  | 404 | } efi_pci_io_protocol_64; | 
|  | 405 |  | 
|  | 406 | typedef struct { | 
| Matthew Garrett | dd5fc85 | 2012-12-05 14:33:26 -0700 | [diff] [blame] | 407 | void *poll_mem; | 
|  | 408 | void *poll_io; | 
|  | 409 | efi_pci_io_protocol_access_t mem; | 
|  | 410 | efi_pci_io_protocol_access_t io; | 
|  | 411 | efi_pci_io_protocol_access_t pci; | 
|  | 412 | void *copy_mem; | 
|  | 413 | void *map; | 
|  | 414 | void *unmap; | 
|  | 415 | void *allocate_buffer; | 
|  | 416 | void *free_buffer; | 
|  | 417 | void *flush; | 
|  | 418 | void *get_location; | 
|  | 419 | void *attributes; | 
|  | 420 | void *get_bar_attributes; | 
|  | 421 | void *set_bar_attributes; | 
|  | 422 | uint64_t romsize; | 
|  | 423 | void *romimage; | 
|  | 424 | } efi_pci_io_protocol; | 
|  | 425 |  | 
|  | 426 | #define EFI_PCI_IO_ATTRIBUTE_ISA_MOTHERBOARD_IO 0x0001 | 
|  | 427 | #define EFI_PCI_IO_ATTRIBUTE_ISA_IO 0x0002 | 
|  | 428 | #define EFI_PCI_IO_ATTRIBUTE_VGA_PALETTE_IO 0x0004 | 
|  | 429 | #define EFI_PCI_IO_ATTRIBUTE_VGA_MEMORY 0x0008 | 
|  | 430 | #define EFI_PCI_IO_ATTRIBUTE_VGA_IO 0x0010 | 
|  | 431 | #define EFI_PCI_IO_ATTRIBUTE_IDE_PRIMARY_IO 0x0020 | 
|  | 432 | #define EFI_PCI_IO_ATTRIBUTE_IDE_SECONDARY_IO 0x0040 | 
|  | 433 | #define EFI_PCI_IO_ATTRIBUTE_MEMORY_WRITE_COMBINE 0x0080 | 
|  | 434 | #define EFI_PCI_IO_ATTRIBUTE_IO 0x0100 | 
|  | 435 | #define EFI_PCI_IO_ATTRIBUTE_MEMORY 0x0200 | 
|  | 436 | #define EFI_PCI_IO_ATTRIBUTE_BUS_MASTER 0x0400 | 
|  | 437 | #define EFI_PCI_IO_ATTRIBUTE_MEMORY_CACHED 0x0800 | 
|  | 438 | #define EFI_PCI_IO_ATTRIBUTE_MEMORY_DISABLE 0x1000 | 
|  | 439 | #define EFI_PCI_IO_ATTRIBUTE_EMBEDDED_DEVICE 0x2000 | 
|  | 440 | #define EFI_PCI_IO_ATTRIBUTE_EMBEDDED_ROM 0x4000 | 
|  | 441 | #define EFI_PCI_IO_ATTRIBUTE_DUAL_ADDRESS_CYCLE 0x8000 | 
|  | 442 | #define EFI_PCI_IO_ATTRIBUTE_ISA_IO_16 0x10000 | 
|  | 443 | #define EFI_PCI_IO_ATTRIBUTE_VGA_PALETTE_IO_16 0x20000 | 
|  | 444 | #define EFI_PCI_IO_ATTRIBUTE_VGA_IO_16 0x40000 | 
|  | 445 |  | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 446 | /* | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 447 | * Types and defines for EFI ResetSystem | 
|  | 448 | */ | 
|  | 449 | #define EFI_RESET_COLD 0 | 
|  | 450 | #define EFI_RESET_WARM 1 | 
|  | 451 | #define EFI_RESET_SHUTDOWN 2 | 
|  | 452 |  | 
|  | 453 | /* | 
|  | 454 | * EFI Runtime Services table | 
|  | 455 | */ | 
|  | 456 | #define EFI_RUNTIME_SERVICES_SIGNATURE ((u64)0x5652453544e5552ULL) | 
|  | 457 | #define EFI_RUNTIME_SERVICES_REVISION  0x00010000 | 
|  | 458 |  | 
|  | 459 | typedef struct { | 
|  | 460 | efi_table_hdr_t hdr; | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 461 | u32 get_time; | 
|  | 462 | u32 set_time; | 
|  | 463 | u32 get_wakeup_time; | 
|  | 464 | u32 set_wakeup_time; | 
|  | 465 | u32 set_virtual_address_map; | 
|  | 466 | u32 convert_pointer; | 
|  | 467 | u32 get_variable; | 
|  | 468 | u32 get_next_variable; | 
|  | 469 | u32 set_variable; | 
|  | 470 | u32 get_next_high_mono_count; | 
|  | 471 | u32 reset_system; | 
|  | 472 | u32 update_capsule; | 
|  | 473 | u32 query_capsule_caps; | 
|  | 474 | u32 query_variable_info; | 
|  | 475 | } efi_runtime_services_32_t; | 
|  | 476 |  | 
|  | 477 | typedef struct { | 
|  | 478 | efi_table_hdr_t hdr; | 
|  | 479 | u64 get_time; | 
|  | 480 | u64 set_time; | 
|  | 481 | u64 get_wakeup_time; | 
|  | 482 | u64 set_wakeup_time; | 
|  | 483 | u64 set_virtual_address_map; | 
|  | 484 | u64 convert_pointer; | 
|  | 485 | u64 get_variable; | 
|  | 486 | u64 get_next_variable; | 
|  | 487 | u64 set_variable; | 
|  | 488 | u64 get_next_high_mono_count; | 
|  | 489 | u64 reset_system; | 
|  | 490 | u64 update_capsule; | 
|  | 491 | u64 query_capsule_caps; | 
|  | 492 | u64 query_variable_info; | 
|  | 493 | } efi_runtime_services_64_t; | 
|  | 494 |  | 
|  | 495 | typedef struct { | 
|  | 496 | efi_table_hdr_t hdr; | 
| Borislav Petkov | 43ab047 | 2013-06-02 14:56:07 +0200 | [diff] [blame] | 497 | void *get_time; | 
|  | 498 | void *set_time; | 
|  | 499 | void *get_wakeup_time; | 
|  | 500 | void *set_wakeup_time; | 
|  | 501 | void *set_virtual_address_map; | 
|  | 502 | void *convert_pointer; | 
|  | 503 | void *get_variable; | 
|  | 504 | void *get_next_variable; | 
|  | 505 | void *set_variable; | 
|  | 506 | void *get_next_high_mono_count; | 
|  | 507 | void *reset_system; | 
|  | 508 | void *update_capsule; | 
|  | 509 | void *query_capsule_caps; | 
|  | 510 | void *query_variable_info; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 511 | } efi_runtime_services_t; | 
|  | 512 |  | 
|  | 513 | typedef efi_status_t efi_get_time_t (efi_time_t *tm, efi_time_cap_t *tc); | 
|  | 514 | typedef efi_status_t efi_set_time_t (efi_time_t *tm); | 
|  | 515 | typedef efi_status_t efi_get_wakeup_time_t (efi_bool_t *enabled, efi_bool_t *pending, | 
|  | 516 | efi_time_t *tm); | 
|  | 517 | typedef efi_status_t efi_set_wakeup_time_t (efi_bool_t enabled, efi_time_t *tm); | 
|  | 518 | typedef efi_status_t efi_get_variable_t (efi_char16_t *name, efi_guid_t *vendor, u32 *attr, | 
|  | 519 | unsigned long *data_size, void *data); | 
|  | 520 | typedef efi_status_t efi_get_next_variable_t (unsigned long *name_size, efi_char16_t *name, | 
|  | 521 | efi_guid_t *vendor); | 
|  | 522 | typedef efi_status_t efi_set_variable_t (efi_char16_t *name, efi_guid_t *vendor, | 
| Matthew Garrett | f7a2d73 | 2011-06-06 15:36:24 -0400 | [diff] [blame] | 523 | u32 attr, unsigned long data_size, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 524 | void *data); | 
|  | 525 | typedef efi_status_t efi_get_next_high_mono_count_t (u32 *count); | 
|  | 526 | typedef void efi_reset_system_t (int reset_type, efi_status_t status, | 
|  | 527 | unsigned long data_size, efi_char16_t *data); | 
|  | 528 | typedef efi_status_t efi_set_virtual_address_map_t (unsigned long memory_map_size, | 
|  | 529 | unsigned long descriptor_size, | 
|  | 530 | u32 descriptor_version, | 
|  | 531 | efi_memory_desc_t *virtual_map); | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 532 | typedef efi_status_t efi_query_variable_info_t(u32 attr, | 
|  | 533 | u64 *storage_space, | 
|  | 534 | u64 *remaining_space, | 
|  | 535 | u64 *max_variable_size); | 
|  | 536 | typedef efi_status_t efi_update_capsule_t(efi_capsule_header_t **capsules, | 
|  | 537 | unsigned long count, | 
|  | 538 | unsigned long sg_list); | 
|  | 539 | typedef efi_status_t efi_query_capsule_caps_t(efi_capsule_header_t **capsules, | 
|  | 540 | unsigned long count, | 
|  | 541 | u64 *max_size, | 
|  | 542 | int *reset_type); | 
| Ard Biesheuvel | ca0e30d | 2016-02-01 22:06:58 +0000 | [diff] [blame] | 543 | typedef efi_status_t efi_query_variable_store_t(u32 attributes, | 
|  | 544 | unsigned long size, | 
|  | 545 | bool nonblocking); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 546 |  | 
| Ard Biesheuvel | 022ee6c | 2014-06-26 12:09:05 +0200 | [diff] [blame] | 547 | void efi_native_runtime_setup(void); | 
|  | 548 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 549 | /* | 
| Peter Jones | 54fd11f | 2016-06-25 08:20:25 +0100 | [diff] [blame] | 550 | * EFI Configuration Table and GUID definitions | 
|  | 551 | * | 
| Ingo Molnar | 7fb2b43 | 2016-06-27 12:49:20 +0200 | [diff] [blame] | 552 | * These are all defined in a single line to make them easier to | 
|  | 553 | * grep for and to see them at a glance - while still having a | 
|  | 554 | * similar structure to the definitions in the spec. | 
|  | 555 | * | 
|  | 556 | * Here's how they are structured: | 
| Peter Jones | 54fd11f | 2016-06-25 08:20:25 +0100 | [diff] [blame] | 557 | * | 
|  | 558 | * GUID: 12345678-1234-1234-1234-123456789012 | 
|  | 559 | * Spec: | 
|  | 560 | *      #define EFI_SOME_PROTOCOL_GUID \ | 
|  | 561 | *        {0x12345678,0x1234,0x1234,\ | 
|  | 562 | *          {0x12,0x34,0x12,0x34,0x56,0x78,0x90,0x12}} | 
|  | 563 | * Here: | 
| Ingo Molnar | 7fb2b43 | 2016-06-27 12:49:20 +0200 | [diff] [blame] | 564 | *	#define SOME_PROTOCOL_GUID		EFI_GUID(0x12345678, 0x1234, 0x1234,  0x12, 0x34, 0x12, 0x34, 0x56, 0x78, 0x90, 0x12) | 
|  | 565 | *					^ tabs					    ^extra space | 
|  | 566 | * | 
|  | 567 | * Note that the 'extra space' separates the values at the same place | 
|  | 568 | * where the UEFI SPEC breaks the line. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 569 | */ | 
| Ingo Molnar | 7fb2b43 | 2016-06-27 12:49:20 +0200 | [diff] [blame] | 570 | #define NULL_GUID				EFI_GUID(0x00000000, 0x0000, 0x0000,  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00) | 
|  | 571 | #define MPS_TABLE_GUID				EFI_GUID(0xeb9d2d2f, 0x2d88, 0x11d3,  0x9a, 0x16, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) | 
|  | 572 | #define ACPI_TABLE_GUID				EFI_GUID(0xeb9d2d30, 0x2d88, 0x11d3,  0x9a, 0x16, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) | 
|  | 573 | #define ACPI_20_TABLE_GUID			EFI_GUID(0x8868e871, 0xe4f1, 0x11d3,  0xbc, 0x22, 0x00, 0x80, 0xc7, 0x3c, 0x88, 0x81) | 
|  | 574 | #define SMBIOS_TABLE_GUID			EFI_GUID(0xeb9d2d31, 0x2d88, 0x11d3,  0x9a, 0x16, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) | 
|  | 575 | #define SMBIOS3_TABLE_GUID			EFI_GUID(0xf2fd1544, 0x9794, 0x4a2c,  0x99, 0x2e, 0xe5, 0xbb, 0xcf, 0x20, 0xe3, 0x94) | 
|  | 576 | #define SAL_SYSTEM_TABLE_GUID			EFI_GUID(0xeb9d2d32, 0x2d88, 0x11d3,  0x9a, 0x16, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) | 
|  | 577 | #define HCDP_TABLE_GUID				EFI_GUID(0xf951938d, 0x620b, 0x42ef,  0x82, 0x79, 0xa8, 0x4b, 0x79, 0x61, 0x78, 0x98) | 
|  | 578 | #define UGA_IO_PROTOCOL_GUID			EFI_GUID(0x61a4d49e, 0x6f68, 0x4f1b,  0xb9, 0x22, 0xa8, 0x6e, 0xed, 0x0b, 0x07, 0xa2) | 
|  | 579 | #define EFI_GLOBAL_VARIABLE_GUID		EFI_GUID(0x8be4df61, 0x93ca, 0x11d2,  0xaa, 0x0d, 0x00, 0xe0, 0x98, 0x03, 0x2b, 0x8c) | 
|  | 580 | #define UV_SYSTEM_TABLE_GUID			EFI_GUID(0x3b13a7d4, 0x633e, 0x11dd,  0x93, 0xec, 0xda, 0x25, 0x56, 0xd8, 0x95, 0x93) | 
|  | 581 | #define LINUX_EFI_CRASH_GUID			EFI_GUID(0xcfc8fc79, 0xbe2e, 0x4ddc,  0x97, 0xf0, 0x9f, 0x98, 0xbf, 0xe2, 0x98, 0xa0) | 
|  | 582 | #define LOADED_IMAGE_PROTOCOL_GUID		EFI_GUID(0x5b1b31a1, 0x9562, 0x11d2,  0x8e, 0x3f, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b) | 
|  | 583 | #define EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID	EFI_GUID(0x9042a9de, 0x23dc, 0x4a38,  0x96, 0xfb, 0x7a, 0xde, 0xd0, 0x80, 0x51, 0x6a) | 
|  | 584 | #define EFI_UGA_PROTOCOL_GUID			EFI_GUID(0x982c298b, 0xf4fa, 0x41cb,  0xb8, 0x38, 0x77, 0xaa, 0x68, 0x8f, 0xb8, 0x39) | 
|  | 585 | #define EFI_PCI_IO_PROTOCOL_GUID		EFI_GUID(0x4cf5b200, 0x68b8, 0x4ca5,  0x9e, 0xec, 0xb2, 0x3e, 0x3f, 0x50, 0x02, 0x9a) | 
|  | 586 | #define EFI_FILE_INFO_ID			EFI_GUID(0x09576e92, 0x6d3f, 0x11d2,  0x8e, 0x39, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b) | 
|  | 587 | #define EFI_SYSTEM_RESOURCE_TABLE_GUID		EFI_GUID(0xb122a263, 0x3661, 0x4f68,  0x99, 0x29, 0x78, 0xf8, 0xb0, 0xd6, 0x21, 0x80) | 
|  | 588 | #define EFI_FILE_SYSTEM_GUID			EFI_GUID(0x964e5b22, 0x6459, 0x11d2,  0x8e, 0x39, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b) | 
|  | 589 | #define DEVICE_TREE_GUID			EFI_GUID(0xb1b621d5, 0xf19c, 0x41a5,  0x83, 0x0b, 0xd9, 0x15, 0x2c, 0x69, 0xaa, 0xe0) | 
|  | 590 | #define EFI_PROPERTIES_TABLE_GUID		EFI_GUID(0x880aaca3, 0x4adc, 0x4a04,  0x90, 0x79, 0xb7, 0x47, 0x34, 0x08, 0x25, 0xe5) | 
|  | 591 | #define EFI_RNG_PROTOCOL_GUID			EFI_GUID(0x3152bca5, 0xeade, 0x433d,  0x86, 0x2e, 0xc0, 0x1c, 0xdc, 0x29, 0x1f, 0x44) | 
| Ard Biesheuvel | 568bc4e | 2016-11-12 21:32:33 +0000 | [diff] [blame^] | 592 | #define EFI_RNG_ALGORITHM_RAW			EFI_GUID(0xe43176d7, 0xb6e8, 0x4827,  0xb7, 0x84, 0x7f, 0xfd, 0xc4, 0xb6, 0x85, 0x61) | 
| Ingo Molnar | 7fb2b43 | 2016-06-27 12:49:20 +0200 | [diff] [blame] | 593 | #define EFI_MEMORY_ATTRIBUTES_TABLE_GUID	EFI_GUID(0xdcfa911d, 0x26eb, 0x469f,  0xa2, 0x20, 0x38, 0xb7, 0xdc, 0x46, 0x12, 0x20) | 
|  | 594 | #define EFI_CONSOLE_OUT_DEVICE_GUID		EFI_GUID(0xd3b36f2c, 0xd551, 0x11d4,  0x9a, 0x46, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) | 
| Ard Biesheuvel | fc37206 | 2016-04-25 21:06:49 +0100 | [diff] [blame] | 595 |  | 
| Ard Biesheuvel | 801820b | 2016-04-25 21:06:53 +0100 | [diff] [blame] | 596 | /* | 
|  | 597 | * This GUID is used to pass to the kernel proper the struct screen_info | 
|  | 598 | * structure that was populated by the stub based on the GOP protocol instance | 
|  | 599 | * associated with ConOut | 
|  | 600 | */ | 
| Ingo Molnar | 7fb2b43 | 2016-06-27 12:49:20 +0200 | [diff] [blame] | 601 | #define LINUX_EFI_ARM_SCREEN_INFO_TABLE_GUID	EFI_GUID(0xe03fc20a, 0x85dc, 0x406e,  0xb9, 0x0e, 0x4a, 0xb5, 0x02, 0x37, 0x1d, 0x95) | 
|  | 602 | #define LINUX_EFI_LOADER_ENTRY_GUID		EFI_GUID(0x4a67b082, 0x0a4c, 0x41cf,  0xb6, 0xc7, 0x44, 0x0b, 0x29, 0xbb, 0x8c, 0x4f) | 
| Ard Biesheuvel | 6362598 | 2016-11-12 21:32:31 +0000 | [diff] [blame] | 603 | #define LINUX_EFI_RANDOM_SEED_TABLE_GUID	EFI_GUID(0x1ce1e5bc, 0x7ceb, 0x42f2,  0x81, 0xe5, 0x8a, 0xad, 0xf1, 0x80, 0xf5, 0x7b) | 
| Compostella, Jeremy | 06f7d4a | 2016-04-25 21:06:57 +0100 | [diff] [blame] | 604 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 605 | typedef struct { | 
|  | 606 | efi_guid_t guid; | 
| Olof Johansson | 1adbfa3 | 2012-02-12 13:24:29 -0800 | [diff] [blame] | 607 | u64 table; | 
|  | 608 | } efi_config_table_64_t; | 
|  | 609 |  | 
|  | 610 | typedef struct { | 
|  | 611 | efi_guid_t guid; | 
|  | 612 | u32 table; | 
|  | 613 | } efi_config_table_32_t; | 
|  | 614 |  | 
|  | 615 | typedef struct { | 
|  | 616 | efi_guid_t guid; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 617 | unsigned long table; | 
|  | 618 | } efi_config_table_t; | 
|  | 619 |  | 
| Leif Lindholm | 272686b | 2013-09-05 11:34:54 +0100 | [diff] [blame] | 620 | typedef struct { | 
|  | 621 | efi_guid_t guid; | 
|  | 622 | const char *name; | 
|  | 623 | unsigned long *ptr; | 
|  | 624 | } efi_config_table_type_t; | 
|  | 625 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 626 | #define EFI_SYSTEM_TABLE_SIGNATURE ((u64)0x5453595320494249ULL) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 627 |  | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 628 | #define EFI_2_30_SYSTEM_TABLE_REVISION  ((2 << 16) | (30)) | 
|  | 629 | #define EFI_2_20_SYSTEM_TABLE_REVISION  ((2 << 16) | (20)) | 
|  | 630 | #define EFI_2_10_SYSTEM_TABLE_REVISION  ((2 << 16) | (10)) | 
|  | 631 | #define EFI_2_00_SYSTEM_TABLE_REVISION  ((2 << 16) | (00)) | 
|  | 632 | #define EFI_1_10_SYSTEM_TABLE_REVISION  ((1 << 16) | (10)) | 
|  | 633 | #define EFI_1_02_SYSTEM_TABLE_REVISION  ((1 << 16) | (02)) | 
|  | 634 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 635 | typedef struct { | 
|  | 636 | efi_table_hdr_t hdr; | 
| Olof Johansson | 1adbfa3 | 2012-02-12 13:24:29 -0800 | [diff] [blame] | 637 | u64 fw_vendor;	/* physical addr of CHAR16 vendor string */ | 
|  | 638 | u32 fw_revision; | 
|  | 639 | u32 __pad1; | 
|  | 640 | u64 con_in_handle; | 
|  | 641 | u64 con_in; | 
|  | 642 | u64 con_out_handle; | 
|  | 643 | u64 con_out; | 
|  | 644 | u64 stderr_handle; | 
|  | 645 | u64 stderr; | 
|  | 646 | u64 runtime; | 
|  | 647 | u64 boottime; | 
|  | 648 | u32 nr_tables; | 
|  | 649 | u32 __pad2; | 
|  | 650 | u64 tables; | 
|  | 651 | } efi_system_table_64_t; | 
|  | 652 |  | 
|  | 653 | typedef struct { | 
|  | 654 | efi_table_hdr_t hdr; | 
|  | 655 | u32 fw_vendor;	/* physical addr of CHAR16 vendor string */ | 
|  | 656 | u32 fw_revision; | 
|  | 657 | u32 con_in_handle; | 
|  | 658 | u32 con_in; | 
|  | 659 | u32 con_out_handle; | 
|  | 660 | u32 con_out; | 
|  | 661 | u32 stderr_handle; | 
|  | 662 | u32 stderr; | 
|  | 663 | u32 runtime; | 
|  | 664 | u32 boottime; | 
|  | 665 | u32 nr_tables; | 
|  | 666 | u32 tables; | 
|  | 667 | } efi_system_table_32_t; | 
|  | 668 |  | 
|  | 669 | typedef struct { | 
|  | 670 | efi_table_hdr_t hdr; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 671 | unsigned long fw_vendor;	/* physical addr of CHAR16 vendor string */ | 
|  | 672 | u32 fw_revision; | 
|  | 673 | unsigned long con_in_handle; | 
|  | 674 | unsigned long con_in; | 
|  | 675 | unsigned long con_out_handle; | 
|  | 676 | unsigned long con_out; | 
|  | 677 | unsigned long stderr_handle; | 
|  | 678 | unsigned long stderr; | 
|  | 679 | efi_runtime_services_t *runtime; | 
| Matt Fleming | f30ca6b | 2011-11-15 12:56:32 +0000 | [diff] [blame] | 680 | efi_boot_services_t *boottime; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 681 | unsigned long nr_tables; | 
|  | 682 | unsigned long tables; | 
|  | 683 | } efi_system_table_t; | 
|  | 684 |  | 
| Matt Fleming | 9479c7c | 2016-02-26 21:22:05 +0000 | [diff] [blame] | 685 | /* | 
|  | 686 | * Architecture independent structure for describing a memory map for the | 
|  | 687 | * benefit of efi_memmap_init_early(), saving us the need to pass four | 
|  | 688 | * parameters. | 
|  | 689 | */ | 
|  | 690 | struct efi_memory_map_data { | 
|  | 691 | phys_addr_t phys_map; | 
|  | 692 | unsigned long size; | 
|  | 693 | unsigned long desc_version; | 
|  | 694 | unsigned long desc_size; | 
|  | 695 | }; | 
|  | 696 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 697 | struct efi_memory_map { | 
| Ard Biesheuvel | 44511fb | 2015-10-23 11:48:16 +0200 | [diff] [blame] | 698 | phys_addr_t phys_map; | 
| Matt Tolentino | 7ae65fd | 2005-09-03 15:56:27 -0700 | [diff] [blame] | 699 | void *map; | 
|  | 700 | void *map_end; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 701 | int nr_map; | 
|  | 702 | unsigned long desc_version; | 
| Matt Tolentino | 7ae65fd | 2005-09-03 15:56:27 -0700 | [diff] [blame] | 703 | unsigned long desc_size; | 
| Matt Fleming | dca0f97 | 2016-02-27 15:52:50 +0000 | [diff] [blame] | 704 | bool late; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 705 | }; | 
|  | 706 |  | 
| Matt Fleming | 60863c0 | 2016-02-29 20:30:39 +0000 | [diff] [blame] | 707 | struct efi_mem_range { | 
|  | 708 | struct range range; | 
|  | 709 | u64 attribute; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 710 | }; | 
|  | 711 |  | 
| Mark Salter | 0302f71 | 2013-12-30 12:12:12 -0500 | [diff] [blame] | 712 | struct efi_fdt_params { | 
|  | 713 | u64 system_table; | 
|  | 714 | u64 mmap; | 
|  | 715 | u32 mmap_size; | 
|  | 716 | u32 desc_size; | 
|  | 717 | u32 desc_ver; | 
|  | 718 | }; | 
|  | 719 |  | 
| Matt Fleming | 8e84f34 | 2011-11-15 12:56:50 +0000 | [diff] [blame] | 720 | typedef struct { | 
|  | 721 | u32 revision; | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 722 | u32 parent_handle; | 
|  | 723 | u32 system_table; | 
|  | 724 | u32 device_handle; | 
|  | 725 | u32 file_path; | 
|  | 726 | u32 reserved; | 
|  | 727 | u32 load_options_size; | 
|  | 728 | u32 load_options; | 
|  | 729 | u32 image_base; | 
|  | 730 | __aligned_u64 image_size; | 
|  | 731 | unsigned int image_code_type; | 
|  | 732 | unsigned int image_data_type; | 
|  | 733 | unsigned long unload; | 
|  | 734 | } efi_loaded_image_32_t; | 
|  | 735 |  | 
|  | 736 | typedef struct { | 
|  | 737 | u32 revision; | 
|  | 738 | u64 parent_handle; | 
|  | 739 | u64 system_table; | 
|  | 740 | u64 device_handle; | 
|  | 741 | u64 file_path; | 
|  | 742 | u64 reserved; | 
|  | 743 | u32 load_options_size; | 
|  | 744 | u64 load_options; | 
|  | 745 | u64 image_base; | 
|  | 746 | __aligned_u64 image_size; | 
|  | 747 | unsigned int image_code_type; | 
|  | 748 | unsigned int image_data_type; | 
|  | 749 | unsigned long unload; | 
|  | 750 | } efi_loaded_image_64_t; | 
|  | 751 |  | 
|  | 752 | typedef struct { | 
|  | 753 | u32 revision; | 
| Matt Fleming | 8e84f34 | 2011-11-15 12:56:50 +0000 | [diff] [blame] | 754 | void *parent_handle; | 
|  | 755 | efi_system_table_t *system_table; | 
|  | 756 | void *device_handle; | 
|  | 757 | void *file_path; | 
|  | 758 | void *reserved; | 
|  | 759 | u32 load_options_size; | 
|  | 760 | void *load_options; | 
|  | 761 | void *image_base; | 
|  | 762 | __aligned_u64 image_size; | 
|  | 763 | unsigned int image_code_type; | 
|  | 764 | unsigned int image_data_type; | 
|  | 765 | unsigned long unload; | 
|  | 766 | } efi_loaded_image_t; | 
|  | 767 |  | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 768 |  | 
|  | 769 | typedef struct { | 
|  | 770 | u64 size; | 
|  | 771 | u64 file_size; | 
|  | 772 | u64 phys_size; | 
|  | 773 | efi_time_t create_time; | 
|  | 774 | efi_time_t last_access_time; | 
|  | 775 | efi_time_t modification_time; | 
|  | 776 | __aligned_u64 attribute; | 
|  | 777 | efi_char16_t filename[1]; | 
|  | 778 | } efi_file_info_t; | 
|  | 779 |  | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 780 | typedef struct { | 
|  | 781 | u64 revision; | 
|  | 782 | u32 open; | 
|  | 783 | u32 close; | 
|  | 784 | u32 delete; | 
|  | 785 | u32 read; | 
|  | 786 | u32 write; | 
|  | 787 | u32 get_position; | 
|  | 788 | u32 set_position; | 
|  | 789 | u32 get_info; | 
|  | 790 | u32 set_info; | 
|  | 791 | u32 flush; | 
|  | 792 | } efi_file_handle_32_t; | 
|  | 793 |  | 
|  | 794 | typedef struct { | 
|  | 795 | u64 revision; | 
|  | 796 | u64 open; | 
|  | 797 | u64 close; | 
|  | 798 | u64 delete; | 
|  | 799 | u64 read; | 
|  | 800 | u64 write; | 
|  | 801 | u64 get_position; | 
|  | 802 | u64 set_position; | 
|  | 803 | u64 get_info; | 
|  | 804 | u64 set_info; | 
|  | 805 | u64 flush; | 
|  | 806 | } efi_file_handle_64_t; | 
|  | 807 |  | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 808 | typedef struct _efi_file_handle { | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 809 | u64 revision; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 810 | efi_status_t (*open)(struct _efi_file_handle *, | 
|  | 811 | struct _efi_file_handle **, | 
|  | 812 | efi_char16_t *, u64, u64); | 
|  | 813 | efi_status_t (*close)(struct _efi_file_handle *); | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 814 | void *delete; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 815 | efi_status_t (*read)(struct _efi_file_handle *, unsigned long *, | 
|  | 816 | void *); | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 817 | void *write; | 
|  | 818 | void *get_position; | 
|  | 819 | void *set_position; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 820 | efi_status_t (*get_info)(struct _efi_file_handle *, efi_guid_t *, | 
|  | 821 | unsigned long *, void *); | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 822 | void *set_info; | 
|  | 823 | void *flush; | 
|  | 824 | } efi_file_handle_t; | 
|  | 825 |  | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 826 | typedef struct _efi_file_io_interface { | 
|  | 827 | u64 revision; | 
|  | 828 | int (*open_volume)(struct _efi_file_io_interface *, | 
|  | 829 | efi_file_handle_t **); | 
|  | 830 | } efi_file_io_interface_t; | 
|  | 831 |  | 
| Matt Fleming | 55839d5 | 2011-08-11 10:28:06 +0100 | [diff] [blame] | 832 | #define EFI_FILE_MODE_READ	0x0000000000000001 | 
|  | 833 | #define EFI_FILE_MODE_WRITE	0x0000000000000002 | 
|  | 834 | #define EFI_FILE_MODE_CREATE	0x8000000000000000 | 
|  | 835 |  | 
| Ard Biesheuvel | bf92486 | 2015-09-09 10:08:15 +0200 | [diff] [blame] | 836 | typedef struct { | 
|  | 837 | u32 version; | 
|  | 838 | u32 length; | 
|  | 839 | u64 memory_protection_attribute; | 
|  | 840 | } efi_properties_table_t; | 
|  | 841 |  | 
|  | 842 | #define EFI_PROPERTIES_TABLE_VERSION	0x00010000 | 
|  | 843 | #define EFI_PROPERTIES_RUNTIME_MEMORY_PROTECTION_NON_EXECUTABLE_PE_DATA	0x1 | 
|  | 844 |  | 
| Bjorn Helgaas | b2c99e3 | 2006-03-26 01:37:08 -0800 | [diff] [blame] | 845 | #define EFI_INVALID_TABLE_ADDR		(~0UL) | 
|  | 846 |  | 
| Ard Biesheuvel | a604af0 | 2016-04-25 21:06:44 +0100 | [diff] [blame] | 847 | typedef struct { | 
|  | 848 | u32 version; | 
|  | 849 | u32 num_entries; | 
|  | 850 | u32 desc_size; | 
|  | 851 | u32 reserved; | 
|  | 852 | efi_memory_desc_t entry[0]; | 
|  | 853 | } efi_memory_attributes_table_t; | 
|  | 854 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 855 | /* | 
|  | 856 | * All runtime access to EFI goes through this structure: | 
|  | 857 | */ | 
|  | 858 | extern struct efi { | 
|  | 859 | efi_system_table_t *systab;	/* EFI system table */ | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 860 | unsigned int runtime_version;	/* Runtime services version */ | 
| Bjorn Helgaas | b2c99e3 | 2006-03-26 01:37:08 -0800 | [diff] [blame] | 861 | unsigned long mps;		/* MPS table */ | 
|  | 862 | unsigned long acpi;		/* ACPI table  (IA64 ext 0.71) */ | 
|  | 863 | unsigned long acpi20;		/* ACPI table  (ACPI 2.0) */ | 
| Ard Biesheuvel | e1ccbbc | 2014-10-14 16:34:47 +0200 | [diff] [blame] | 864 | unsigned long smbios;		/* SMBIOS table (32 bit entry point) */ | 
|  | 865 | unsigned long smbios3;		/* SMBIOS table (64 bit entry point) */ | 
| Bjorn Helgaas | b2c99e3 | 2006-03-26 01:37:08 -0800 | [diff] [blame] | 866 | unsigned long sal_systab;	/* SAL system table */ | 
|  | 867 | unsigned long boot_info;	/* boot info table */ | 
|  | 868 | unsigned long hcdp;		/* HCDP table */ | 
|  | 869 | unsigned long uga;		/* UGA table */ | 
| Russ Anderson | a50f70b | 2008-10-03 11:58:54 -0500 | [diff] [blame] | 870 | unsigned long uv_systab;	/* UV system table */ | 
| Dave Young | a0998eb | 2013-12-20 18:02:17 +0800 | [diff] [blame] | 871 | unsigned long fw_vendor;	/* fw_vendor */ | 
|  | 872 | unsigned long runtime;		/* runtime table */ | 
|  | 873 | unsigned long config_table;	/* config tables */ | 
| Peter Jones | 0bb5490 | 2015-04-28 18:44:31 -0400 | [diff] [blame] | 874 | unsigned long esrt;		/* ESRT table */ | 
| Ard Biesheuvel | bf92486 | 2015-09-09 10:08:15 +0200 | [diff] [blame] | 875 | unsigned long properties_table;	/* properties table */ | 
| Ard Biesheuvel | a604af0 | 2016-04-25 21:06:44 +0100 | [diff] [blame] | 876 | unsigned long mem_attr_table;	/* memory attributes table */ | 
| Ard Biesheuvel | 6362598 | 2016-11-12 21:32:31 +0000 | [diff] [blame] | 877 | unsigned long rng_seed;		/* UEFI firmware random seed */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 878 | efi_get_time_t *get_time; | 
|  | 879 | efi_set_time_t *set_time; | 
|  | 880 | efi_get_wakeup_time_t *get_wakeup_time; | 
|  | 881 | efi_set_wakeup_time_t *set_wakeup_time; | 
|  | 882 | efi_get_variable_t *get_variable; | 
|  | 883 | efi_get_next_variable_t *get_next_variable; | 
|  | 884 | efi_set_variable_t *set_variable; | 
| Ard Biesheuvel | 70d2a3c | 2016-02-01 22:06:56 +0000 | [diff] [blame] | 885 | efi_set_variable_t *set_variable_nonblocking; | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 886 | efi_query_variable_info_t *query_variable_info; | 
| Ard Biesheuvel | d3cac1f | 2016-02-01 22:06:57 +0000 | [diff] [blame] | 887 | efi_query_variable_info_t *query_variable_info_nonblocking; | 
| Matthew Garrett | 3b37023 | 2011-06-06 15:36:25 -0400 | [diff] [blame] | 888 | efi_update_capsule_t *update_capsule; | 
|  | 889 | efi_query_capsule_caps_t *query_capsule_caps; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 890 | efi_get_next_high_mono_count_t *get_next_high_mono_count; | 
|  | 891 | efi_reset_system_t *reset_system; | 
|  | 892 | efi_set_virtual_address_map_t *set_virtual_address_map; | 
| Matt Fleming | 884f4f6 | 2016-04-25 21:06:39 +0100 | [diff] [blame] | 893 | struct efi_memory_map memmap; | 
| Matt Fleming | 3e90959 | 2014-01-15 13:21:22 +0000 | [diff] [blame] | 894 | unsigned long flags; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 895 | } efi; | 
|  | 896 |  | 
|  | 897 | static inline int | 
|  | 898 | efi_guidcmp (efi_guid_t left, efi_guid_t right) | 
|  | 899 | { | 
|  | 900 | return memcmp(&left, &right, sizeof (efi_guid_t)); | 
|  | 901 | } | 
|  | 902 |  | 
|  | 903 | static inline char * | 
| Borislav Petkov | 26e0227 | 2014-12-18 16:02:17 +0100 | [diff] [blame] | 904 | efi_guid_to_str(efi_guid_t *guid, char *out) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 905 | { | 
| Joe Perches | 925ede0bf | 2009-12-14 18:01:14 -0800 | [diff] [blame] | 906 | sprintf(out, "%pUl", guid->b); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 907 | return out; | 
|  | 908 | } | 
|  | 909 |  | 
|  | 910 | extern void efi_init (void); | 
|  | 911 | extern void *efi_get_pal_addr (void); | 
|  | 912 | extern void efi_map_pal_code (void); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 913 | extern void efi_memmap_walk (efi_freemem_callback_t callback, void *arg); | 
| Arnd Bergmann | 70f4f93 | 2016-06-17 16:48:17 +0200 | [diff] [blame] | 914 | extern void efi_gettimeofday (struct timespec64 *ts); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 915 | extern void efi_enter_virtual_mode (void);	/* switch EFI to virtual mode, if possible */ | 
| Josh Triplett | 7851079 | 2012-09-28 17:55:44 -0700 | [diff] [blame] | 916 | #ifdef CONFIG_X86 | 
| Josh Triplett | 2223af3 | 2012-09-28 17:57:05 -0700 | [diff] [blame] | 917 | extern void efi_late_init(void); | 
| Josh Triplett | 7851079 | 2012-09-28 17:55:44 -0700 | [diff] [blame] | 918 | extern void efi_free_boot_services(void); | 
| Ard Biesheuvel | ca0e30d | 2016-02-01 22:06:58 +0000 | [diff] [blame] | 919 | extern efi_status_t efi_query_variable_store(u32 attributes, | 
|  | 920 | unsigned long size, | 
|  | 921 | bool nonblocking); | 
| Tony Luck | b05b9f5 | 2015-06-24 16:58:15 -0700 | [diff] [blame] | 922 | extern void efi_find_mirror(void); | 
| Josh Triplett | 7851079 | 2012-09-28 17:55:44 -0700 | [diff] [blame] | 923 | #else | 
| Josh Triplett | 2223af3 | 2012-09-28 17:57:05 -0700 | [diff] [blame] | 924 | static inline void efi_late_init(void) {} | 
| Josh Triplett | 7851079 | 2012-09-28 17:55:44 -0700 | [diff] [blame] | 925 | static inline void efi_free_boot_services(void) {} | 
| Matt Fleming | a6e4d5a | 2013-03-25 09:14:30 +0000 | [diff] [blame] | 926 |  | 
| Ard Biesheuvel | ca0e30d | 2016-02-01 22:06:58 +0000 | [diff] [blame] | 927 | static inline efi_status_t efi_query_variable_store(u32 attributes, | 
|  | 928 | unsigned long size, | 
|  | 929 | bool nonblocking) | 
| Matt Fleming | a6e4d5a | 2013-03-25 09:14:30 +0000 | [diff] [blame] | 930 | { | 
|  | 931 | return EFI_SUCCESS; | 
|  | 932 | } | 
| Josh Triplett | 7851079 | 2012-09-28 17:55:44 -0700 | [diff] [blame] | 933 | #endif | 
| Josh Triplett | 7bc90e0 | 2012-09-28 17:56:08 -0700 | [diff] [blame] | 934 | extern void __iomem *efi_lookup_mapped_addr(u64 phys_addr); | 
| Matt Fleming | 9479c7c | 2016-02-26 21:22:05 +0000 | [diff] [blame] | 935 |  | 
|  | 936 | extern int __init efi_memmap_init_early(struct efi_memory_map_data *data); | 
| Matt Fleming | dca0f97 | 2016-02-27 15:52:50 +0000 | [diff] [blame] | 937 | extern int __init efi_memmap_init_late(phys_addr_t addr, unsigned long size); | 
| Matt Fleming | 9479c7c | 2016-02-26 21:22:05 +0000 | [diff] [blame] | 938 | extern void __init efi_memmap_unmap(void); | 
| Matt Fleming | c45f4da | 2016-06-22 16:54:00 +0100 | [diff] [blame] | 939 | extern int __init efi_memmap_install(phys_addr_t addr, unsigned int nr_map); | 
| Matt Fleming | 60863c0 | 2016-02-29 20:30:39 +0000 | [diff] [blame] | 940 | extern int __init efi_memmap_split_count(efi_memory_desc_t *md, | 
|  | 941 | struct range *range); | 
|  | 942 | extern void __init efi_memmap_insert(struct efi_memory_map *old_memmap, | 
|  | 943 | void *buf, struct efi_mem_range *mem); | 
| Matt Fleming | 9479c7c | 2016-02-26 21:22:05 +0000 | [diff] [blame] | 944 |  | 
| Leif Lindholm | 272686b | 2013-09-05 11:34:54 +0100 | [diff] [blame] | 945 | extern int efi_config_init(efi_config_table_type_t *arch_tables); | 
| Peter Jones | 3846c15 | 2015-06-05 15:14:54 -0400 | [diff] [blame] | 946 | #ifdef CONFIG_EFI_ESRT | 
| Peter Jones | 0bb5490 | 2015-04-28 18:44:31 -0400 | [diff] [blame] | 947 | extern void __init efi_esrt_init(void); | 
| Peter Jones | 3846c15 | 2015-06-05 15:14:54 -0400 | [diff] [blame] | 948 | #else | 
|  | 949 | static inline void efi_esrt_init(void) { } | 
|  | 950 | #endif | 
| Ard Biesheuvel | 7bb6841 | 2014-10-18 15:04:15 +0200 | [diff] [blame] | 951 | extern int efi_config_parse_tables(void *config_tables, int count, int sz, | 
|  | 952 | efi_config_table_type_t *arch_tables); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 953 | extern u64 efi_get_iobase (void); | 
|  | 954 | extern u32 efi_mem_type (unsigned long phys_addr); | 
|  | 955 | extern u64 efi_mem_attributes (unsigned long phys_addr); | 
| Bjorn Helgaas | 32e62c6 | 2006-05-05 17:19:50 -0600 | [diff] [blame] | 956 | extern u64 efi_mem_attribute (unsigned long phys_addr, unsigned long size); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 957 | extern int __init efi_uart_console_only (void); | 
| Peter Jones | 0bb5490 | 2015-04-28 18:44:31 -0400 | [diff] [blame] | 958 | extern u64 efi_mem_desc_end(efi_memory_desc_t *md); | 
|  | 959 | extern int efi_mem_desc_lookup(u64 phys_addr, efi_memory_desc_t *out_md); | 
| Matt Fleming | 816e761 | 2016-02-29 21:22:52 +0000 | [diff] [blame] | 960 | extern void efi_mem_reserve(phys_addr_t addr, u64 size); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 961 | extern void efi_initialize_iomem_resources(struct resource *code_resource, | 
| Bernhard Walle | 00bf409 | 2007-10-21 16:42:01 -0700 | [diff] [blame] | 962 | struct resource *data_resource, struct resource *bss_resource); | 
| Matthew Garrett | 916f676 | 2011-05-25 09:53:13 -0400 | [diff] [blame] | 963 | extern void efi_reserve_boot_services(void); | 
| Leif Lindholm | 7968c0e | 2015-08-26 14:24:58 +0100 | [diff] [blame] | 964 | extern int efi_get_fdt_params(struct efi_fdt_params *params); | 
| Peter Jones | 0bb5490 | 2015-04-28 18:44:31 -0400 | [diff] [blame] | 965 | extern struct kobject *efi_kobj; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 966 |  | 
| Matt Fleming | 44be28e | 2014-06-13 12:39:55 +0100 | [diff] [blame] | 967 | extern int efi_reboot_quirk_mode; | 
| Matt Fleming | 0c5ed61 | 2014-06-13 12:35:21 +0100 | [diff] [blame] | 968 | extern bool efi_poweroff_required(void); | 
|  | 969 |  | 
| Taku Izumi | 0f96a99 | 2015-09-30 23:01:56 +0900 | [diff] [blame] | 970 | #ifdef CONFIG_EFI_FAKE_MEMMAP | 
|  | 971 | extern void __init efi_fake_memmap(void); | 
|  | 972 | #else | 
|  | 973 | static inline void efi_fake_memmap(void) { } | 
|  | 974 | #endif | 
|  | 975 |  | 
| Ard Biesheuvel | 10f0d2f5 | 2016-04-25 21:06:45 +0100 | [diff] [blame] | 976 | /* | 
|  | 977 | * efi_memattr_perm_setter - arch specific callback function passed into | 
|  | 978 | *                           efi_memattr_apply_permissions() that updates the | 
|  | 979 | *                           mapping permissions described by the second | 
|  | 980 | *                           argument in the page tables referred to by the | 
|  | 981 | *                           first argument. | 
|  | 982 | */ | 
|  | 983 | typedef int (*efi_memattr_perm_setter)(struct mm_struct *, efi_memory_desc_t *); | 
|  | 984 |  | 
|  | 985 | extern int efi_memattr_init(void); | 
|  | 986 | extern int efi_memattr_apply_permissions(struct mm_struct *mm, | 
|  | 987 | efi_memattr_perm_setter fn); | 
|  | 988 |  | 
| Mark Salter | e885cd8 | 2014-01-10 14:26:06 -0500 | [diff] [blame] | 989 | /* Iterate through an efi_memory_map */ | 
| Matt Fleming | 78ce248 | 2016-04-25 21:06:38 +0100 | [diff] [blame] | 990 | #define for_each_efi_memory_desc_in_map(m, md)				   \ | 
| Mark Salter | e885cd8 | 2014-01-10 14:26:06 -0500 | [diff] [blame] | 991 | for ((md) = (m)->map;						   \ | 
| Jan Beulich | d4c4fed | 2016-08-15 09:05:45 -0600 | [diff] [blame] | 992 | (md) && ((void *)(md) + (m)->desc_size) <= (m)->map_end;	   \ | 
| Mark Salter | e885cd8 | 2014-01-10 14:26:06 -0500 | [diff] [blame] | 993 | (md) = (void *)(md) + (m)->desc_size) | 
|  | 994 |  | 
| Matt Fleming | 78ce248 | 2016-04-25 21:06:38 +0100 | [diff] [blame] | 995 | /** | 
|  | 996 | * for_each_efi_memory_desc - iterate over descriptors in efi.memmap | 
|  | 997 | * @md: the efi_memory_desc_t * iterator | 
|  | 998 | * | 
|  | 999 | * Once the loop finishes @md must not be accessed. | 
|  | 1000 | */ | 
|  | 1001 | #define for_each_efi_memory_desc(md) \ | 
| Matt Fleming | 884f4f6 | 2016-04-25 21:06:39 +0100 | [diff] [blame] | 1002 | for_each_efi_memory_desc_in_map(&efi.memmap, md) | 
| Matt Fleming | 78ce248 | 2016-04-25 21:06:38 +0100 | [diff] [blame] | 1003 |  | 
| Laszlo Ersek | 98d2a6c | 2014-09-03 13:32:20 +0200 | [diff] [blame] | 1004 | /* | 
|  | 1005 | * Format an EFI memory descriptor's type and attributes to a user-provided | 
|  | 1006 | * character buffer, as per snprintf(), and return the buffer. | 
|  | 1007 | */ | 
|  | 1008 | char * __init efi_md_typeattr_format(char *buf, size_t size, | 
|  | 1009 | const efi_memory_desc_t *md); | 
|  | 1010 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1011 | /** | 
|  | 1012 | * efi_range_is_wc - check the WC bit on an address range | 
|  | 1013 | * @start: starting kvirt address | 
|  | 1014 | * @len: length of range | 
|  | 1015 | * | 
|  | 1016 | * Consult the EFI memory map and make sure it's ok to set this range WC. | 
|  | 1017 | * Returns true or false. | 
|  | 1018 | */ | 
|  | 1019 | static inline int efi_range_is_wc(unsigned long start, unsigned long len) | 
|  | 1020 | { | 
| Jesper Juhl | 986a80d | 2005-06-16 15:14:00 -0700 | [diff] [blame] | 1021 | unsigned long i; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1022 |  | 
|  | 1023 | for (i = 0; i < len; i += (1UL << EFI_PAGE_SHIFT)) { | 
|  | 1024 | unsigned long paddr = __pa(start + i); | 
|  | 1025 | if (!(efi_mem_attributes(paddr) & EFI_MEMORY_WC)) | 
|  | 1026 | return 0; | 
|  | 1027 | } | 
|  | 1028 | /* The range checked out */ | 
|  | 1029 | return 1; | 
|  | 1030 | } | 
|  | 1031 |  | 
|  | 1032 | #ifdef CONFIG_EFI_PCDP | 
|  | 1033 | extern int __init efi_setup_pcdp_console(char *); | 
|  | 1034 | #endif | 
|  | 1035 |  | 
|  | 1036 | /* | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1037 | * We play games with efi_enabled so that the compiler will, if | 
|  | 1038 | * possible, remove EFI-related code altogether. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1039 | */ | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1040 | #define EFI_BOOT		0	/* Were we booted from EFI? */ | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1041 | #define EFI_CONFIG_TABLES	2	/* Can we use EFI config tables? */ | 
|  | 1042 | #define EFI_RUNTIME_SERVICES	3	/* Can we use runtime services? */ | 
|  | 1043 | #define EFI_MEMMAP		4	/* Can we use EFI memory map? */ | 
|  | 1044 | #define EFI_64BIT		5	/* Is the firmware 64-bit? */ | 
| Daniel Kiper | 9f27bc5 | 2014-06-30 19:52:58 +0200 | [diff] [blame] | 1045 | #define EFI_PARAVIRT		6	/* Access is via a paravirt interface */ | 
|  | 1046 | #define EFI_ARCH_1		7	/* First arch-specific bit */ | 
| Borislav Petkov | fed6cef | 2015-02-05 11:44:41 +0100 | [diff] [blame] | 1047 | #define EFI_DBG			8	/* Print additional debug info at runtime */ | 
| Ard Biesheuvel | a104171 | 2015-09-23 07:29:34 -0700 | [diff] [blame] | 1048 | #define EFI_NX_PE_DATA		9	/* Can runtime data regions be mapped non-executable? */ | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1049 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1050 | #ifdef CONFIG_EFI | 
| Matt Fleming | 3e90959 | 2014-01-15 13:21:22 +0000 | [diff] [blame] | 1051 | /* | 
|  | 1052 | * Test whether the above EFI_* bits are enabled. | 
|  | 1053 | */ | 
|  | 1054 | static inline bool efi_enabled(int feature) | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1055 | { | 
| Matt Fleming | 3e90959 | 2014-01-15 13:21:22 +0000 | [diff] [blame] | 1056 | return test_bit(feature, &efi.flags) != 0; | 
|  | 1057 | } | 
| Matt Fleming | 8562c99 | 2014-06-13 12:22:22 +0100 | [diff] [blame] | 1058 | extern void efi_reboot(enum reboot_mode reboot_mode, const char *__unused); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1059 | #else | 
| Matt Fleming | 3e90959 | 2014-01-15 13:21:22 +0000 | [diff] [blame] | 1060 | static inline bool efi_enabled(int feature) | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1061 | { | 
| Matt Fleming | 3e90959 | 2014-01-15 13:21:22 +0000 | [diff] [blame] | 1062 | return false; | 
| Matt Fleming | 83e6818 | 2012-11-14 09:42:35 +0000 | [diff] [blame] | 1063 | } | 
| Matt Fleming | 8562c99 | 2014-06-13 12:22:22 +0100 | [diff] [blame] | 1064 | static inline void | 
|  | 1065 | efi_reboot(enum reboot_mode reboot_mode, const char *__unused) {} | 
| Matt Fleming | 87615a3 | 2016-04-25 21:07:00 +0100 | [diff] [blame] | 1066 |  | 
|  | 1067 | static inline bool | 
|  | 1068 | efi_capsule_pending(int *reset_type) | 
|  | 1069 | { | 
|  | 1070 | return false; | 
|  | 1071 | } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1072 | #endif | 
|  | 1073 |  | 
| Matt Fleming | 806b035 | 2016-04-25 21:06:58 +0100 | [diff] [blame] | 1074 | extern int efi_status_to_err(efi_status_t status); | 
|  | 1075 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1076 | /* | 
|  | 1077 | * Variable Attributes | 
|  | 1078 | */ | 
|  | 1079 | #define EFI_VARIABLE_NON_VOLATILE       0x0000000000000001 | 
|  | 1080 | #define EFI_VARIABLE_BOOTSERVICE_ACCESS 0x0000000000000002 | 
|  | 1081 | #define EFI_VARIABLE_RUNTIME_ACCESS     0x0000000000000004 | 
| Matthew Garrett | 41b3254 | 2012-04-30 16:11:29 -0400 | [diff] [blame] | 1082 | #define EFI_VARIABLE_HARDWARE_ERROR_RECORD 0x0000000000000008 | 
|  | 1083 | #define EFI_VARIABLE_AUTHENTICATED_WRITE_ACCESS 0x0000000000000010 | 
|  | 1084 | #define EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS 0x0000000000000020 | 
|  | 1085 | #define EFI_VARIABLE_APPEND_WRITE	0x0000000000000040 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1086 |  | 
| Matthew Garrett | 41b3254 | 2012-04-30 16:11:29 -0400 | [diff] [blame] | 1087 | #define EFI_VARIABLE_MASK 	(EFI_VARIABLE_NON_VOLATILE | \ | 
|  | 1088 | EFI_VARIABLE_BOOTSERVICE_ACCESS | \ | 
|  | 1089 | EFI_VARIABLE_RUNTIME_ACCESS | \ | 
|  | 1090 | EFI_VARIABLE_HARDWARE_ERROR_RECORD | \ | 
|  | 1091 | EFI_VARIABLE_AUTHENTICATED_WRITE_ACCESS | \ | 
|  | 1092 | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS | \ | 
|  | 1093 | EFI_VARIABLE_APPEND_WRITE) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1094 | /* | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1095 | * Length of a GUID string (strlen("aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee")) | 
|  | 1096 | * not including trailing NUL | 
|  | 1097 | */ | 
| Andy Shevchenko | ba7e34b | 2016-05-20 17:01:18 -0700 | [diff] [blame] | 1098 | #define EFI_VARIABLE_GUID_LEN	UUID_STRING_LEN | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1099 |  | 
|  | 1100 | /* | 
| Matt Fleming | e2527a7 | 2011-11-15 12:57:26 +0000 | [diff] [blame] | 1101 | * The type of search to perform when calling boottime->locate_handle | 
|  | 1102 | */ | 
|  | 1103 | #define EFI_LOCATE_ALL_HANDLES			0 | 
|  | 1104 | #define EFI_LOCATE_BY_REGISTER_NOTIFY		1 | 
|  | 1105 | #define EFI_LOCATE_BY_PROTOCOL			2 | 
|  | 1106 |  | 
|  | 1107 | /* | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1108 | * EFI Device Path information | 
|  | 1109 | */ | 
|  | 1110 | #define EFI_DEV_HW			0x01 | 
|  | 1111 | #define  EFI_DEV_PCI				 1 | 
|  | 1112 | #define  EFI_DEV_PCCARD				 2 | 
|  | 1113 | #define  EFI_DEV_MEM_MAPPED			 3 | 
|  | 1114 | #define  EFI_DEV_VENDOR				 4 | 
|  | 1115 | #define  EFI_DEV_CONTROLLER			 5 | 
|  | 1116 | #define EFI_DEV_ACPI			0x02 | 
|  | 1117 | #define   EFI_DEV_BASIC_ACPI			 1 | 
|  | 1118 | #define   EFI_DEV_EXPANDED_ACPI			 2 | 
|  | 1119 | #define EFI_DEV_MSG			0x03 | 
|  | 1120 | #define   EFI_DEV_MSG_ATAPI			 1 | 
|  | 1121 | #define   EFI_DEV_MSG_SCSI			 2 | 
|  | 1122 | #define   EFI_DEV_MSG_FC			 3 | 
|  | 1123 | #define   EFI_DEV_MSG_1394			 4 | 
|  | 1124 | #define   EFI_DEV_MSG_USB			 5 | 
|  | 1125 | #define   EFI_DEV_MSG_USB_CLASS			15 | 
|  | 1126 | #define   EFI_DEV_MSG_I20			 6 | 
|  | 1127 | #define   EFI_DEV_MSG_MAC			11 | 
|  | 1128 | #define   EFI_DEV_MSG_IPV4			12 | 
|  | 1129 | #define   EFI_DEV_MSG_IPV6			13 | 
|  | 1130 | #define   EFI_DEV_MSG_INFINIBAND		 9 | 
|  | 1131 | #define   EFI_DEV_MSG_UART			14 | 
|  | 1132 | #define   EFI_DEV_MSG_VENDOR			10 | 
|  | 1133 | #define EFI_DEV_MEDIA			0x04 | 
|  | 1134 | #define   EFI_DEV_MEDIA_HARD_DRIVE		 1 | 
|  | 1135 | #define   EFI_DEV_MEDIA_CDROM			 2 | 
|  | 1136 | #define   EFI_DEV_MEDIA_VENDOR			 3 | 
|  | 1137 | #define   EFI_DEV_MEDIA_FILE			 4 | 
|  | 1138 | #define   EFI_DEV_MEDIA_PROTOCOL		 5 | 
|  | 1139 | #define EFI_DEV_BIOS_BOOT		0x05 | 
|  | 1140 | #define EFI_DEV_END_PATH		0x7F | 
|  | 1141 | #define EFI_DEV_END_PATH2		0xFF | 
|  | 1142 | #define   EFI_DEV_END_INSTANCE			0x01 | 
|  | 1143 | #define   EFI_DEV_END_ENTIRE			0xFF | 
|  | 1144 |  | 
|  | 1145 | struct efi_generic_dev_path { | 
|  | 1146 | u8 type; | 
|  | 1147 | u8 sub_type; | 
|  | 1148 | u16 length; | 
|  | 1149 | } __attribute ((packed)); | 
|  | 1150 |  | 
| Huang, Ying | 4a3575f | 2008-02-25 15:18:37 +0800 | [diff] [blame] | 1151 | static inline void memrange_efi_to_native(u64 *addr, u64 *npages) | 
|  | 1152 | { | 
|  | 1153 | *npages = PFN_UP(*addr + (*npages<<EFI_PAGE_SHIFT)) - PFN_DOWN(*addr); | 
|  | 1154 | *addr &= PAGE_MASK; | 
|  | 1155 | } | 
|  | 1156 |  | 
| Matt Fleming | 0485177 | 2013-02-08 15:48:51 +0000 | [diff] [blame] | 1157 | /* | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1158 | * EFI Variable support. | 
|  | 1159 | * | 
|  | 1160 | * Different firmware drivers can expose their EFI-like variables using | 
|  | 1161 | * the following. | 
|  | 1162 | */ | 
|  | 1163 |  | 
|  | 1164 | struct efivar_operations { | 
|  | 1165 | efi_get_variable_t *get_variable; | 
|  | 1166 | efi_get_next_variable_t *get_next_variable; | 
|  | 1167 | efi_set_variable_t *set_variable; | 
| Ard Biesheuvel | 70d2a3c | 2016-02-01 22:06:56 +0000 | [diff] [blame] | 1168 | efi_set_variable_t *set_variable_nonblocking; | 
| Matt Fleming | a6e4d5a | 2013-03-25 09:14:30 +0000 | [diff] [blame] | 1169 | efi_query_variable_store_t *query_variable_store; | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1170 | }; | 
|  | 1171 |  | 
|  | 1172 | struct efivars { | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1173 | struct kset *kset; | 
| Lee, Chun-Yi | 605e70c | 2012-10-05 13:54:56 +0800 | [diff] [blame] | 1174 | struct kobject *kobject; | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1175 | const struct efivar_operations *ops; | 
|  | 1176 | }; | 
|  | 1177 |  | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1178 | /* | 
|  | 1179 | * The maximum size of VariableName + Data = 1024 | 
|  | 1180 | * Therefore, it's reasonable to save that much | 
|  | 1181 | * space in each part of the structure, | 
|  | 1182 | * and we use a page for reading/writing. | 
|  | 1183 | */ | 
|  | 1184 |  | 
| Matt Fleming | a5d92ad | 2014-03-17 10:57:00 +0000 | [diff] [blame] | 1185 | #define EFI_VAR_NAME_LEN	1024 | 
|  | 1186 |  | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1187 | struct efi_variable { | 
| Matt Fleming | a5d92ad | 2014-03-17 10:57:00 +0000 | [diff] [blame] | 1188 | efi_char16_t  VariableName[EFI_VAR_NAME_LEN/sizeof(efi_char16_t)]; | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1189 | efi_guid_t    VendorGuid; | 
|  | 1190 | unsigned long DataSize; | 
|  | 1191 | __u8          Data[1024]; | 
|  | 1192 | efi_status_t  Status; | 
|  | 1193 | __u32         Attributes; | 
|  | 1194 | } __attribute__((packed)); | 
|  | 1195 |  | 
|  | 1196 | struct efivar_entry { | 
|  | 1197 | struct efi_variable var; | 
|  | 1198 | struct list_head list; | 
|  | 1199 | struct kobject kobj; | 
| Seiji Aguchi | e0d5973 | 2013-10-30 15:27:26 -0400 | [diff] [blame] | 1200 | bool scanning; | 
|  | 1201 | bool deleting; | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1202 | }; | 
|  | 1203 |  | 
| Matt Fleming | 677703c | 2014-01-10 13:47:37 +0000 | [diff] [blame] | 1204 | struct efi_simple_text_output_protocol_32 { | 
|  | 1205 | u32 reset; | 
|  | 1206 | u32 output_string; | 
|  | 1207 | u32 test_string; | 
|  | 1208 | }; | 
|  | 1209 |  | 
|  | 1210 | struct efi_simple_text_output_protocol_64 { | 
|  | 1211 | u64 reset; | 
|  | 1212 | u64 output_string; | 
|  | 1213 | u64 test_string; | 
|  | 1214 | }; | 
| Roy Franz | ed37ddf | 2013-09-22 15:45:26 -0700 | [diff] [blame] | 1215 |  | 
|  | 1216 | struct efi_simple_text_output_protocol { | 
|  | 1217 | void *reset; | 
|  | 1218 | efi_status_t (*output_string)(void *, void *); | 
|  | 1219 | void *test_string; | 
|  | 1220 | }; | 
|  | 1221 |  | 
| Ard Biesheuvel | fc37206 | 2016-04-25 21:06:49 +0100 | [diff] [blame] | 1222 | #define PIXEL_RGB_RESERVED_8BIT_PER_COLOR		0 | 
|  | 1223 | #define PIXEL_BGR_RESERVED_8BIT_PER_COLOR		1 | 
|  | 1224 | #define PIXEL_BIT_MASK					2 | 
|  | 1225 | #define PIXEL_BLT_ONLY					3 | 
|  | 1226 | #define PIXEL_FORMAT_MAX				4 | 
|  | 1227 |  | 
|  | 1228 | struct efi_pixel_bitmask { | 
|  | 1229 | u32 red_mask; | 
|  | 1230 | u32 green_mask; | 
|  | 1231 | u32 blue_mask; | 
|  | 1232 | u32 reserved_mask; | 
|  | 1233 | }; | 
|  | 1234 |  | 
|  | 1235 | struct efi_graphics_output_mode_info { | 
|  | 1236 | u32 version; | 
|  | 1237 | u32 horizontal_resolution; | 
|  | 1238 | u32 vertical_resolution; | 
|  | 1239 | int pixel_format; | 
|  | 1240 | struct efi_pixel_bitmask pixel_information; | 
|  | 1241 | u32 pixels_per_scan_line; | 
|  | 1242 | } __packed; | 
|  | 1243 |  | 
|  | 1244 | struct efi_graphics_output_protocol_mode_32 { | 
|  | 1245 | u32 max_mode; | 
|  | 1246 | u32 mode; | 
|  | 1247 | u32 info; | 
|  | 1248 | u32 size_of_info; | 
|  | 1249 | u64 frame_buffer_base; | 
|  | 1250 | u32 frame_buffer_size; | 
|  | 1251 | } __packed; | 
|  | 1252 |  | 
|  | 1253 | struct efi_graphics_output_protocol_mode_64 { | 
|  | 1254 | u32 max_mode; | 
|  | 1255 | u32 mode; | 
|  | 1256 | u64 info; | 
|  | 1257 | u64 size_of_info; | 
|  | 1258 | u64 frame_buffer_base; | 
|  | 1259 | u64 frame_buffer_size; | 
|  | 1260 | } __packed; | 
|  | 1261 |  | 
|  | 1262 | struct efi_graphics_output_protocol_mode { | 
|  | 1263 | u32 max_mode; | 
|  | 1264 | u32 mode; | 
|  | 1265 | unsigned long info; | 
|  | 1266 | unsigned long size_of_info; | 
|  | 1267 | u64 frame_buffer_base; | 
|  | 1268 | unsigned long frame_buffer_size; | 
|  | 1269 | } __packed; | 
|  | 1270 |  | 
|  | 1271 | struct efi_graphics_output_protocol_32 { | 
|  | 1272 | u32 query_mode; | 
|  | 1273 | u32 set_mode; | 
|  | 1274 | u32 blt; | 
|  | 1275 | u32 mode; | 
|  | 1276 | }; | 
|  | 1277 |  | 
|  | 1278 | struct efi_graphics_output_protocol_64 { | 
|  | 1279 | u64 query_mode; | 
|  | 1280 | u64 set_mode; | 
|  | 1281 | u64 blt; | 
|  | 1282 | u64 mode; | 
|  | 1283 | }; | 
|  | 1284 |  | 
|  | 1285 | struct efi_graphics_output_protocol { | 
|  | 1286 | unsigned long query_mode; | 
|  | 1287 | unsigned long set_mode; | 
|  | 1288 | unsigned long blt; | 
|  | 1289 | struct efi_graphics_output_protocol_mode *mode; | 
|  | 1290 | }; | 
|  | 1291 |  | 
|  | 1292 | typedef efi_status_t (*efi_graphics_output_protocol_query_mode)( | 
|  | 1293 | struct efi_graphics_output_protocol *, u32, unsigned long *, | 
|  | 1294 | struct efi_graphics_output_mode_info **); | 
|  | 1295 |  | 
| Matt Fleming | 0485177 | 2013-02-08 15:48:51 +0000 | [diff] [blame] | 1296 | extern struct list_head efivar_sysfs_list; | 
|  | 1297 |  | 
|  | 1298 | static inline void | 
|  | 1299 | efivar_unregister(struct efivar_entry *var) | 
|  | 1300 | { | 
|  | 1301 | kobject_put(&var->kobj); | 
|  | 1302 | } | 
|  | 1303 |  | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1304 | int efivars_register(struct efivars *efivars, | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1305 | const struct efivar_operations *ops, | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1306 | struct kobject *kobject); | 
|  | 1307 | int efivars_unregister(struct efivars *efivars); | 
|  | 1308 | struct kobject *efivars_kobject(void); | 
|  | 1309 |  | 
|  | 1310 | int efivar_init(int (*func)(efi_char16_t *, efi_guid_t, unsigned long, void *), | 
| Julia Lawall | 1cfd631 | 2016-05-06 22:39:30 +0100 | [diff] [blame] | 1311 | void *data, bool duplicates, struct list_head *head); | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1312 |  | 
| Sylvain Chouleur | 21b3ddd | 2016-07-15 21:36:30 +0200 | [diff] [blame] | 1313 | int efivar_entry_add(struct efivar_entry *entry, struct list_head *head); | 
|  | 1314 | int efivar_entry_remove(struct efivar_entry *entry); | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1315 |  | 
|  | 1316 | int __efivar_entry_delete(struct efivar_entry *entry); | 
|  | 1317 | int efivar_entry_delete(struct efivar_entry *entry); | 
|  | 1318 |  | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1319 | int efivar_entry_size(struct efivar_entry *entry, unsigned long *size); | 
| Matt Fleming | 8a415b8 | 2013-04-29 20:08:02 +0100 | [diff] [blame] | 1320 | int __efivar_entry_get(struct efivar_entry *entry, u32 *attributes, | 
|  | 1321 | unsigned long *size, void *data); | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1322 | int efivar_entry_get(struct efivar_entry *entry, u32 *attributes, | 
|  | 1323 | unsigned long *size, void *data); | 
|  | 1324 | int efivar_entry_set(struct efivar_entry *entry, u32 attributes, | 
|  | 1325 | unsigned long size, void *data, struct list_head *head); | 
|  | 1326 | int efivar_entry_set_get_size(struct efivar_entry *entry, u32 attributes, | 
|  | 1327 | unsigned long *size, void *data, bool *set); | 
|  | 1328 | int efivar_entry_set_safe(efi_char16_t *name, efi_guid_t vendor, u32 attributes, | 
|  | 1329 | bool block, unsigned long size, void *data); | 
|  | 1330 |  | 
| Sylvain Chouleur | 21b3ddd | 2016-07-15 21:36:30 +0200 | [diff] [blame] | 1331 | int efivar_entry_iter_begin(void); | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1332 | void efivar_entry_iter_end(void); | 
|  | 1333 |  | 
|  | 1334 | int __efivar_entry_iter(int (*func)(struct efivar_entry *, void *), | 
|  | 1335 | struct list_head *head, void *data, | 
|  | 1336 | struct efivar_entry **prev); | 
|  | 1337 | int efivar_entry_iter(int (*func)(struct efivar_entry *, void *), | 
|  | 1338 | struct list_head *head, void *data); | 
|  | 1339 |  | 
|  | 1340 | struct efivar_entry *efivar_entry_find(efi_char16_t *name, efi_guid_t guid, | 
|  | 1341 | struct list_head *head, bool remove); | 
|  | 1342 |  | 
| Peter Jones | 8282f5d | 2016-02-08 14:48:14 -0500 | [diff] [blame] | 1343 | bool efivar_validate(efi_guid_t vendor, efi_char16_t *var_name, u8 *data, | 
|  | 1344 | unsigned long data_size); | 
| Peter Jones | ed8b0de | 2016-02-08 14:48:15 -0500 | [diff] [blame] | 1345 | bool efivar_variable_is_removable(efi_guid_t vendor, const char *name, | 
|  | 1346 | size_t len); | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1347 |  | 
| Tom Gundersen | a9499fa | 2013-02-08 15:37:06 +0000 | [diff] [blame] | 1348 | extern struct work_struct efivar_work; | 
| Matt Fleming | 0485177 | 2013-02-08 15:48:51 +0000 | [diff] [blame] | 1349 | void efivar_run_worker(void); | 
|  | 1350 |  | 
| Tom Gundersen | a9499fa | 2013-02-08 15:37:06 +0000 | [diff] [blame] | 1351 | #if defined(CONFIG_EFI_VARS) || defined(CONFIG_EFI_VARS_MODULE) | 
| Matt Fleming | e14ab23 | 2013-02-03 20:16:40 +0000 | [diff] [blame] | 1352 | int efivars_sysfs_init(void); | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1353 |  | 
| Seiji Aguchi | e0d5973 | 2013-10-30 15:27:26 -0400 | [diff] [blame] | 1354 | #define EFIVARS_DATA_SIZE_MAX 1024 | 
|  | 1355 |  | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1356 | #endif /* CONFIG_EFI_VARS */ | 
| Matt Fleming | f0133f3 | 2016-04-25 21:06:59 +0100 | [diff] [blame] | 1357 | extern bool efi_capsule_pending(int *reset_type); | 
|  | 1358 |  | 
|  | 1359 | extern int efi_capsule_supported(efi_guid_t guid, u32 flags, | 
|  | 1360 | size_t size, int *reset); | 
|  | 1361 |  | 
|  | 1362 | extern int efi_capsule_update(efi_capsule_header_t *capsule, | 
|  | 1363 | struct page **pages); | 
| Mike Waychison | 4fc756b | 2011-03-11 17:43:27 -0800 | [diff] [blame] | 1364 |  | 
| Dave Young | 926172d | 2013-12-20 18:02:18 +0800 | [diff] [blame] | 1365 | #ifdef CONFIG_EFI_RUNTIME_MAP | 
|  | 1366 | int efi_runtime_map_init(struct kobject *); | 
| Vivek Goyal | 6a2c20e | 2014-08-08 14:26:11 -0700 | [diff] [blame] | 1367 | int efi_get_runtime_map_size(void); | 
|  | 1368 | int efi_get_runtime_map_desc_size(void); | 
|  | 1369 | int efi_runtime_map_copy(void *buf, size_t bufsz); | 
| Dave Young | 926172d | 2013-12-20 18:02:18 +0800 | [diff] [blame] | 1370 | #else | 
|  | 1371 | static inline int efi_runtime_map_init(struct kobject *kobj) | 
|  | 1372 | { | 
|  | 1373 | return 0; | 
|  | 1374 | } | 
|  | 1375 |  | 
| Vivek Goyal | 6a2c20e | 2014-08-08 14:26:11 -0700 | [diff] [blame] | 1376 | static inline int efi_get_runtime_map_size(void) | 
|  | 1377 | { | 
|  | 1378 | return 0; | 
|  | 1379 | } | 
|  | 1380 |  | 
|  | 1381 | static inline int efi_get_runtime_map_desc_size(void) | 
|  | 1382 | { | 
|  | 1383 | return 0; | 
|  | 1384 | } | 
|  | 1385 |  | 
|  | 1386 | static inline int efi_runtime_map_copy(void *buf, size_t bufsz) | 
|  | 1387 | { | 
|  | 1388 | return 0; | 
|  | 1389 | } | 
|  | 1390 |  | 
| Dave Young | 926172d | 2013-12-20 18:02:18 +0800 | [diff] [blame] | 1391 | #endif | 
|  | 1392 |  | 
| Ard Biesheuvel | bd66947 | 2014-07-02 14:54:42 +0200 | [diff] [blame] | 1393 | /* prototypes shared between arch specific and generic stub code */ | 
|  | 1394 |  | 
|  | 1395 | #define pr_efi(sys_table, msg)     efi_printk(sys_table, "EFI stub: "msg) | 
|  | 1396 | #define pr_efi_err(sys_table, msg) efi_printk(sys_table, "EFI stub: ERROR: "msg) | 
|  | 1397 |  | 
|  | 1398 | void efi_printk(efi_system_table_t *sys_table_arg, char *str); | 
|  | 1399 |  | 
|  | 1400 | void efi_free(efi_system_table_t *sys_table_arg, unsigned long size, | 
|  | 1401 | unsigned long addr); | 
|  | 1402 |  | 
|  | 1403 | char *efi_convert_cmdline(efi_system_table_t *sys_table_arg, | 
|  | 1404 | efi_loaded_image_t *image, int *cmd_line_len); | 
|  | 1405 |  | 
|  | 1406 | efi_status_t efi_get_memory_map(efi_system_table_t *sys_table_arg, | 
| Jeffrey Hugo | dadb57a | 2016-08-29 14:38:51 -0600 | [diff] [blame] | 1407 | struct efi_boot_memmap *map); | 
| Ard Biesheuvel | bd66947 | 2014-07-02 14:54:42 +0200 | [diff] [blame] | 1408 |  | 
|  | 1409 | efi_status_t efi_low_alloc(efi_system_table_t *sys_table_arg, | 
|  | 1410 | unsigned long size, unsigned long align, | 
|  | 1411 | unsigned long *addr); | 
|  | 1412 |  | 
|  | 1413 | efi_status_t efi_high_alloc(efi_system_table_t *sys_table_arg, | 
|  | 1414 | unsigned long size, unsigned long align, | 
|  | 1415 | unsigned long *addr, unsigned long max); | 
|  | 1416 |  | 
|  | 1417 | efi_status_t efi_relocate_kernel(efi_system_table_t *sys_table_arg, | 
|  | 1418 | unsigned long *image_addr, | 
|  | 1419 | unsigned long image_size, | 
|  | 1420 | unsigned long alloc_size, | 
|  | 1421 | unsigned long preferred_addr, | 
|  | 1422 | unsigned long alignment); | 
|  | 1423 |  | 
|  | 1424 | efi_status_t handle_cmdline_files(efi_system_table_t *sys_table_arg, | 
|  | 1425 | efi_loaded_image_t *image, | 
|  | 1426 | char *cmd_line, char *option_string, | 
|  | 1427 | unsigned long max_addr, | 
|  | 1428 | unsigned long *load_addr, | 
|  | 1429 | unsigned long *load_size); | 
|  | 1430 |  | 
| Matt Fleming | 5a17dae | 2014-08-05 11:52:11 +0100 | [diff] [blame] | 1431 | efi_status_t efi_parse_options(char *cmdline); | 
|  | 1432 |  | 
| Ard Biesheuvel | 2c23b73 | 2016-04-25 21:06:48 +0100 | [diff] [blame] | 1433 | efi_status_t efi_setup_gop(efi_system_table_t *sys_table_arg, | 
|  | 1434 | struct screen_info *si, efi_guid_t *proto, | 
|  | 1435 | unsigned long size); | 
|  | 1436 |  | 
| Dave Young | b2e0a54 | 2014-08-14 17:15:26 +0800 | [diff] [blame] | 1437 | bool efi_runtime_disabled(void); | 
| Alex Thorlton | 80e7559 | 2016-06-25 08:20:27 +0100 | [diff] [blame] | 1438 | extern void efi_call_virt_check_flags(unsigned long flags, const char *call); | 
|  | 1439 |  | 
|  | 1440 | /* | 
|  | 1441 | * Arch code can implement the following three template macros, avoiding | 
|  | 1442 | * reptition for the void/non-void return cases of {__,}efi_call_virt(): | 
|  | 1443 | * | 
|  | 1444 | *  * arch_efi_call_virt_setup() | 
|  | 1445 | * | 
|  | 1446 | *    Sets up the environment for the call (e.g. switching page tables, | 
|  | 1447 | *    allowing kernel-mode use of floating point, if required). | 
|  | 1448 | * | 
|  | 1449 | *  * arch_efi_call_virt() | 
|  | 1450 | * | 
|  | 1451 | *    Performs the call. The last expression in the macro must be the call | 
|  | 1452 | *    itself, allowing the logic to be shared by the void and non-void | 
|  | 1453 | *    cases. | 
|  | 1454 | * | 
|  | 1455 | *  * arch_efi_call_virt_teardown() | 
|  | 1456 | * | 
|  | 1457 | *    Restores the usual kernel environment once the call has returned. | 
|  | 1458 | */ | 
|  | 1459 |  | 
|  | 1460 | #define efi_call_virt_pointer(p, f, args...)				\ | 
|  | 1461 | ({									\ | 
|  | 1462 | efi_status_t __s;						\ | 
|  | 1463 | unsigned long __flags;						\ | 
|  | 1464 | \ | 
|  | 1465 | arch_efi_call_virt_setup();					\ | 
|  | 1466 | \ | 
|  | 1467 | local_save_flags(__flags);					\ | 
|  | 1468 | __s = arch_efi_call_virt(p, f, args);				\ | 
|  | 1469 | efi_call_virt_check_flags(__flags, __stringify(f));		\ | 
|  | 1470 | \ | 
|  | 1471 | arch_efi_call_virt_teardown();					\ | 
|  | 1472 | \ | 
|  | 1473 | __s;								\ | 
|  | 1474 | }) | 
|  | 1475 |  | 
|  | 1476 | #define __efi_call_virt_pointer(p, f, args...)				\ | 
|  | 1477 | ({									\ | 
|  | 1478 | unsigned long __flags;						\ | 
|  | 1479 | \ | 
|  | 1480 | arch_efi_call_virt_setup();					\ | 
|  | 1481 | \ | 
|  | 1482 | local_save_flags(__flags);					\ | 
|  | 1483 | arch_efi_call_virt(p, f, args);					\ | 
|  | 1484 | efi_call_virt_check_flags(__flags, __stringify(f));		\ | 
|  | 1485 | \ | 
|  | 1486 | arch_efi_call_virt_teardown();					\ | 
|  | 1487 | }) | 
|  | 1488 |  | 
| Jeffrey Hugo | fc07716 | 2016-08-29 14:38:52 -0600 | [diff] [blame] | 1489 | typedef efi_status_t (*efi_exit_boot_map_processing)( | 
|  | 1490 | efi_system_table_t *sys_table_arg, | 
|  | 1491 | struct efi_boot_memmap *map, | 
|  | 1492 | void *priv); | 
|  | 1493 |  | 
|  | 1494 | efi_status_t efi_exit_boot_services(efi_system_table_t *sys_table, | 
|  | 1495 | void *handle, | 
|  | 1496 | struct efi_boot_memmap *map, | 
|  | 1497 | void *priv, | 
|  | 1498 | efi_exit_boot_map_processing priv_func); | 
| Ard Biesheuvel | 6362598 | 2016-11-12 21:32:31 +0000 | [diff] [blame] | 1499 |  | 
|  | 1500 | struct linux_efi_random_seed { | 
|  | 1501 | u32	size; | 
|  | 1502 | u8	bits[]; | 
|  | 1503 | }; | 
|  | 1504 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1505 | #endif /* _LINUX_EFI_H */ |