]> git.proxmox.com Git - mirror_edk2.git/blame - IntelFrameworkModulePkg/Include/Protocol/IsaAcpi.h
Add comments for Include header files
[mirror_edk2.git] / IntelFrameworkModulePkg / Include / Protocol / IsaAcpi.h
CommitLineData
8ca67c46 1/** @file\r
f4671790 2 ISA Acpi Protocol is used to operate and communicate with ISA device.\r
a9102619 3\r
f4671790 4Copyright (c) 2006 - 2009, Intel Corporation \r
a9102619 5All rights reserved. This program and the accompanying materials \r
6are licensed and made available under the terms and conditions of the BSD License \r
7which accompanies this distribution. The full text of the license may be found at \r
8http://opensource.org/licenses/bsd-license.php \r
9 \r
10THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
11WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
12\r
3db51098 13**/\r
a9102619 14\r
15#ifndef __ISA_ACPI_H_\r
16#define __ISA_ACPI_H_\r
17\r
18#define EFI_ISA_ACPI_PROTOCOL_GUID \\r
19 { 0x64a892dc, 0x5561, 0x4536, { 0x92, 0xc7, 0x79, 0x9b, 0xfc, 0x18, 0x33, 0x55 } }\r
20\r
21typedef struct _EFI_ISA_ACPI_PROTOCOL EFI_ISA_ACPI_PROTOCOL;\r
22\r
23//\r
24// Resource Attribute definition\r
25//\r
26#define EFI_ISA_ACPI_IRQ_TYPE_HIGH_TRUE_EDGE_SENSITIVE 0x01\r
27#define EFI_ISA_ACPI_IRQ_TYPE_LOW_TRUE_EDGE_SENSITIVE 0x02\r
28#define EFI_ISA_ACPI_IRQ_TYPE_HIGH_TRUE_LEVEL_SENSITIVE 0x04\r
29#define EFI_ISA_ACPI_IRQ_TYPE_LOW_TRUE_LEVEL_SENSITIVE 0x08\r
30\r
31#define EFI_ISA_ACPI_DMA_SPEED_TYPE_MASK 0x03\r
32\r
33#define EFI_ISA_ACPI_DMA_SPEED_TYPE_COMPATIBILITY 0x00\r
34#define EFI_ISA_ACPI_DMA_SPEED_TYPE_A 0x01\r
35#define EFI_ISA_ACPI_DMA_SPEED_TYPE_B 0x02\r
36#define EFI_ISA_ACPI_DMA_SPEED_TYPE_F 0x03\r
37#define EFI_ISA_ACPI_DMA_COUNT_BY_BYTE 0x04\r
38#define EFI_ISA_ACPI_DMA_COUNT_BY_WORD 0x08\r
39#define EFI_ISA_ACPI_DMA_BUS_MASTER 0x10\r
40#define EFI_ISA_ACPI_DMA_TRANSFER_TYPE_8_BIT 0x20\r
41#define EFI_ISA_ACPI_DMA_TRANSFER_TYPE_8_BIT_AND_16_BIT 0x40\r
42#define EFI_ISA_ACPI_DMA_TRANSFER_TYPE_16_BIT 0x80\r
43\r
44#define EFI_ISA_ACPI_MEMORY_WIDTH_MASK 0x03\r
45\r
46#define EFI_ISA_ACPI_MEMORY_WIDTH_8_BIT 0x00\r
47#define EFI_ISA_ACPI_MEMORY_WIDTH_16_BIT 0x01\r
48#define EFI_ISA_ACPI_MEMORY_WIDTH_8_BIT_AND_16_BIT 0x02\r
49#define EFI_ISA_ACPI_MEMORY_WRITEABLE 0x04\r
50#define EFI_ISA_ACPI_MEMORY_CACHEABLE 0x08\r
51#define EFI_ISA_ACPI_MEMORY_SHADOWABLE 0x10\r
52#define EFI_ISA_ACPI_MEMORY_EXPANSION_ROM 0x20\r
53\r
54#define EFI_ISA_ACPI_IO_DECODE_10_BITS 0x01\r
55#define EFI_ISA_ACPI_IO_DECODE_16_BITS 0x02\r
56\r
57//\r
58// Resource List definition: \r
a9102619 59//\r
a9102619 60typedef enum {\r
61 EfiIsaAcpiResourceEndOfList,\r
62 EfiIsaAcpiResourceIo,\r
63 EfiIsaAcpiResourceMemory,\r
64 EfiIsaAcpiResourceDma,\r
65 EfiIsaAcpiResourceInterrupt\r
66} EFI_ISA_ACPI_RESOURCE_TYPE;\r
67\r
68typedef struct {\r
69 EFI_ISA_ACPI_RESOURCE_TYPE Type;\r
70 UINT32 Attribute;\r
71 UINT32 StartRange;\r
72 UINT32 EndRange;\r
73} EFI_ISA_ACPI_RESOURCE;\r
74\r
75typedef struct {\r
76 UINT32 HID;\r
77 UINT32 UID;\r
78} EFI_ISA_ACPI_DEVICE_ID;\r
79\r
80typedef struct {\r
81 EFI_ISA_ACPI_DEVICE_ID Device;\r
82 EFI_ISA_ACPI_RESOURCE *ResourceItem;\r
83} EFI_ISA_ACPI_RESOURCE_LIST;\r
84\r
f4671790
LG
85/**\r
86 Enumerate the ISA devices on the ISA bus.\r
87\r
88 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
89 @param Device Found next ISA device.\r
90\r
91 @retval EFI_NOT_FOUND No device found.\r
92 @retval EFI_SUCCESS Success get the next ISA device.\r
93\r
94**/\r
a9102619 95typedef\r
96EFI_STATUS\r
97(EFIAPI *EFI_ISA_ACPI_DEVICE_ENUMERATE) (\r
98 IN EFI_ISA_ACPI_PROTOCOL *This,\r
99 OUT EFI_ISA_ACPI_DEVICE_ID **Device\r
100 );\r
f4671790
LG
101\r
102/**\r
103 Set ISA device power.\r
104\r
105 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
106 @param Device ISA device.\r
107 @param OnOff Whether to set power on or off.\r
108\r
109 @retval EFI_SUCCESS Successfully set ISA device.\r
110\r
111**/\r
a9102619 112typedef\r
113EFI_STATUS\r
114(EFIAPI *EFI_ISA_ACPI_SET_DEVICE_POWER) (\r
115 IN EFI_ISA_ACPI_PROTOCOL *This,\r
116 IN EFI_ISA_ACPI_DEVICE_ID *Device,\r
117 IN BOOLEAN OnOff\r
118 );\r
119 \r
f4671790
LG
120/**\r
121 Get current Resource of the specific ISA device.\r
122\r
123 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
124 @param Device ISA device.\r
125 @param ResourceList Returned resource list.\r
126\r
127 @retval EFI_SUCCESS Successfully get current resource.\r
128 @retval EFI_NOT_FOUND No resource found.\r
129\r
130**/\r
a9102619 131typedef\r
132EFI_STATUS\r
133(EFIAPI *EFI_ISA_ACPI_GET_CUR_RESOURCE) (\r
134 IN EFI_ISA_ACPI_PROTOCOL *This,\r
135 IN EFI_ISA_ACPI_DEVICE_ID *Device,\r
136 OUT EFI_ISA_ACPI_RESOURCE_LIST **ResourceList\r
137 );\r
138\r
f4671790
LG
139/**\r
140 Get possible resource for the specific ISA device.\r
141\r
142 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
143 @param Device ISA device.\r
144 @param ResourceList Returned resource list.\r
145\r
146 @retval EFI_SUCCESS Successfully get possible resource.\r
147 @retval EFI_NOT_FOUND No resource found.\r
148**/\r
a9102619 149typedef\r
150EFI_STATUS\r
151(EFIAPI *EFI_ISA_ACPI_GET_POS_RESOURCE) (\r
152 IN EFI_ISA_ACPI_PROTOCOL *This,\r
153 IN EFI_ISA_ACPI_DEVICE_ID *Device,\r
154 OUT EFI_ISA_ACPI_RESOURCE_LIST **ResourceList\r
155 );\r
f4671790
LG
156\r
157/**\r
158 Set resources for the specific ISA device.\r
159\r
160 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
161 @param Device ISA device.\r
162 @param ResourceList Resource list will be set.\r
163\r
164 @retval EFI_SUCCESS Successfully set resource.\r
165\r
166**/\r
a9102619 167typedef\r
168EFI_STATUS\r
169(EFIAPI *EFI_ISA_ACPI_SET_RESOURCE) (\r
170 IN EFI_ISA_ACPI_PROTOCOL *This,\r
171 IN EFI_ISA_ACPI_DEVICE_ID *Device,\r
172 IN EFI_ISA_ACPI_RESOURCE_LIST *ResourceList\r
173 ); \r
174\r
f4671790
LG
175/**\r
176 Enable or disable ISA device.\r
177\r
178 @param This Pointer of EFI_ISA_ACPI_PROTOCOL.\r
179 @param Device ISA device.\r
180 @param Enable Enable/Disable.\r
181\r
182 @retval EFI_SUCCESS Successfully perform this action.\r
183\r
184**/\r
a9102619 185typedef\r
186EFI_STATUS\r
187(EFIAPI *EFI_ISA_ACPI_ENABLE_DEVICE) (\r
188 IN EFI_ISA_ACPI_PROTOCOL *This,\r
189 IN EFI_ISA_ACPI_DEVICE_ID *Device,\r
190 IN BOOLEAN Enable\r
191 ); \r
192\r
f4671790
LG
193/**\r
194 Init ISA device.\r
195\r
196 @param This Pointer to EFI_ISA_ACPI_PROTOCOL.\r
197 @param Device ISA device.\r
198\r
199 @retval EFI_SUCCESS Successfully initialize ISA device.\r
200\r
201**/\r
a9102619 202typedef\r
203EFI_STATUS\r
204(EFIAPI *EFI_ISA_ACPI_INIT_DEVICE) (\r
205 IN EFI_ISA_ACPI_PROTOCOL *This,\r
206 IN EFI_ISA_ACPI_DEVICE_ID *Device\r
207 ); \r
208\r
f4671790
LG
209/**\r
210 ISA Interface Init.\r
211\r
212 @param This Pointer of EFI_ISA_ACPI_PROTOCOL.\r
213\r
214 @retval EFI_SUCCESS Successfully initialize ISA interface.\r
215\r
216**/\r
a9102619 217typedef\r
218EFI_STATUS\r
219(EFIAPI *EFI_ISA_ACPI_INTERFACE_INIT) (\r
220 IN EFI_ISA_ACPI_PROTOCOL *This\r
221 );\r
222\r
223//\r
224// Interface structure for the ISA ACPI Protocol\r
225//\r
226struct _EFI_ISA_ACPI_PROTOCOL {\r
227 EFI_ISA_ACPI_DEVICE_ENUMERATE DeviceEnumerate;\r
228 EFI_ISA_ACPI_SET_DEVICE_POWER SetPower;\r
229 EFI_ISA_ACPI_GET_CUR_RESOURCE GetCurResource;\r
230 EFI_ISA_ACPI_GET_POS_RESOURCE GetPosResource;\r
231 EFI_ISA_ACPI_SET_RESOURCE SetResource;\r
232 EFI_ISA_ACPI_ENABLE_DEVICE EnableDevice;\r
233 EFI_ISA_ACPI_INIT_DEVICE InitDevice;\r
234 EFI_ISA_ACPI_INTERFACE_INIT InterfaceInit;\r
235};\r
236\r
237extern EFI_GUID gEfiIsaAcpiProtocolGuid;\r
238 \r
239#endif\r