efidbg.h revision 1.1 1 1.1 jakllsch /* $NetBSD: efidbg.h,v 1.1 2014/04/01 16:16:07 jakllsch Exp $ */
2 1.1 jakllsch
3 1.1 jakllsch /*
4 1.1 jakllsch * Copyright (c) 1999, 2000
5 1.1 jakllsch * Intel Corporation.
6 1.1 jakllsch * All rights reserved.
7 1.1 jakllsch *
8 1.1 jakllsch * Redistribution and use in source and binary forms, with or without
9 1.1 jakllsch * modification, are permitted provided that the following conditions
10 1.1 jakllsch * are met:
11 1.1 jakllsch *
12 1.1 jakllsch * 1. Redistributions of source code must retain the above copyright
13 1.1 jakllsch * notice, this list of conditions and the following disclaimer.
14 1.1 jakllsch *
15 1.1 jakllsch * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 jakllsch * notice, this list of conditions and the following disclaimer in the
17 1.1 jakllsch * documentation and/or other materials provided with the distribution.
18 1.1 jakllsch *
19 1.1 jakllsch * 3. All advertising materials mentioning features or use of this software
20 1.1 jakllsch * must display the following acknowledgement:
21 1.1 jakllsch *
22 1.1 jakllsch * This product includes software developed by Intel Corporation and
23 1.1 jakllsch * its contributors.
24 1.1 jakllsch *
25 1.1 jakllsch * 4. Neither the name of Intel Corporation or its contributors may be
26 1.1 jakllsch * used to endorse or promote products derived from this software
27 1.1 jakllsch * without specific prior written permission.
28 1.1 jakllsch *
29 1.1 jakllsch * THIS SOFTWARE IS PROVIDED BY INTEL CORPORATION AND CONTRIBUTORS ``AS IS''
30 1.1 jakllsch * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
31 1.1 jakllsch * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
32 1.1 jakllsch * ARE DISCLAIMED. IN NO EVENT SHALL INTEL CORPORATION OR CONTRIBUTORS BE
33 1.1 jakllsch * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
34 1.1 jakllsch * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
35 1.1 jakllsch * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
36 1.1 jakllsch * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
37 1.1 jakllsch * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
38 1.1 jakllsch * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
39 1.1 jakllsch * THE POSSIBILITY OF SUCH DAMAGE.
40 1.1 jakllsch *
41 1.1 jakllsch */
42 1.1 jakllsch
43 1.1 jakllsch
44 1.1 jakllsch #ifndef _EFIDBG_H_
45 1.1 jakllsch #define _EFIDBG_H_
46 1.1 jakllsch
47 1.1 jakllsch #include "eficontext.h"
48 1.1 jakllsch #include "efiser.h"
49 1.1 jakllsch
50 1.1 jakllsch typedef struct _DEBUGPORT_16550_CONFIG_DATA {
51 1.1 jakllsch UINT32 PortAddress;
52 1.1 jakllsch UINT64 BaudRate;
53 1.1 jakllsch UINT32 ReceiveFifoDepth;
54 1.1 jakllsch UINT32 Timeout;
55 1.1 jakllsch UINT8 Parity;
56 1.1 jakllsch UINT8 DataBits;
57 1.1 jakllsch UINT8 StopBits;
58 1.1 jakllsch UINT32 ControlMask;
59 1.1 jakllsch BOOLEAN RtsCtsEnable; // RTS, CTS control
60 1.1 jakllsch } DEBUGPORT_16550_CONFIG_DATA;
61 1.1 jakllsch
62 1.1 jakllsch typedef struct _DEBUGPORT_16550_DEVICE_PATH {
63 1.1 jakllsch EFI_DEVICE_PATH Header;
64 1.1 jakllsch DEBUGPORT_16550_CONFIG_DATA ConfigData;
65 1.1 jakllsch } DEBUGPORT_16550_DEVICE_PATH;
66 1.1 jakllsch
67 1.1 jakllsch typedef union {
68 1.1 jakllsch EFI_DEVICE_PATH DevPath;
69 1.1 jakllsch DEBUGPORT_16550_DEVICE_PATH Uart;
70 1.1 jakllsch // add new types of debugport device paths to this union...
71 1.1 jakllsch } DEBUGPORT_DEV_PATH;
72 1.1 jakllsch
73 1.1 jakllsch
74 1.1 jakllsch //
75 1.1 jakllsch // Debug Support protocol {2755590C-6F3C-42FA-9EA4-A3BA543CDA25}
76 1.1 jakllsch //
77 1.1 jakllsch
78 1.1 jakllsch #define DEBUG_SUPPORT_PROTOCOL \
79 1.1 jakllsch { 0x2755590C, 0x6F3C, 0x42fa, 0x9E, 0xA4, 0xA3, 0xBA, 0x54, 0x3C, 0xDA, 0x25 }
80 1.1 jakllsch
81 1.1 jakllsch
82 1.1 jakllsch typedef UINTN EXCEPTION_TYPE;
83 1.1 jakllsch
84 1.1 jakllsch typedef
85 1.1 jakllsch VOID
86 1.1 jakllsch (*EXCEPTION_HANDLER) (
87 1.1 jakllsch IN EXCEPTION_TYPE ExceptionType,
88 1.1 jakllsch IN SYSTEM_CONTEXT *SystemContext
89 1.1 jakllsch );
90 1.1 jakllsch
91 1.1 jakllsch typedef
92 1.1 jakllsch EFI_STATUS
93 1.1 jakllsch (EFIAPI *EFI_REGISTER_TIMER_TICK_CALLBACK) (
94 1.1 jakllsch IN struct _EFI_DEBUG_SUPPORT_INTERFACE *This,
95 1.1 jakllsch IN EXCEPTION_HANDLER TimerTickCallback
96 1.1 jakllsch );
97 1.1 jakllsch
98 1.1 jakllsch typedef
99 1.1 jakllsch EFI_STATUS
100 1.1 jakllsch (EFIAPI *EFI_REGISTER_EXCEPTION_HANDLER) (
101 1.1 jakllsch IN struct _EFI_DEBUG_SUPPORT_INTERFACE *This,
102 1.1 jakllsch IN EXCEPTION_HANDLER ExceptionHandler,
103 1.1 jakllsch IN EXCEPTION_TYPE ExceptionType
104 1.1 jakllsch );
105 1.1 jakllsch
106 1.1 jakllsch typedef
107 1.1 jakllsch EFI_STATUS
108 1.1 jakllsch (EFIAPI *EFI_IP_CALL_TRACE) (
109 1.1 jakllsch IN struct _EFI_DEBUG_SUPPORT_INTERFACE *This
110 1.1 jakllsch );
111 1.1 jakllsch
112 1.1 jakllsch
113 1.1 jakllsch #define EFI_DEBUG_SUPPORT_INTERFACE_REVISION 0x00010000
114 1.1 jakllsch
115 1.1 jakllsch typedef struct _EFI_DEBUG_SUPPORT_INTERFACE {
116 1.1 jakllsch UINT32 Revision;
117 1.1 jakllsch EFI_REGISTER_TIMER_TICK_CALLBACK RegisterTimerTickCallback;
118 1.1 jakllsch EFI_REGISTER_EXCEPTION_HANDLER RegisterExceptionHandler;
119 1.1 jakllsch EFI_IP_CALL_TRACE IpCallTrace;
120 1.1 jakllsch } EFI_DEBUG_SUPPORT_INTERFACE;
121 1.1 jakllsch
122 1.1 jakllsch
123 1.1 jakllsch //
124 1.1 jakllsch // Debugport io protocol {EBA4E8D2-3858-41EC-A281-2647BA9660D0}
125 1.1 jakllsch //
126 1.1 jakllsch
127 1.1 jakllsch #define DEBUGPORT_IO_PROTOCOL \
128 1.1 jakllsch { 0XEBA4E8D2, 0X3858, 0X41EC, 0XA2, 0X81, 0X26, 0X47, 0XBA, 0X96, 0X60, 0XD0 }
129 1.1 jakllsch
130 1.1 jakllsch
131 1.1 jakllsch typedef
132 1.1 jakllsch EFI_STATUS
133 1.1 jakllsch (EFIAPI *EFI_DEBUGPORT_IO_RESET) (
134 1.1 jakllsch IN struct _EFI_DEBUGPORT_IO_INTERFACE *This
135 1.1 jakllsch );
136 1.1 jakllsch
137 1.1 jakllsch typedef
138 1.1 jakllsch EFI_STATUS
139 1.1 jakllsch (EFIAPI *EFI_DEBUGPORT_IO_READ) (
140 1.1 jakllsch IN struct _EFI_DEBUGPORT_IO_INTERFACE *This,
141 1.1 jakllsch IN OUT UINTN *BufferSize,
142 1.1 jakllsch OUT VOID *Buffer
143 1.1 jakllsch );
144 1.1 jakllsch
145 1.1 jakllsch typedef
146 1.1 jakllsch EFI_STATUS
147 1.1 jakllsch (EFIAPI *EFI_DEBUGPORT_IO_WRITE) (
148 1.1 jakllsch IN struct _EFI_DEBUGPORT_IO_INTERFACE *This,
149 1.1 jakllsch IN OUT UINTN *BufferSize,
150 1.1 jakllsch IN VOID *Buffer
151 1.1 jakllsch );
152 1.1 jakllsch
153 1.1 jakllsch #define EFI_DEBUGPORT_IO_INTERFACE_REVISION 0x00010000
154 1.1 jakllsch
155 1.1 jakllsch typedef struct _EFI_DEBUGPORT_IO_INTERFACE {
156 1.1 jakllsch UINT32 Revision;
157 1.1 jakllsch EFI_DEBUGPORT_IO_READ Read;
158 1.1 jakllsch EFI_DEBUGPORT_IO_WRITE Write;
159 1.1 jakllsch EFI_DEBUGPORT_IO_RESET Reset;
160 1.1 jakllsch } EFI_DEBUGPORT_IO_INTERFACE;
161 1.1 jakllsch
162 1.1 jakllsch
163 1.1 jakllsch //
164 1.1 jakllsch // Debugport UART16550 control protocol {628EA978-4C26-4605-BC02-A42A496917DD}
165 1.1 jakllsch //
166 1.1 jakllsch
167 1.1 jakllsch #define DEBUGPORT_UART16550_CONTROL_PROTOCOL \
168 1.1 jakllsch { 0X628EA978, 0X4C26, 0X4605, 0XBC, 0X2, 0XA4, 0X2A, 0X49, 0X69, 0X17, 0XDD }
169 1.1 jakllsch
170 1.1 jakllsch // Note: The definitions for EFI_PARITY_TYPE, EFI_STOP_BITS_TYPE, and
171 1.1 jakllsch // SERIAL_IO_MODE are included from efiser.h
172 1.1 jakllsch
173 1.1 jakllsch typedef
174 1.1 jakllsch EFI_STATUS
175 1.1 jakllsch (EFIAPI *EFI_UART16550_SET_ATTRIBUTES) (
176 1.1 jakllsch IN struct _EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE *This,
177 1.1 jakllsch IN UINT64 BaudRate,
178 1.1 jakllsch IN UINT32 ReceiveFifoDepth,
179 1.1 jakllsch IN UINT32 Timeout,
180 1.1 jakllsch IN EFI_PARITY_TYPE Parity,
181 1.1 jakllsch IN UINT8 DataBits,
182 1.1 jakllsch IN EFI_STOP_BITS_TYPE StopBits
183 1.1 jakllsch );
184 1.1 jakllsch
185 1.1 jakllsch typedef
186 1.1 jakllsch EFI_STATUS
187 1.1 jakllsch (EFIAPI *EFI_UART16550_SET_CONTROL_BITS) (
188 1.1 jakllsch IN struct _EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE *This,
189 1.1 jakllsch IN UINT32 Control
190 1.1 jakllsch );
191 1.1 jakllsch
192 1.1 jakllsch typedef
193 1.1 jakllsch EFI_STATUS
194 1.1 jakllsch (EFIAPI *EFI_UART16550_GET_CONTROL_BITS) (
195 1.1 jakllsch IN struct _EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE *This,
196 1.1 jakllsch OUT UINT32 *Control
197 1.1 jakllsch );
198 1.1 jakllsch
199 1.1 jakllsch #define EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE_REVISION 0x00010000
200 1.1 jakllsch
201 1.1 jakllsch typedef struct _EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE {
202 1.1 jakllsch UINT32 Revision;
203 1.1 jakllsch EFI_UART16550_SET_ATTRIBUTES SetAttributes;
204 1.1 jakllsch EFI_UART16550_SET_CONTROL_BITS SetControl;
205 1.1 jakllsch EFI_UART16550_GET_CONTROL_BITS GetControl;
206 1.1 jakllsch DEBUGPORT_16550_CONFIG_DATA *Mode;
207 1.1 jakllsch } EFI_DEBUGPORT_UART16550_CONTROL_INTERFACE;
208 1.1 jakllsch
209 1.1 jakllsch
210 1.1 jakllsch #define DEVICE_PATH_DEBUGPORT DEBUGPORT_IO_PROTOCOL
211 1.1 jakllsch
212 1.1 jakllsch #endif /* _EFIDBG_H_ */
213