xref: /rk3399_rockchip-uboot/include/efi_api.h (revision 2bb9b79d64ca5112af3147a267ece894945aa470)
1867a6ac8SSimon Glass /*
2867a6ac8SSimon Glass  * Extensible Firmware Interface
3867a6ac8SSimon Glass  * Based on 'Extensible Firmware Interface Specification' version 0.9,
4867a6ac8SSimon Glass  * April 30, 1999
5867a6ac8SSimon Glass  *
6867a6ac8SSimon Glass  * Copyright (C) 1999 VA Linux Systems
7867a6ac8SSimon Glass  * Copyright (C) 1999 Walt Drummond <drummond@valinux.com>
8867a6ac8SSimon Glass  * Copyright (C) 1999, 2002-2003 Hewlett-Packard Co.
9867a6ac8SSimon Glass  *	David Mosberger-Tang <davidm@hpl.hp.com>
10867a6ac8SSimon Glass  *	Stephane Eranian <eranian@hpl.hp.com>
11867a6ac8SSimon Glass  *
12867a6ac8SSimon Glass  * From include/linux/efi.h in kernel 4.1 with some additions/subtractions
13867a6ac8SSimon Glass  */
14867a6ac8SSimon Glass 
15867a6ac8SSimon Glass #ifndef _EFI_API_H
16867a6ac8SSimon Glass #define _EFI_API_H
17867a6ac8SSimon Glass 
18867a6ac8SSimon Glass #include <efi.h>
19867a6ac8SSimon Glass 
20*2bb9b79dSAlexander Graf /* Types and defines for EFI CreateEvent */
21*2bb9b79dSAlexander Graf enum efi_event_type {
22*2bb9b79dSAlexander Graf 	EFI_TIMER_STOP = 0,
23*2bb9b79dSAlexander Graf 	EFI_TIMER_PERIODIC = 1,
24*2bb9b79dSAlexander Graf 	EFI_TIMER_RELATIVE = 2
25*2bb9b79dSAlexander Graf };
26*2bb9b79dSAlexander Graf 
27867a6ac8SSimon Glass /* EFI Boot Services table */
28867a6ac8SSimon Glass struct efi_boot_services {
29867a6ac8SSimon Glass 	struct efi_table_hdr hdr;
30*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *raise_tpl)(unsigned long new_tpl);
31*2bb9b79dSAlexander Graf 	void (EFIAPI *restore_tpl)(unsigned long old_tpl);
32867a6ac8SSimon Glass 
33867a6ac8SSimon Glass 	efi_status_t (EFIAPI *allocate_pages)(int, int, unsigned long,
34867a6ac8SSimon Glass 					      efi_physical_addr_t *);
35867a6ac8SSimon Glass 	efi_status_t (EFIAPI *free_pages)(efi_physical_addr_t, unsigned long);
36867a6ac8SSimon Glass 	efi_status_t (EFIAPI *get_memory_map)(unsigned long *memory_map_size,
37867a6ac8SSimon Glass 			struct efi_mem_desc *desc, unsigned long *key,
38867a6ac8SSimon Glass 			unsigned long *desc_size, u32 *desc_version);
39867a6ac8SSimon Glass 	efi_status_t (EFIAPI *allocate_pool)(int, unsigned long, void **);
40867a6ac8SSimon Glass 	efi_status_t (EFIAPI *free_pool)(void *);
41867a6ac8SSimon Glass 
42*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *create_event)(enum efi_event_type type,
43*2bb9b79dSAlexander Graf 			unsigned long notify_tpl,
44*2bb9b79dSAlexander Graf 			void (EFIAPI *notify_function) (void *event,
45*2bb9b79dSAlexander Graf 							void *context),
46*2bb9b79dSAlexander Graf 			void *notify_context, void **event);
47*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_timer)(void *event, int type,
48*2bb9b79dSAlexander Graf 			uint64_t trigger_time);
49867a6ac8SSimon Glass 	efi_status_t (EFIAPI *wait_for_event)(unsigned long number_of_events,
50867a6ac8SSimon Glass 			void *event, unsigned long *index);
51*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *signal_event)(void *event);
52*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *close_event)(void *event);
53*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *check_event)(void *event);
54867a6ac8SSimon Glass 
55*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *install_protocol_interface)(
56*2bb9b79dSAlexander Graf 			void **handle, efi_guid_t *protocol,
57*2bb9b79dSAlexander Graf 			int protocol_interface_type, void *protocol_interface);
58*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *reinstall_protocol_interface)(
59*2bb9b79dSAlexander Graf 			void *handle, efi_guid_t *protocol,
60*2bb9b79dSAlexander Graf 			void *old_interface, void *new_interface);
61*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *uninstall_protocol_interface)(void *handle,
62*2bb9b79dSAlexander Graf 			efi_guid_t *protocol, void *protocol_interface);
63867a6ac8SSimon Glass 	efi_status_t (EFIAPI *handle_protocol)(efi_handle_t, efi_guid_t *,
64867a6ac8SSimon Glass 					       void **);
65867a6ac8SSimon Glass 	void *reserved;
66*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *register_protocol_notify)(
67*2bb9b79dSAlexander Graf 			efi_guid_t *protocol, void *event,
68*2bb9b79dSAlexander Graf 			void **registration);
69867a6ac8SSimon Glass 	efi_status_t (EFIAPI *locate_handle)(
70867a6ac8SSimon Glass 			enum efi_locate_search_type search_type,
71867a6ac8SSimon Glass 			efi_guid_t *protocol, void *search_key,
72867a6ac8SSimon Glass 			unsigned long *buffer_size, efi_handle_t *buffer);
73867a6ac8SSimon Glass 	efi_status_t (EFIAPI *locate_device_path)(efi_guid_t *protocol,
74867a6ac8SSimon Glass 			struct efi_device_path **device_path,
75867a6ac8SSimon Glass 			efi_handle_t *device);
76*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *install_configuration_table)(
77*2bb9b79dSAlexander Graf 			efi_guid_t *guid, void *table);
78867a6ac8SSimon Glass 
79867a6ac8SSimon Glass 	efi_status_t (EFIAPI *load_image)(bool boot_policiy,
80867a6ac8SSimon Glass 			efi_handle_t parent_image,
81867a6ac8SSimon Glass 			struct efi_device_path *file_path, void *source_buffer,
82867a6ac8SSimon Glass 			unsigned long source_size, efi_handle_t *image);
83867a6ac8SSimon Glass 	efi_status_t (EFIAPI *start_image)(efi_handle_t handle,
84867a6ac8SSimon Glass 					   unsigned long *exitdata_size,
85867a6ac8SSimon Glass 					   s16 **exitdata);
86867a6ac8SSimon Glass 	efi_status_t (EFIAPI *exit)(efi_handle_t handle,
87867a6ac8SSimon Glass 				    efi_status_t exit_status,
88867a6ac8SSimon Glass 				    unsigned long exitdata_size, s16 *exitdata);
89*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *unload_image)(void *image_handle);
90867a6ac8SSimon Glass 	efi_status_t (EFIAPI *exit_boot_services)(efi_handle_t, unsigned long);
91867a6ac8SSimon Glass 
92867a6ac8SSimon Glass 	efi_status_t (EFIAPI *get_next_monotonic_count)(u64 *count);
93867a6ac8SSimon Glass 	efi_status_t (EFIAPI *stall)(unsigned long usecs);
94*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_watchdog_timer)(unsigned long timeout,
95*2bb9b79dSAlexander Graf 			uint64_t watchdog_code, unsigned long data_size,
96*2bb9b79dSAlexander Graf 			uint16_t *watchdog_data);
97867a6ac8SSimon Glass 	efi_status_t(EFIAPI *connect_controller)(efi_handle_t controller_handle,
98867a6ac8SSimon Glass 			efi_handle_t *driver_image_handle,
99867a6ac8SSimon Glass 			struct efi_device_path *remaining_device_path,
100867a6ac8SSimon Glass 			bool recursive);
101*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *disconnect_controller)(void *controller_handle,
102*2bb9b79dSAlexander Graf 			void *driver_image_handle, void *child_handle);
103867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_BY_HANDLE_PROTOCOL  0x00000001
104867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_GET_PROTOCOL        0x00000002
105867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_TEST_PROTOCOL       0x00000004
106867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_BY_CHILD_CONTROLLER 0x00000008
107867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_BY_DRIVER           0x00000010
108867a6ac8SSimon Glass #define EFI_OPEN_PROTOCOL_EXCLUSIVE           0x00000020
109867a6ac8SSimon Glass 	efi_status_t (EFIAPI *open_protocol)(efi_handle_t handle,
110867a6ac8SSimon Glass 			efi_guid_t *protocol, void **interface,
111867a6ac8SSimon Glass 			efi_handle_t agent_handle,
112867a6ac8SSimon Glass 			efi_handle_t controller_handle, u32 attributes);
113*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *close_protocol)(void *handle,
114*2bb9b79dSAlexander Graf 			efi_guid_t *protocol, void *agent_handle,
115*2bb9b79dSAlexander Graf 			void *controller_handle);
116867a6ac8SSimon Glass 	efi_status_t(EFIAPI *open_protocol_information)(efi_handle_t handle,
117867a6ac8SSimon Glass 			efi_guid_t *protocol,
118867a6ac8SSimon Glass 			struct efi_open_protocol_info_entry **entry_buffer,
119867a6ac8SSimon Glass 			unsigned long *entry_count);
120867a6ac8SSimon Glass 	efi_status_t (EFIAPI *protocols_per_handle)(efi_handle_t handle,
121867a6ac8SSimon Glass 			efi_guid_t ***protocol_buffer,
122867a6ac8SSimon Glass 			unsigned long *protocols_buffer_count);
123867a6ac8SSimon Glass 	efi_status_t (EFIAPI *locate_handle_buffer) (
124867a6ac8SSimon Glass 			enum efi_locate_search_type search_type,
125867a6ac8SSimon Glass 			efi_guid_t *protocol, void *search_key,
126867a6ac8SSimon Glass 			unsigned long *no_handles, efi_handle_t **buffer);
127*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *locate_protocol)(efi_guid_t *protocol,
128*2bb9b79dSAlexander Graf 			void *registration, void **protocol_interface);
129*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *install_multiple_protocol_interfaces)(
130*2bb9b79dSAlexander Graf 			void **handle, ...);
131*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *uninstall_multiple_protocol_interfaces)(
132*2bb9b79dSAlexander Graf 			void *handle, ...);
133*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *calculate_crc32)(void *data,
134*2bb9b79dSAlexander Graf 			unsigned long data_size, uint32_t *crc32);
135*2bb9b79dSAlexander Graf 	void (EFIAPI *copy_mem)(void *destination, void *source,
136*2bb9b79dSAlexander Graf 			unsigned long length);
137*2bb9b79dSAlexander Graf 	void (EFIAPI *set_mem)(void *buffer, unsigned long size,
138*2bb9b79dSAlexander Graf 			uint8_t value);
139867a6ac8SSimon Glass 	void *create_event_ex;
140867a6ac8SSimon Glass };
141867a6ac8SSimon Glass 
142867a6ac8SSimon Glass /* Types and defines for EFI ResetSystem */
143867a6ac8SSimon Glass enum efi_reset_type {
144867a6ac8SSimon Glass 	EFI_RESET_COLD = 0,
145867a6ac8SSimon Glass 	EFI_RESET_WARM = 1,
146867a6ac8SSimon Glass 	EFI_RESET_SHUTDOWN = 2
147867a6ac8SSimon Glass };
148867a6ac8SSimon Glass 
149867a6ac8SSimon Glass /* EFI Runtime Services table */
150867a6ac8SSimon Glass #define EFI_RUNTIME_SERVICES_SIGNATURE	0x5652453544e5552ULL
151867a6ac8SSimon Glass #define EFI_RUNTIME_SERVICES_REVISION	0x00010000
152867a6ac8SSimon Glass 
153867a6ac8SSimon Glass struct efi_runtime_services {
154867a6ac8SSimon Glass 	struct efi_table_hdr hdr;
155*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *get_time)(struct efi_time *time,
156*2bb9b79dSAlexander Graf 			struct efi_time_cap *capabilities);
157*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_time)(struct efi_time *time);
158*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *get_wakeup_time)(char *enabled, char *pending,
159*2bb9b79dSAlexander Graf 			struct efi_time *time);
160*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_wakeup_time)(char enabled,
161*2bb9b79dSAlexander Graf 			struct efi_time *time);
162*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_virtual_address_map)(
163*2bb9b79dSAlexander Graf 			unsigned long memory_map_size,
164*2bb9b79dSAlexander Graf 			unsigned long descriptor_size,
165*2bb9b79dSAlexander Graf 			uint32_t descriptor_version,
166*2bb9b79dSAlexander Graf 			struct efi_mem_desc *virtmap);
167*2bb9b79dSAlexander Graf 	efi_status_t (*convert_pointer)(unsigned long dbg, void **address);
168867a6ac8SSimon Glass 	efi_status_t (EFIAPI *get_variable)(s16 *variable_name,
169867a6ac8SSimon Glass 			efi_guid_t *vendor, u32 *attributes,
170867a6ac8SSimon Glass 			unsigned long *data_size, void *data);
171867a6ac8SSimon Glass 	efi_status_t (EFIAPI *get_next_variable)(
172867a6ac8SSimon Glass 			unsigned long *variable_name_size,
173867a6ac8SSimon Glass 			s16 *variable_name, efi_guid_t *vendor);
174867a6ac8SSimon Glass 	efi_status_t (EFIAPI *set_variable)(s16 *variable_name,
175867a6ac8SSimon Glass 			efi_guid_t *vendor, u32 attributes,
176867a6ac8SSimon Glass 			unsigned long data_size, void *data);
177*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *get_next_high_mono_count)(
178*2bb9b79dSAlexander Graf 			uint32_t *high_count);
179867a6ac8SSimon Glass 	void (EFIAPI *reset_system)(enum efi_reset_type reset_type,
180867a6ac8SSimon Glass 				    efi_status_t reset_status,
181867a6ac8SSimon Glass 				    unsigned long data_size, void *reset_data);
182867a6ac8SSimon Glass 	void *update_capsule;
183867a6ac8SSimon Glass 	void *query_capsule_caps;
184867a6ac8SSimon Glass 	void *query_variable_info;
185867a6ac8SSimon Glass };
186867a6ac8SSimon Glass 
187867a6ac8SSimon Glass /* EFI Configuration Table and GUID definitions */
188867a6ac8SSimon Glass #define NULL_GUID \
189867a6ac8SSimon Glass 	EFI_GUID(0x00000000, 0x0000, 0x0000, 0x00, 0x00, \
190867a6ac8SSimon Glass 		 0x00, 0x00, 0x00, 0x00, 0x00, 0x00)
191867a6ac8SSimon Glass 
192867a6ac8SSimon Glass #define LOADED_IMAGE_PROTOCOL_GUID \
193867a6ac8SSimon Glass 	EFI_GUID(0x5b1b31a1, 0x9562, 0x11d2, 0x8e, 0x3f, \
194867a6ac8SSimon Glass 		 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b)
195867a6ac8SSimon Glass 
196*2bb9b79dSAlexander Graf #define EFI_FDT_GUID \
197*2bb9b79dSAlexander Graf 	EFI_GUID(0xb1b621d5, 0xf19c, 0x41a5, \
198*2bb9b79dSAlexander Graf 		 0x83, 0x0b, 0xd9, 0x15, 0x2c, 0x69, 0xaa, 0xe0)
199*2bb9b79dSAlexander Graf 
200*2bb9b79dSAlexander Graf struct efi_configuration_table
201*2bb9b79dSAlexander Graf {
202*2bb9b79dSAlexander Graf 	efi_guid_t guid;
203*2bb9b79dSAlexander Graf 	void *table;
204*2bb9b79dSAlexander Graf };
205*2bb9b79dSAlexander Graf 
206*2bb9b79dSAlexander Graf #define EFI_SYSTEM_TABLE_SIGNATURE ((u64)0x5453595320494249ULL)
207*2bb9b79dSAlexander Graf 
208867a6ac8SSimon Glass struct efi_system_table {
209867a6ac8SSimon Glass 	struct efi_table_hdr hdr;
210867a6ac8SSimon Glass 	unsigned long fw_vendor;   /* physical addr of wchar_t vendor string */
211867a6ac8SSimon Glass 	u32 fw_revision;
212867a6ac8SSimon Glass 	unsigned long con_in_handle;
213867a6ac8SSimon Glass 	struct efi_simple_input_interface *con_in;
214867a6ac8SSimon Glass 	unsigned long con_out_handle;
215867a6ac8SSimon Glass 	struct efi_simple_text_output_protocol *con_out;
216867a6ac8SSimon Glass 	unsigned long stderr_handle;
217*2bb9b79dSAlexander Graf 	struct efi_simple_text_output_protocol *std_err;
218867a6ac8SSimon Glass 	struct efi_runtime_services *runtime;
219867a6ac8SSimon Glass 	struct efi_boot_services *boottime;
220867a6ac8SSimon Glass 	unsigned long nr_tables;
221*2bb9b79dSAlexander Graf 	struct efi_configuration_table *tables;
222867a6ac8SSimon Glass };
223867a6ac8SSimon Glass 
224*2bb9b79dSAlexander Graf #define LOADED_IMAGE_GUID \
225*2bb9b79dSAlexander Graf 	EFI_GUID(0x5b1b31a1, 0x9562, 0x11d2, \
226*2bb9b79dSAlexander Graf 		 0x8e, 0x3f, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b)
227*2bb9b79dSAlexander Graf 
228867a6ac8SSimon Glass struct efi_loaded_image {
229867a6ac8SSimon Glass 	u32 revision;
230867a6ac8SSimon Glass 	void *parent_handle;
231867a6ac8SSimon Glass 	struct efi_system_table *system_table;
232867a6ac8SSimon Glass 	void *device_handle;
233867a6ac8SSimon Glass 	void *file_path;
234867a6ac8SSimon Glass 	void *reserved;
235867a6ac8SSimon Glass 	u32 load_options_size;
236867a6ac8SSimon Glass 	void *load_options;
237867a6ac8SSimon Glass 	void *image_base;
238867a6ac8SSimon Glass 	aligned_u64 image_size;
239867a6ac8SSimon Glass 	unsigned int image_code_type;
240867a6ac8SSimon Glass 	unsigned int image_data_type;
241867a6ac8SSimon Glass 	unsigned long unload;
242867a6ac8SSimon Glass };
243867a6ac8SSimon Glass 
244*2bb9b79dSAlexander Graf #define DEVICE_PATH_GUID \
245*2bb9b79dSAlexander Graf 	EFI_GUID(0x09576e91, 0x6d3f, 0x11d2, \
246*2bb9b79dSAlexander Graf 		 0x8e, 0x39, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b )
247*2bb9b79dSAlexander Graf 
248*2bb9b79dSAlexander Graf #define DEVICE_PATH_TYPE_END			0x7f
249*2bb9b79dSAlexander Graf #  define DEVICE_PATH_SUB_TYPE_END		0xff
250*2bb9b79dSAlexander Graf 
251867a6ac8SSimon Glass struct efi_device_path {
252867a6ac8SSimon Glass 	u8 type;
253867a6ac8SSimon Glass 	u8 sub_type;
254867a6ac8SSimon Glass 	u16 length;
255867a6ac8SSimon Glass };
256867a6ac8SSimon Glass 
257*2bb9b79dSAlexander Graf #define DEVICE_PATH_TYPE_MEDIA_DEVICE		0x04
258*2bb9b79dSAlexander Graf #  define DEVICE_PATH_SUB_TYPE_FILE_PATH	0x04
259*2bb9b79dSAlexander Graf 
260*2bb9b79dSAlexander Graf struct efi_device_path_file_path {
261*2bb9b79dSAlexander Graf 	struct efi_device_path dp;
262*2bb9b79dSAlexander Graf 	u16 str[16];
263*2bb9b79dSAlexander Graf };
264*2bb9b79dSAlexander Graf 
265*2bb9b79dSAlexander Graf #define BLOCK_IO_GUID \
266*2bb9b79dSAlexander Graf 	EFI_GUID(0x964e5b21, 0x6459, 0x11d2, \
267*2bb9b79dSAlexander Graf 		 0x8e, 0x39, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b)
268*2bb9b79dSAlexander Graf 
269*2bb9b79dSAlexander Graf struct efi_block_io_media
270*2bb9b79dSAlexander Graf {
271*2bb9b79dSAlexander Graf 	u32 media_id;
272*2bb9b79dSAlexander Graf 	char removable_media;
273*2bb9b79dSAlexander Graf 	char media_present;
274*2bb9b79dSAlexander Graf 	char logical_partition;
275*2bb9b79dSAlexander Graf 	char read_only;
276*2bb9b79dSAlexander Graf 	char write_caching;
277*2bb9b79dSAlexander Graf 	u8 pad[3];
278*2bb9b79dSAlexander Graf 	u32 block_size;
279*2bb9b79dSAlexander Graf 	u32 io_align;
280*2bb9b79dSAlexander Graf 	u8 pad2[4];
281*2bb9b79dSAlexander Graf 	u64 last_block;
282*2bb9b79dSAlexander Graf };
283*2bb9b79dSAlexander Graf 
284*2bb9b79dSAlexander Graf struct efi_block_io {
285*2bb9b79dSAlexander Graf 	u64 revision;
286*2bb9b79dSAlexander Graf 	struct efi_block_io_media *media;
287*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *reset)(struct efi_block_io *this,
288*2bb9b79dSAlexander Graf 			char extended_verification);
289*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *read_blocks)(struct efi_block_io *this,
290*2bb9b79dSAlexander Graf 			u32 media_id, u64 lba, unsigned long buffer_size,
291*2bb9b79dSAlexander Graf 			void *buffer);
292*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *write_blocks)(struct efi_block_io *this,
293*2bb9b79dSAlexander Graf 			u32 media_id, u64 lba, unsigned long buffer_size,
294*2bb9b79dSAlexander Graf 			void *buffer);
295*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *flush_blocks)(struct efi_block_io *this);
296*2bb9b79dSAlexander Graf };
297*2bb9b79dSAlexander Graf 
298867a6ac8SSimon Glass struct simple_text_output_mode {
299867a6ac8SSimon Glass 	s32 max_mode;
300867a6ac8SSimon Glass 	s32 mode;
301867a6ac8SSimon Glass 	s32 attribute;
302867a6ac8SSimon Glass 	s32 cursor_column;
303867a6ac8SSimon Glass 	s32 cursor_row;
304867a6ac8SSimon Glass 	bool cursor_visible;
305867a6ac8SSimon Glass };
306867a6ac8SSimon Glass 
307867a6ac8SSimon Glass struct efi_simple_text_output_protocol {
308867a6ac8SSimon Glass 	void *reset;
309867a6ac8SSimon Glass 	efi_status_t (EFIAPI *output_string)(
310867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this,
311867a6ac8SSimon Glass 			const unsigned short *str);
312*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *test_string)(
313*2bb9b79dSAlexander Graf 			struct efi_simple_text_output_protocol *this,
314*2bb9b79dSAlexander Graf 			const unsigned short *str);
315867a6ac8SSimon Glass 	efi_status_t(EFIAPI *query_mode)(
316867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this,
317867a6ac8SSimon Glass 			unsigned long mode_number, unsigned long *columns,
318867a6ac8SSimon Glass 			unsigned long *rows);
319867a6ac8SSimon Glass 	efi_status_t(EFIAPI *set_mode)(
320867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this,
321867a6ac8SSimon Glass 			unsigned long mode_number);
322867a6ac8SSimon Glass 	efi_status_t(EFIAPI *set_attribute)(
323867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this,
324867a6ac8SSimon Glass 			unsigned long attribute);
325867a6ac8SSimon Glass 	efi_status_t(EFIAPI *clear_screen) (
326867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this);
327867a6ac8SSimon Glass 	efi_status_t(EFIAPI *set_cursor_position) (
328867a6ac8SSimon Glass 			struct efi_simple_text_output_protocol *this,
329867a6ac8SSimon Glass 			unsigned long column, unsigned long row);
330*2bb9b79dSAlexander Graf 	efi_status_t(EFIAPI *enable_cursor)(
331*2bb9b79dSAlexander Graf 			struct efi_simple_text_output_protocol *this,
332*2bb9b79dSAlexander Graf 			bool enable);
333867a6ac8SSimon Glass 	struct simple_text_output_mode *mode;
334867a6ac8SSimon Glass };
335867a6ac8SSimon Glass 
336867a6ac8SSimon Glass struct efi_input_key {
337867a6ac8SSimon Glass 	u16 scan_code;
338867a6ac8SSimon Glass 	s16 unicode_char;
339867a6ac8SSimon Glass };
340867a6ac8SSimon Glass 
341867a6ac8SSimon Glass struct efi_simple_input_interface {
342867a6ac8SSimon Glass 	efi_status_t(EFIAPI *reset)(struct efi_simple_input_interface *this,
343867a6ac8SSimon Glass 			bool ExtendedVerification);
344867a6ac8SSimon Glass 	efi_status_t(EFIAPI *read_key_stroke)(
345867a6ac8SSimon Glass 			struct efi_simple_input_interface *this,
346867a6ac8SSimon Glass 			struct efi_input_key *key);
347867a6ac8SSimon Glass 	void *wait_for_key;
348867a6ac8SSimon Glass };
349867a6ac8SSimon Glass 
350*2bb9b79dSAlexander Graf #define CONSOLE_CONTROL_GUID \
351*2bb9b79dSAlexander Graf 	EFI_GUID(0xf42f7782, 0x12e, 0x4c12, \
352*2bb9b79dSAlexander Graf 		 0x99, 0x56, 0x49, 0xf9, 0x43, 0x4, 0xf7, 0x21)
353*2bb9b79dSAlexander Graf #define EFI_CONSOLE_MODE_TEXT	0
354*2bb9b79dSAlexander Graf #define EFI_CONSOLE_MODE_GFX	1
355*2bb9b79dSAlexander Graf 
356*2bb9b79dSAlexander Graf struct efi_console_control_protocol
357*2bb9b79dSAlexander Graf {
358*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *get_mode)(
359*2bb9b79dSAlexander Graf 			struct efi_console_control_protocol *this, int *mode,
360*2bb9b79dSAlexander Graf 			char *uga_exists, char *std_in_locked);
361*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *set_mode)(
362*2bb9b79dSAlexander Graf 			struct efi_console_control_protocol *this, int mode);
363*2bb9b79dSAlexander Graf 	efi_status_t (EFIAPI *lock_std_in)(
364*2bb9b79dSAlexander Graf 			struct efi_console_control_protocol *this,
365*2bb9b79dSAlexander Graf 			uint16_t *password);
366*2bb9b79dSAlexander Graf };
367*2bb9b79dSAlexander Graf 
368867a6ac8SSimon Glass #endif
369