2 This file declares the related BootScript definitions and some SMBus definitions.
4 Copyright (c) 2006, Intel Corporation
5 All rights reserved. This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
13 Module Name: BootScript.h
15 @par Revision Reference:
16 These definitions are defined in BootScript Spec 0.91 and SmBus PPI spec 0.9.
20 #ifndef _EFI_SCRIPT_H_
21 #define _EFI_SCRIPT_H_
23 #define EFI_ACPI_S3_RESUME_SCRIPT_TABLE 0x00
26 // Boot Script Opcode Definitions
29 #define EFI_BOOT_SCRIPT_IO_WRITE_OPCODE 0x00
30 #define EFI_BOOT_SCRIPT_IO_READ_WRITE_OPCODE 0x01
31 #define EFI_BOOT_SCRIPT_MEM_WRITE_OPCODE 0x02
32 #define EFI_BOOT_SCRIPT_MEM_READ_WRITE_OPCODE 0x03
33 #define EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE_OPCODE 0x04
34 #define EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE_OPCODE 0x05
35 #define EFI_BOOT_SCRIPT_SMBUS_EXECUTE_OPCODE 0x06
36 #define EFI_BOOT_SCRIPT_STALL_OPCODE 0x07
37 #define EFI_BOOT_SCRIPT_DISPATCH_OPCODE 0x08
38 #define EFI_BOOT_SCRIPT_DISPATCH_2_OPCODE 0x09
39 #define EFI_BOOT_SCRIPT_INFORMATION_OPCODE 0x0A
41 #define EFI_BOOT_SCRIPT_TABLE_OPCODE 0xAA
42 #define EFI_BOOT_SCRIPT_TERMINATE_OPCODE 0xFF
49 // EFI Boot Script Width
52 EfiBootScriptWidthUint8
,
53 EfiBootScriptWidthUint16
,
54 EfiBootScriptWidthUint32
,
55 EfiBootScriptWidthUint64
,
56 EfiBootScriptWidthFifoUint8
,
57 EfiBootScriptWidthFifoUint16
,
58 EfiBootScriptWidthFifoUint32
,
59 EfiBootScriptWidthFifoUint64
,
60 EfiBootScriptWidthFillUint8
,
61 EfiBootScriptWidthFillUint16
,
62 EfiBootScriptWidthFillUint32
,
63 EfiBootScriptWidthFillUint64
,
64 EfiBootScriptWidthMaximum
65 } EFI_BOOT_SCRIPT_WIDTH
;
68 // EFI Smbus Device Address, Smbus Device Command, Smbus Operation
71 UINTN SmbusDeviceAddress
: 7;
72 } EFI_SMBUS_DEVICE_ADDRESS
;
74 typedef UINTN EFI_SMBUS_DEVICE_COMMAND
;
76 typedef enum _EFI_SMBUS_OPERATION
89 EfiSmbusBWBRProcessCall
90 } EFI_SMBUS_OPERATION
;
93 // Boot Script Opcode Header Structure Definitions
99 } EFI_BOOT_SCRIPT_GENERIC_HEADER
;
107 } EFI_BOOT_SCRIPT_TABLE_HEADER
;
113 } EFI_BOOT_SCRIPT_COMMON_HEADER
;
121 } EFI_BOOT_SCRIPT_IO_WRITE
;
128 } EFI_BOOT_SCRIPT_IO_READ_WRITE
;
136 } EFI_BOOT_SCRIPT_MEM_WRITE
;
143 } EFI_BOOT_SCRIPT_MEM_READ_WRITE
;
151 } EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE
;
158 } EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE
;
168 } EFI_BOOT_SCRIPT_SMBUS_EXECUTE
;
174 } EFI_BOOT_SCRIPT_STALL
;
179 EFI_PHYSICAL_ADDRESS EntryPoint
;
180 } EFI_BOOT_SCRIPT_DISPATCH
;
185 EFI_PHYSICAL_ADDRESS EntryPoint
;
186 EFI_PHYSICAL_ADDRESS Context
;
187 } EFI_BOOT_SCRIPT_DISPATCH_2
;
192 UINT32 InformationLength
;
193 EFI_PHYSICAL_ADDRESS Information
;
194 } EFI_BOOT_SCRIPT_INFORMATION
;
199 } EFI_BOOT_SCRIPT_TERMINATE
;
202 EFI_BOOT_SCRIPT_GENERIC_HEADER
*Header
;
203 EFI_BOOT_SCRIPT_TABLE_HEADER
*TableInfo
;
204 EFI_BOOT_SCRIPT_IO_WRITE
*IoWrite
;
205 EFI_BOOT_SCRIPT_IO_READ_WRITE
*IoReadWrite
;
206 EFI_BOOT_SCRIPT_MEM_WRITE
*MemWrite
;
207 EFI_BOOT_SCRIPT_MEM_READ_WRITE
*MemReadWrite
;
208 EFI_BOOT_SCRIPT_PCI_CONFIG_WRITE
*PciWrite
;
209 EFI_BOOT_SCRIPT_PCI_CONFIG_READ_WRITE
*PciReadWrite
;
210 EFI_BOOT_SCRIPT_SMBUS_EXECUTE
*SmbusExecute
;
211 EFI_BOOT_SCRIPT_STALL
*Stall
;
212 EFI_BOOT_SCRIPT_DISPATCH
*Dispatch
;
213 EFI_BOOT_SCRIPT_DISPATCH_2
*Dispatch2
;
214 EFI_BOOT_SCRIPT_INFORMATION
*Information
;
215 EFI_BOOT_SCRIPT_TERMINATE
*Terminate
;
216 EFI_BOOT_SCRIPT_COMMON_HEADER
*CommonHeader
;
218 } BOOT_SCRIPT_POINTERS
;