ref: eb8fe8137b742646e9f3402149596eb8da62cc72
dir: /sys/src/boot/efi/efi.h/
typedef ushort	CHAR16;
typedef uchar	UINT8;
typedef ushort	UINT16;
typedef ulong	UINT32;
typedef uvlong	UINT64;
typedef UINT8	BOOLEAN;
typedef uintptr	UINTN;
typedef void*	EFI_HANDLE;
typedef UINT32	EFI_STATUS;
enum {
	AllHandles,
	ByRegisterNotify,
	ByProtocol,
};
typedef struct {
	UINT32		Data1;
	UINT16		Data2;
	UINT16		Data3;
	UINT8		Data4[8];
} EFI_GUID;
typedef struct {
	UINT16		ScanCode;
	CHAR16		UnicodeChar;
} EFI_INPUT_KEY;
typedef struct {
	void		*Reset;
	void		*ReadKeyStroke;
	void		*WaitForKey;
} EFI_SIMPLE_TEXT_INPUT_PROTOCOL;
typedef struct {
	void		*Reset;
	void		*OutputString;
	void		*TestString;
	void		*QueryMode;
	void		*SetMode;
	void		*SetAttribute;
	void		*ClearScreen;
	void		*SetCursorPosition;
	void		*EnableCursor;
	void		*Mode;
} EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL;
typedef struct {
	UINT32		Revision;
	EFI_HANDLE	ParentHandle;
	void		*SystemTable;
	EFI_HANDLE	DeviceHandle;
	void		*FilePath;
	void		*Reserved;
	UINT32		LoadOptionsSize;
	void		*LoadOptions;
	void		*ImageBase;
	UINT64		ImageSize;
	UINT32		ImageCodeType;
	UINT32		ImageDataType;
	void		*Unload;
} EFI_LOADED_IMAGE_PROTOCOL;
typedef struct {
	UINT32		RedMask;
	UINT32		GreenMask;
	UINT32		BlueMask;
	UINT32		ReservedMask;
} EFI_PIXEL_BITMASK;
enum {
	PixelRedGreenBlueReserved8BitPerColor,
	PixelBlueGreenRedReserved8BitPerColor,
	PixelBitMask,
	PixelBltOnly,
	PixelFormatMax,
};
typedef struct {
	UINT32		Version;
	UINT32		HorizontalResolution;
	UINT32		VerticalResolution;
	UINT32		PixelFormat;
	EFI_PIXEL_BITMASK	PixelInformation;
	UINT32		PixelsPerScanLine;
} EFI_GRAPHICS_OUTPUT_MODE_INFORMATION;
typedef struct {
	UINT32		MaxMode;
	UINT32		Mode;
	EFI_GRAPHICS_OUTPUT_MODE_INFORMATION *Info;
	UINTN		SizeOfInfo;
	UINT64		FrameBufferBase;
	UINTN		FrameBufferSize;
} EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE;
typedef struct {
	void		*QueryMode;
	void		*SetMode;
	void		*Blt;
	EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE *Mode;
} EFI_GRAPHICS_OUTPUT_PROTOCOL;
enum {
	EfiReservedMemoryType,
	EfiLoaderCode,
	EfiLoaderData,
	EfiBootServicesCode,
	EfiBootServicesData,
	EfiRuntimeServicesCode,
	EfiRuntimeServicesData,
	EfiConventionalMemory,
	EfiUnusableMemory,
	EfiACPIReclaimMemory,
	EfiACPIMemoryNVS,
	EfiMemoryMappedIO,
	EfiMemoryMappedIOPortSpace,
	EfiPalCode,
	EfiMaxMemoryType,
};
typedef struct {
	UINT32		Type;
	UINT32		Reserved;
	UINT64		PhysicalStart;
	UINT64		VirtualStart;
	UINT64		NumberOfPages;
	UINT64		Attribute;
} EFI_MEMORY_DESCRIPTOR;
typedef struct {
	UINT64	Signature;
	UINT32	Revision;
	UINT32	HeaderSize;
	UINT32	CRC32;
	UINT32	Reserved;
} EFI_TABLE_HEADER;
typedef struct {
	EFI_TABLE_HEADER;
	void		*RaiseTPL;
	void		*RestoreTPL;
	void		*AllocatePages;
	void		*FreePages;
	void		*GetMemoryMap;
	void		*AllocatePool;
	void		*FreePool;
	void		*CreateEvent;
	void		*SetTimer;
	void		*WaitForEvent;
	void		*SignalEvent;
	void		*CloseEvent;
	void		*CheckEvent;
	void		**InstallProtocolInterface;
	void		**ReinstallProtocolInterface;
	void		**UninstallProtocolInterface;
	void		*HandleProtocol;
	void		*Reserved;
	void		*RegisterProtocolNotify;
	void		*LocateHandle;
	void		*LocateDevicePath;
	void		*InstallConfigurationTable;
	void		*LoadImage;
	void		*StartImage;
	void		*Exit;
	void		*UnloadImage;
	void		*ExitBootServices;
	void		*GetNextMonotonicCount;
	void		*Stall;
	void		*SetWatchdogTimer;
	void		*ConnectController;
	void		*DisconnectController;
	void		*OpenProtocol;
	void		*CloseProtocol;
	void		*OpenProtocolInformation;
	void		*ProtocolsPerHandle;
	void		*LocateHandleBuffer;
	void		*LocateProtocol;
	void		*InstallMultipleProtocolInterfaces;
	void		*UninstallMultipleProtocolInterfaces;
	void		*CalculateCrc32;
	void		*CopyMem;
	void		*SetMem;
	void		*CreateEventEx;
} EFI_BOOT_SERVICES;
typedef struct {
	EFI_TABLE_HEADER;
	void		*GetTime;
	void		*SetTime;
	void		*GetWakeupTime;
	void		*SetWakeupTime;
	void		*SetVirtualAddressMap;
	void		*ConvertPointer;
	void		*GetVariable;
	void		*GetNextVariableName;
	void		*SetVariable;
	void		*GetNextHighMonotonicCount;
	void		*ResetSystem;
	void		*UpdateCapsule;
	void		*QueryCapsuleCapabilities;
	void		*QueryVariableInfo;
} EFI_RUNTIME_SERVICES;
typedef struct {
	EFI_GUID	VendorGuid;
	void		*VendorTable;
} EFI_CONFIGURATION_TABLE;
typedef struct {
	EFI_TABLE_HEADER;
	CHAR16		*FirmwareVendor;
	UINT32		FirmwareRevision;
	EFI_HANDLE	ConsoleInHandle;
	EFI_SIMPLE_TEXT_INPUT_PROTOCOL	*ConIn;
	EFI_HANDLE	ConsoleOutHandle;
	EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL	*ConOut;
	EFI_HANDLE	StandardErrorHandle;
	EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL	*StdErr;
	EFI_RUNTIME_SERVICES	*RuntimeServices;
	EFI_BOOT_SERVICES	*BootServices;
	UINTN			NumberOfTableEntries;
	EFI_CONFIGURATION_TABLE	*ConfigurationTable;
} EFI_SYSTEM_TABLE;
extern EFI_SYSTEM_TABLE *ST;
extern EFI_HANDLE IH;