3 Copyright (c) 2004 - 2007, Intel Corporation
4 All rights reserved. This program and the accompanying materials
5 are licensed and made available under the terms and conditions of the BSD License
6 which accompanies this distribution. The full text of the license may be found at
7 http://opensource.org/licenses/bsd-license.php
9 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
10 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
22 #ifndef _EFI_SCRIPT_H_
23 #define _EFI_SCRIPT_H_
27 #define EFI_ACPI_S3_RESUME_SCRIPT_TABLE 0x00
30 // Boot Script Opcode Definitions
32 typedef const UINT16 EFI_BOOT_SCRIPT_OPCODE
;
34 #define EFI_BOOT_SCRIPT_IO_WRITE_OPCODE 0x00
35 #define EFI_BOOT_SCRIPT_IO_READ_WRITE_OPCODE 0x01
36 #define EFI_BOOT_SCRIPT_MEM_WRITE_OPCODE 0x02
37 #define EFI_BOOT_SCRIPT_MEM_READ_WRITE_OPCODE 0x03
38 #define EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE_OPCODE 0x04
39 #define EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE_OPCODE 0x05
40 #define EFI_BOOT_SCRIPT_SMBUS_EXECUTE_OPCODE 0x06
41 #define EFI_BOOT_SCRIPT_STALL_OPCODE 0x07
42 #define EFI_BOOT_SCRIPT_DISPATCH_OPCODE 0x08
43 #define EFI_BOOT_SCRIPT_INFORMATION_OPCODE 0x0A
45 #define EFI_BOOT_SCRIPT_PCI_CONFIG2_WRITE_OPCODE 0x0B
46 #define EFI_BOOT_SCRIPT_PCI_CONFIG2_READ_WRITE_OPCODE 0x0C
48 #define EFI_BOOT_SCRIPT_TABLE_OPCODE 0xAA
49 #define EFI_BOOT_SCRIPT_TERMINATE_OPCODE 0xFF
54 // EFI Boot Script Width
57 EfiBootScriptWidthUint8
,
58 EfiBootScriptWidthUint16
,
59 EfiBootScriptWidthUint32
,
60 EfiBootScriptWidthUint64
,
61 EfiBootScriptWidthFifoUint8
,
62 EfiBootScriptWidthFifoUint16
,
63 EfiBootScriptWidthFifoUint32
,
64 EfiBootScriptWidthFifoUint64
,
65 EfiBootScriptWidthFillUint8
,
66 EfiBootScriptWidthFillUint16
,
67 EfiBootScriptWidthFillUint32
,
68 EfiBootScriptWidthFillUint64
,
69 EfiBootScriptWidthMaximum
70 } EFI_BOOT_SCRIPT_WIDTH
;
75 } EFI_BOOT_SCRIPT_GENERIC_HEADER
;
83 } EFI_BOOT_SCRIPT_TABLE_HEADER
;
89 } EFI_BOOT_SCRIPT_COMMON_HEADER
;
97 } EFI_BOOT_SCRIPT_IO_WRITE
;
104 } EFI_BOOT_SCRIPT_IO_READ_WRITE
;
112 } EFI_BOOT_SCRIPT_MEM_WRITE
;
119 } EFI_BOOT_SCRIPT_MEM_READ_WRITE
;
127 } EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE
;
136 } EFI_BOOT_SCRIPT_PCI_CONFIG2_WRITE
;
143 } EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE
;
151 } EFI_BOOT_SCRIPT_PCI_CONFIG2_READ_WRITE
;
162 } EFI_BOOT_SCRIPT_SMBUS_EXECUTE
;
168 } EFI_BOOT_SCRIPT_STALL
;
173 EFI_PHYSICAL_ADDRESS EntryPoint
;
174 } EFI_BOOT_SCRIPT_DISPATCH
;
179 UINT32 InformationLength
;
180 EFI_PHYSICAL_ADDRESS Information
;
181 } EFI_BOOT_SCRIPT_INFORMATION
;
186 } EFI_BOOT_SCRIPT_TERMINATE
;
189 EFI_BOOT_SCRIPT_GENERIC_HEADER
*Header
;
190 EFI_BOOT_SCRIPT_TABLE_HEADER
*TableInfo
;
191 EFI_BOOT_SCRIPT_IO_WRITE
*IoWrite
;
192 EFI_BOOT_SCRIPT_IO_READ_WRITE
*IoReadWrite
;
193 EFI_BOOT_SCRIPT_MEM_WRITE
*MemWrite
;
194 EFI_BOOT_SCRIPT_MEM_READ_WRITE
*MemReadWrite
;
195 EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE
*PciWrite
;
196 EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE
*PciReadWrite
;
197 EFI_BOOT_SCRIPT_PCI_CONFIG2_WRITE
*PciWrite2
;
198 EFI_BOOT_SCRIPT_PCI_CONFIG2_READ_WRITE
*PciReadWrite2
;
199 EFI_BOOT_SCRIPT_SMBUS_EXECUTE
*SmbusExecute
;
200 EFI_BOOT_SCRIPT_STALL
*Stall
;
201 EFI_BOOT_SCRIPT_DISPATCH
*Dispatch
;
202 EFI_BOOT_SCRIPT_INFORMATION
*Information
;
203 EFI_BOOT_SCRIPT_TERMINATE
*Terminate
;
204 EFI_BOOT_SCRIPT_COMMON_HEADER
*CommonHeader
;
206 } BOOT_SCRIPT_POINTERS
;