]> git.proxmox.com Git - mirror_edk2.git/blame - PcAtChipsetPkg/8259InterruptControllerDxe/8259.h
add detailed description for functions.
[mirror_edk2.git] / PcAtChipsetPkg / 8259InterruptControllerDxe / 8259.h
CommitLineData
90b8b0ec 1/** @file\r
2 Driver implementing the Tiano Legacy 8259 Protocol\r
1166d068 3\r
ae6a37f0 4Copyright (c) 2005 - 2009, Intel Corporation \r
1166d068 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
1166d068 13**/\r
14\r
15#ifndef _8259_H__\r
16#define _8259_H__\r
17\r
18#include <FrameworkDxe.h>\r
19\r
1166d068 20#include <Protocol/Legacy8259.h>\r
ae6a37f0 21#include <Protocol/PciIo.h>\r
1166d068 22\r
23#include <Library/UefiBootServicesTableLib.h>\r
24#include <Library/DebugLib.h>\r
8be701c3 25#include <Library/IoLib.h>\r
ae6a37f0 26#include <Library/BaseLib.h>\r
1166d068 27\r
ae6a37f0 28#include <IndustryStandard/Pci22.h>\r
1166d068 29//\r
30// 8259 Hardware definitions\r
31//\r
32#define LEGACY_MODE_BASE_VECTOR_MASTER 0x08\r
33#define LEGACY_MODE_BASE_VECTOR_SLAVE 0x70\r
34\r
35#define PROTECTED_MODE_BASE_VECTOR_MASTER 0x68\r
36#define PROTECTED_MODE_BASE_VECTOR_SLAVE 0x70\r
37\r
38#define LEGACY_8259_CONTROL_REGISTER_MASTER 0x20\r
39#define LEGACY_8259_MASK_REGISTER_MASTER 0x21\r
40#define LEGACY_8259_CONTROL_REGISTER_SLAVE 0xA0\r
41#define LEGACY_8259_MASK_REGISTER_SLAVE 0xA1\r
42#define LEGACY_8259_EDGE_LEVEL_TRIGGERED_REGISTER_MASTER 0x4D0\r
43#define LEGACY_8259_EDGE_LEVEL_TRIGGERED_REGISTER_SLAVE 0x4D1\r
44\r
45#define LEGACY_8259_EOI 0x20\r
46\r
47//\r
48// Protocol Function Prototypes\r
49//\r
50EFI_STATUS\r
51EFIAPI\r
52Interrupt8259SetVectorBase (\r
90b8b0ec 53 IN EFI_LEGACY_8259_PROTOCOL *This,\r
54 IN UINT8 MasterBase,\r
55 IN UINT8 SlaveBase\r
56 );\r
1166d068 57\r
58EFI_STATUS\r
59EFIAPI\r
60Interrupt8259GetMask (\r
90b8b0ec 61 IN EFI_LEGACY_8259_PROTOCOL *This,\r
1166d068 62 OUT UINT16 *LegacyMask, OPTIONAL\r
63 OUT UINT16 *LegacyEdgeLevel, OPTIONAL\r
64 OUT UINT16 *ProtectedMask, OPTIONAL\r
65 OUT UINT16 *ProtectedEdgeLevel OPTIONAL\r
90b8b0ec 66 );\r
1166d068 67\r
68EFI_STATUS\r
69EFIAPI\r
70Interrupt8259SetMask (\r
90b8b0ec 71 IN EFI_LEGACY_8259_PROTOCOL *This,\r
72 IN UINT16 *LegacyMask, OPTIONAL\r
73 IN UINT16 *LegacyEdgeLevel, OPTIONAL\r
74 IN UINT16 *ProtectedMask, OPTIONAL\r
75 IN UINT16 *ProtectedEdgeLevel OPTIONAL\r
76 );\r
1166d068 77\r
78EFI_STATUS\r
79EFIAPI\r
80Interrupt8259SetMode (\r
90b8b0ec 81 IN EFI_LEGACY_8259_PROTOCOL *This,\r
82 IN EFI_8259_MODE Mode,\r
83 IN UINT16 *Mask, OPTIONAL\r
84 IN UINT16 *EdgeLevel OPTIONAL\r
85 );\r
1166d068 86\r
87EFI_STATUS\r
88EFIAPI\r
89Interrupt8259GetVector (\r
90 IN EFI_LEGACY_8259_PROTOCOL *This,\r
91 IN EFI_8259_IRQ Irq,\r
92 OUT UINT8 *Vector\r
90b8b0ec 93 );\r
1166d068 94\r
95EFI_STATUS\r
96EFIAPI\r
97Interrupt8259EnableIrq (\r
90b8b0ec 98 IN EFI_LEGACY_8259_PROTOCOL *This,\r
99 IN EFI_8259_IRQ Irq,\r
100 IN BOOLEAN LevelTriggered\r
101 );\r
1166d068 102\r
103EFI_STATUS\r
104EFIAPI\r
105Interrupt8259DisableIrq (\r
90b8b0ec 106 IN EFI_LEGACY_8259_PROTOCOL *This,\r
107 IN EFI_8259_IRQ Irq\r
108 );\r
1166d068 109\r
110EFI_STATUS\r
111EFIAPI\r
112Interrupt8259GetInterruptLine (\r
113 IN EFI_LEGACY_8259_PROTOCOL *This,\r
114 IN EFI_HANDLE PciHandle,\r
115 OUT UINT8 *Vector\r
90b8b0ec 116 );\r
1166d068 117\r
118EFI_STATUS\r
119EFIAPI\r
120Interrupt8259EndOfInterrupt (\r
121 IN EFI_LEGACY_8259_PROTOCOL *This,\r
122 IN EFI_8259_IRQ Irq\r
90b8b0ec 123 );\r
1166d068 124\r
125#endif\r