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