lwip: handle UNDI stacks which need to be polled
[syslinux.git] / com32 / include / syslinux / pxe_api.h
blob93243294df0d897b5afc1775e6a7a9f8c428eb52
1 /* ----------------------------------------------------------------------- *
3 * Copyright 2007-2008 H. Peter Anvin - All Rights Reserved
5 * Permission is hereby granted, free of charge, to any person
6 * obtaining a copy of this software and associated documentation
7 * files (the "Software"), to deal in the Software without
8 * restriction, including without limitation the rights to use,
9 * copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom
11 * the Software is furnished to do so, subject to the following
12 * conditions:
14 * The above copyright notice and this permission notice shall
15 * be included in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
19 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
21 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
22 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
24 * OTHER DEALINGS IN THE SOFTWARE.
26 * ----------------------------------------------------------------------- */
29 * syslinux/pxe_api.h
31 * PXE type and constant definitions for SYSLINUX
34 #ifndef _SYSLINUX_PXE_API_H
35 #define _SYSLINUX_PXE_API_H
37 #include <stdint.h>
38 #include <netinet/in.h>
39 #include <klibc/compiler.h>
40 #include <com32.h>
42 /* PXE spec structures and definitions. These mostly follow the PXE
43 spec, except when the PXE spec is unnecessarily stupid. Of course,
44 that is most of the time. */
46 /* Basic types; use Unix-like _t convention instead of SCREAMING; also
47 re-use types we already have, like in_addr_t. */
49 typedef uint16_t pxenv_status_t;
51 #define MAC_ADDR_LEN 16
52 typedef uint8_t mac_addr_t[MAC_ADDR_LEN];
54 /* "Protected mode segment descriptor" according to PXE... */
55 typedef struct {
56 uint16_t sel;
57 uint32_t base;
58 uint16_t size;
59 } __packed pxe_segdesc_t;
61 typedef far_ptr_t segoff16_t;
63 typedef struct {
64 uint8_t opcode;
65 #define BOOTP_REQ 1
66 #define BOOTP_REP 2
67 uint8_t Hardware;
68 uint8_t Hardlen;
69 uint8_t Gatehops;
70 uint32_t ident;
71 uint16_t seconds;
72 uint16_t Flags;
73 #define BOOTP_BCAST 0x8000
74 in_addr_t cip; /* Client IP address */
75 in_addr_t yip; /* You IP address */
76 in_addr_t sip; /* next server IP address */
77 in_addr_t gip; /*relay agent IP address */
78 mac_addr_t CAddr;
79 uint8_t Sname[64];
80 uint8_t bootfile[128];
81 union {
82 #define BOOTP_DHCPVEND 1024
83 uint8_t d[BOOTP_DHCPVEND];
84 struct {
85 uint8_t magic[4];
86 #define VM_RFC1048 0x63825363L
87 uint32_t flags;
88 uint8_t pad[56];
89 } v;
90 } vendor;
91 } __packed pxe_bootp_t;
93 /* Function calling structures and constants */
95 typedef struct s_PXENV_GET_CACHED_INFO {
96 pxenv_status_t Status;
97 uint16_t PacketType;
98 #define PXENV_PACKET_TYPE_DHCP_DISCOVER 1
99 #define PXENV_PACKET_TYPE_DHCP_ACK 2
100 #define PXENV_PACKET_TYPE_CACHED_REPLY 3
101 uint16_t BufferSize;
102 segoff16_t Buffer;
103 uint16_t BufferLimit;
104 } __packed t_PXENV_GET_CACHED_INFO;
106 typedef struct s_PXENV_START_UNDI {
107 pxenv_status_t Status;
108 uint16_t AX;
109 uint16_t BX;
110 uint16_t DX;
111 uint16_t DI;
112 uint16_t ES;
113 } __packed t_PXENV_START_UNDI;
115 typedef struct s_PXENV_STOP_UNDI {
116 pxenv_status_t Status;
117 } __packed t_PXENV_STOP_UNDI;
119 typedef struct s_PXENV_START_BASE {
120 pxenv_status_t Status;
121 } __packed t_PXENV_START_BASE;
123 typedef struct s_PXENV_STOP_BASE {
124 pxenv_status_t Status;
125 } __packed t_PXENV_STOP_BASE;
127 typedef struct s_PXENV_TFTP_OPEN {
128 pxenv_status_t Status;
129 in_addr_t ServerIPAddress;
130 in_addr_t GatewayIPAddress;
131 uint8_t FileName[128];
132 in_port_t TFTPPort;
133 uint16_t PacketSize;
134 } __packed t_PXENV_TFTP_OPEN;
136 typedef struct s_PXENV_TFTP_CLOSE {
137 pxenv_status_t Status;
138 } __packed t_PXENV_TFTP_CLOSE;
140 typedef struct s_PXENV_TFTP_READ {
141 pxenv_status_t Status;
142 uint16_t PacketNumber;
143 uint16_t BufferSize;
144 segoff16_t Buffer;
145 } __packed t_PXENV_TFTP_READ;
147 typedef struct s_PXENV_TFTP_READ_FILE {
148 pxenv_status_t Status;
149 uint8_t FileName[128];
150 uint32_t BufferSize;
151 void *Buffer;
152 in_addr_t ServerIPAddress;
153 in_addr_t GatewayIPAddress;
154 in_addr_t McastIPAddress;
155 in_port_t TFTPClntPort;
156 in_port_t TFTPSrvPort;
157 uint16_t TFTPOpenTimeOut;
158 uint16_t TFTPReopenDelay;
159 } __packed t_PXENV_TFTP_READ_FILE;
161 typedef struct s_PXENV_TFTP_GET_FSIZE {
162 pxenv_status_t Status;
163 in_addr_t ServerIPAddress;
164 in_addr_t GatewayIPAddress;
165 uint8_t FileName[128];
166 uint32_t FileSize;
167 } __packed t_PXENV_TFTP_GET_FSIZE;
169 typedef struct s_PXENV_UDP_OPEN {
170 pxenv_status_t status;
171 in_addr_t src_ip;
172 } __packed t_PXENV_UDP_OPEN;
174 typedef struct s_PXENV_UDP_CLOSE {
175 pxenv_status_t status;
176 } __packed t_PXENV_UDP_CLOSE;
178 typedef struct s_PXENV_UDP_WRITE {
179 pxenv_status_t status;
180 in_addr_t ip;
181 in_addr_t gw;
182 in_port_t src_port;
183 in_port_t dst_port;
184 uint16_t buffer_size;
185 segoff16_t buffer;
186 } __packed t_PXENV_UDP_WRITE;
188 typedef struct s_PXENV_UDP_READ {
189 pxenv_status_t status;
190 in_addr_t src_ip;
191 in_addr_t dest_ip;
192 in_port_t s_port;
193 in_port_t d_port;
194 uint16_t buffer_size;
195 segoff16_t buffer;
196 } __packed t_PXENV_UDP_READ;
198 typedef struct s_PXENV_UNDI_STARTUP {
199 pxenv_status_t Status;
200 } __packed t_PXENV_UNDI_STARTUP;
202 typedef struct s_PXENV_UNDI_CLEANUP {
203 pxenv_status_t Status;
204 } __packed t_PXENV_UNDI_CLEANUP;
206 typedef struct s_PXENV_UNDI_INITIALIZE {
207 pxenv_status_t Status;
208 void *ProtocolIni;
209 uint8_t reserved[8];
210 } __packed t_PXENV_UNDI_INITIALIZE;
212 #define MAXNUM_MCADDR 8
213 typedef struct s_PXENV_UNDI_MCAST_ADDRESS {
214 uint16_t MCastAddrCount;
215 mac_addr_t McastAddr[MAXNUM_MCADDR];
216 } __packed t_PXENV_UNDI_MCAST_ADDRESS;
218 typedef struct s_PXENV_UNDI_RESET {
219 pxenv_status_t Status;
220 t_PXENV_UNDI_MCAST_ADDRESS R_Mcast_Buf;
221 } __packed t_PXENV_UNDI_RESET;
223 typedef struct s_PXENV_UNDI_SHUTDOWN {
224 pxenv_status_t Status;
225 } __packed t_PXENV_UNDI_SHUTDOWN;
227 typedef struct s_PXENV_UNDI_OPEN {
228 pxenv_status_t Status;
229 uint16_t OpenFlag;
230 uint16_t PktFilter;
231 #define FLTR_DIRECTED 0x0001
232 #define FLTR_BRDCST 0x0002
233 #define FLTR_PRMSCS 0x0004
234 #define FLTR_SRC_RTG 0x0008
235 t_PXENV_UNDI_MCAST_ADDRESS R_Mcast_Buf;
236 } __packed t_PXENV_UNDI_OPEN;
238 typedef struct s_PXENV_UNDI_CLOSE {
239 pxenv_status_t Status;
240 } __packed t_PXENV_UNDI_CLOSE;
242 typedef struct s_PXENV_UNDI_TRANSMIT {
243 pxenv_status_t Status;
244 uint8_t Protocol;
245 #define P_UNKNOWN 0
246 #define P_IP 1
247 #define P_ARP 2
248 #define P_RARP 3
249 uint8_t XmitFlag;
250 #define XMT_DESTADDR 0x0000
251 #define XMT_BROADCAST 0x0001
252 segoff16_t DestAddr;
253 segoff16_t TBD;
254 uint32_t Reserved[2];
255 } __packed t_PXENV_UNDI_TRANSMIT;
256 #define MAX_DATA_BLKS 8
257 typedef struct s_PXENV_UNDI_TBD {
258 uint16_t ImmedLength;
259 segoff16_t Xmit;
260 uint16_t DataBlkCount;
261 struct DataBlk {
262 uint8_t TDPtrType;
263 uint8_t TDRsvdByte;
264 uint16_t TDDataLen;
265 segoff16_t TDDataPtr;
266 } DataBlock[MAX_DATA_BLKS];
267 } __packed t_PXENV_UNDI_TBD;
269 typedef struct s_PXENV_UNDI_SET_MCAST_ADDRESS {
270 pxenv_status_t Status;
271 t_PXENV_UNDI_MCAST_ADDRESS R_Mcast_Buf;
272 } __packed t_PXENV_UNDI_SET_MCAST_ADDR;
274 typedef struct s_PXENV_UNDI_SET_STATION_ADDRESS {
275 pxenv_status_t Status;
276 mac_addr_t StationAddress;
277 } __packed t_PXENV_UNDI_SET_STATION_ADDR;
279 typedef struct s_PXENV_UNDI_SET_PACKET_FILTER {
280 pxenv_status_t Status;
281 uint8_t filter;
282 } __packed t_PXENV_UNDI_SET_PACKET_FILTER;
284 typedef struct s_PXENV_UNDI_GET_INFORMATION {
285 pxenv_status_t Status;
286 uint16_t BaseIo;
287 uint16_t IntNumber;
288 uint16_t MaxTranUnit;
289 uint16_t HwType;
290 #define ETHER_TYPE 1
291 #define EXP_ETHER_TYPE 2
292 #define IEEE_TYPE 6
293 #define ARCNET_TYPE 7
294 uint16_t HwAddrLen;
295 mac_addr_t CurrentNodeAddress;
296 mac_addr_t PermNodeAddress;
297 uint16_t ROMAddress;
298 uint16_t RxBufCt;
299 uint16_t TxBufCt;
300 } __packed t_PXENV_UNDI_GET_INFORMATION;
302 typedef struct s_PXENV_UNDI_GET_STATISTICS {
303 pxenv_status_t Status;
304 uint32_t XmtGoodFrames;
305 uint32_t RcvGoodFrames;
306 uint32_t RcvCRCErrors;
307 uint32_t RcvResourceErrors;
308 } __packed t_PXENV_UNDI_GET_STATISTICS;
310 typedef struct s_PXENV_UNDI_CLEAR_STATISTICS {
311 pxenv_status_t Status;
312 } __packed t_PXENV_UNDI_CLEAR_STATISTICS;
314 typedef struct s_PXENV_UNDI_INITIATE_DIAGS {
315 pxenv_status_t Status;
316 } __packed t_PXENV_UNDI_INITIATE_DIAGS;
318 typedef struct s_PXENV_UNDI_FORCE_INTERRUPT {
319 pxenv_status_t Status;
320 } __packed t_PXENV_UNDI_FORCE_INTERRUPT;
322 typedef struct s_PXENV_UNDI_GET_MCAST_ADDRESS {
323 pxenv_status_t Status;
324 in_addr_t InetAddr;
325 mac_addr_t MediaAddr;
326 } __packed t_PXENV_UNDI_GET_MCAST_ADDR;
328 typedef struct s_PXENV_UNDI_GET_NIC_TYPE {
329 pxenv_status_t Status;
330 uint8_t NicType;
331 #define PCI_NIC 2
332 #define PnP_NIC 3
333 #define CardBus_NIC 4
334 union {
335 struct {
336 uint16_t Vendor_ID;
337 uint16_t Dev_ID;
338 uint8_t Base_Class;
339 uint8_t Sub_Class;
340 uint8_t Prog_Intf;
341 uint8_t Rev;
342 uint16_t BusDevFunc;
343 uint16_t SubVendor_ID;
344 uint16_t SubDevice_ID;
345 } pci, cardbus;
346 struct {
347 uint32_t EISA_Dev_ID;
348 uint8_t Base_Class;
349 uint8_t Sub_Class;
350 uint8_t Prog_Intf;
351 uint16_t CardSelNum;
352 } __packed pnp;
353 } __packed info;
354 } __packed t_PXENV_UNDI_GET_NIC_TYPE;
356 typedef struct s_PXENV_UNDI_GET_IFACE_INFO {
357 pxenv_status_t Status;
358 uint8_t IfaceType[16];
359 uint32_t LinkSpeed;
360 uint32_t ServiceFlags;
361 uint32_t Reserved[4];
362 } __packed t_PXENV_UNDI_GET_IFACE_INFO;
363 #define PXE_UNDI_IFACE_FLAG_BCAST 0x00000001
364 #define PXE_UNDI_IFACE_FLAG_MCAST 0x00000002
365 #define PXE_UNDI_IFACE_FLAG_GROUP 0x00000004
366 #define PXE_UNDI_IFACE_FLAG_PROMISC 0x00000008
367 #define PXE_UNDI_IFACE_FLAG_SOFTMAC 0x00000010
368 #define PXE_UNDI_IFACE_FLAG_STATS 0x00000020
369 #define PXE_UNDI_IFACE_FLAG_DIAGS 0x00000040
370 #define PXE_UNDI_IFACE_FLAG_LOOPBACK 0x00000080
371 #define PXE_UNDI_IFACE_FLAG_RCVCHAIN 0x00000100
372 #define PXE_UNDI_IFACE_FLAG_IBMSRCRT 0x00000200
373 #define PXE_UNDI_IFACE_FLAG_RESET 0x00000400
374 #define PXE_UNDI_IFACE_FLAG_OPEN 0x00000800
375 #define PXE_UNDI_IFACE_FLAG_IRQ 0x00001000
376 #define PXE_UNDI_IFACE_FLAG_SRCRT 0x00002000
377 #define PXE_UNDI_IFACE_FLAG_GDTVIRT 0x00004000
378 #define PXE_UNDI_IFACE_FLAG_MULTI 0x00008000
379 #define PXE_UNDI_IFACE_FLAG_LKFISZ 0x00010000
381 typedef struct s_PXENV_UNDI_GET_STATE {
382 #define PXE_UNDI_GET_STATE_STARTED 1
383 #define PXE_UNDI_GET_STATE_INITIALIZED 2
384 #define PXE_UNDI_GET_STATE_OPENED 3
385 pxenv_status_t Status;
386 uint8_t UNDIstate;
387 } __packed t_PXENV_UNDI_GET_STATE;
389 typedef struct s_PXENV_UNDI_ISR {
390 pxenv_status_t Status;
391 uint16_t FuncFlag;
392 uint16_t BufferLength;
393 uint16_t FrameLength;
394 uint16_t FrameHeaderLength;
395 segoff16_t Frame;
396 uint8_t ProtType;
397 uint8_t PktType;
398 } __packed t_PXENV_UNDI_ISR;
400 typedef struct s_PXENV_FILE_API_CHECK {
401 pxenv_status_t Status;
402 uint16_t Size;
403 uint32_t Magic;
404 uint32_t Provider;
405 uint32_t APIMask;
406 uint32_t Flags;
407 } __packed t_PXENV_FILE_API_CHECK;
409 typedef struct s_PXENV_FILE_READ {
410 pxenv_status_t Status;
411 uint16_t FileHandle;
412 uint16_t BufferSize;
413 segoff16_t Buffer;
414 } __packed t_PXENV_FILE_READ;
416 typedef struct s_PXENV_FILE_OPEN {
417 pxenv_status_t Status;
418 uint16_t FileHandle;
419 segoff16_t FileName;
420 uint32_t Reserved;
421 } __packed t_PXENV_FILE_OPEN;
423 typedef struct s_PXENV_FILE_CLOSE {
424 pxenv_status_t Status;
425 uint16_t FileHandle;
426 } __packed t_PXENV_FILE_CLOSE;
428 typedef struct s_PXENV_GET_FILE_SIZE {
429 pxenv_status_t Status;
430 uint16_t FileHandle;
431 uint32_t FileSize;
432 } __packed t_PXENV_GET_FILE_SIZE;
434 typedef struct s_PXENV_UNLOAD_STACK {
435 pxenv_status_t Status;
436 uint8_t reserved[10];
437 } __packed t_PXENV_UNLOAD_STACK;
439 #define PXENV_UNDI_ISR_IN_START 1
440 #define PXENV_UNDI_ISR_IN_PROCESS 2
441 #define PXENV_UNDI_ISR_IN_GET_NEXT 3
442 /* One of these will be returned for
443 PXENV_UNDI_ISR_IN_START */
444 #define PXENV_UNDI_ISR_OUT_OURS 0
445 #define PXENV_UNDI_USR_OUT_NOT_OURS 1
446 /* One of these will be returned for
447 PXENV_UNDI_ISR_IN_PROCESS and
448 PXENV_UNDI_ISR_IN_GET_NEXT */
449 #define PXENV_UNDI_ISR_OUT_DONE 0
450 #define PXENV_UNDI_ISR_OUT_TRANSMIT 2
451 #define PXENV_UNDI_ISR_OUT_RECEIVE 3
452 #define PXENV_UNDI_ISR_OUT_BUSY 4
454 /* Function numbers and error codes */
456 #define PXENV_TFTP_OPEN 0x0020
457 #define PXENV_TFTP_CLOSE 0x0021
458 #define PXENV_TFTP_READ 0x0022
459 #define PXENV_TFTP_READ_FILE 0x0023
460 #define PXENV_TFTP_READ_FILE_PMODE 0x0024
461 #define PXENV_TFTP_GET_FSIZE 0x0025
463 #define PXENV_UDP_OPEN 0x0030
464 #define PXENV_UDP_CLOSE 0x0031
465 #define PXENV_UDP_READ 0x0032
466 #define PXENV_UDP_WRITE 0x0033
468 #define PXENV_START_UNDI 0x0000
469 #define PXENV_UNDI_STARTUP 0x0001
470 #define PXENV_UNDI_CLEANUP 0x0002
471 #define PXENV_UNDI_INITIALIZE 0x0003
472 #define PXENV_UNDI_RESET_NIC 0x0004
473 #define PXENV_UNDI_SHUTDOWN 0x0005
474 #define PXENV_UNDI_OPEN 0x0006
475 #define PXENV_UNDI_CLOSE 0x0007
476 #define PXENV_UNDI_TRANSMIT 0x0008
477 #define PXENV_UNDI_SET_MCAST_ADDR 0x0009
478 #define PXENV_UNDI_SET_STATION_ADDR 0x000A
479 #define PXENV_UNDI_SET_PACKET_FILTER 0x000B
480 #define PXENV_UNDI_GET_INFORMATION 0x000C
481 #define PXENV_UNDI_GET_STATISTICS 0x000D
482 #define PXENV_UNDI_CLEAR_STATISTICS 0x000E
483 #define PXENV_UNDI_INITIATE_DIAGS 0x000F
484 #define PXENV_UNDI_FORCE_INTERRUPT 0x0010
485 #define PXENV_UNDI_GET_MCAST_ADDR 0x0011
486 #define PXENV_UNDI_GET_NIC_TYPE 0x0012
487 #define PXENV_UNDI_GET_IFACE_INFO 0x0013
488 #define PXENV_UNDI_ISR 0x0014
489 #define PXENV_STOP_UNDI 0x0015 /* Overlap...? */
490 #define PXENV_UNDI_GET_STATE 0x0015 /* Overlap...? */
492 #define PXENV_UNLOAD_STACK 0x0070
493 #define PXENV_GET_CACHED_INFO 0x0071
494 #define PXENV_RESTART_DHCP 0x0072
495 #define PXENV_RESTART_TFTP 0x0073
496 #define PXENV_MODE_SWITCH 0x0074
497 #define PXENV_START_BASE 0x0075
498 #define PXENV_STOP_BASE 0x0076
500 /* gPXE extensions... */
501 #define PXENV_FILE_OPEN 0x00e0
502 #define PXENV_FILE_CLOSE 0x00e1
503 #define PXENV_FILE_SELECT 0x00e2
504 #define PXENV_FILE_READ 0x00e3
505 #define PXENV_GET_FILE_SIZE 0x00e4
506 #define PXENV_FILE_EXEC 0x00e5
507 #define PXENV_FILE_API_CHECK 0x00e6
509 /* Exit codes */
510 #define PXENV_EXIT_SUCCESS 0x0000
511 #define PXENV_EXIT_FAILURE 0x0001
513 /* Status codes */
514 #define PXENV_STATUS_SUCCESS 0x00
515 #define PXENV_STATUS_FAILURE 0x01
516 #define PXENV_STATUS_BAD_FUNC 0x02
517 #define PXENV_STATUS_UNSUPPORTED 0x03
518 #define PXENV_STATUS_KEEP_UNDI 0x04
519 #define PXENV_STATUS_KEEP_ALL 0x05
520 #define PXENV_STATUS_OUT_OF_RESOURCES 0x06
521 #define PXENV_STATUS_ARP_TIMEOUT 0x11
522 #define PXENV_STATUS_UDP_CLOSED 0x18
523 #define PXENV_STATUS_UDP_OPEN 0x19
524 #define PXENV_STATUS_TFTP_CLOSED 0x1a
525 #define PXENV_STATUS_TFTP_OPEN 0x1b
526 #define PXENV_STATUS_MCOPY_PROBLEM 0x20
527 #define PXENV_STATUS_BIS_INTEGRITY_FAILURE 0x21
528 #define PXENV_STATUS_BIS_VALIDATE_FAILURE 0x22
529 #define PXENV_STATUS_BIS_INIT_FAILURE 0x23
530 #define PXENV_STATUS_BIS_SHUTDOWN_FAILURE 0x24
531 #define PXENV_STATUS_BIS_GBOA_FAILURE 0x25
532 #define PXENV_STATUS_BIS_FREE_FAILURE 0x26
533 #define PXENV_STATUS_BIS_GSI_FAILURE 0x27
534 #define PXENV_STATUS_BIS_BAD_CKSUM 0x28
535 #define PXENV_STATUS_TFTP_CANNOT_ARP_ADDRESS 0x30
536 #define PXENV_STATUS_TFTP_OPEN_TIMEOUT 0x32
538 #define PXENV_STATUS_TFTP_UNKNOWN_OPCODE 0x33
539 #define PXENV_STATUS_TFTP_READ_TIMEOUT 0x35
540 #define PXENV_STATUS_TFTP_ERROR_OPCODE 0x36
541 #define PXENV_STATUS_TFTP_CANNOT_OPEN_CONNECTION 0x38
542 #define PXENV_STATUS_TFTP_CANNOT_READ_FROM_CONNECTION 0x39
543 #define PXENV_STATUS_TFTP_TOO_MANY_PACKAGES 0x3a
544 #define PXENV_STATUS_TFTP_FILE_NOT_FOUND 0x3b
545 #define PXENV_STATUS_TFTP_ACCESS_VIOLATION 0x3c
546 #define PXENV_STATUS_TFTP_NO_MCAST_ADDRESS 0x3d
547 #define PXENV_STATUS_TFTP_NO_FILESIZE 0x3e
548 #define PXENV_STATUS_TFTP_INVALID_PACKET_SIZE 0x3f
549 #define PXENV_STATUS_DHCP_TIMEOUT 0x51
550 #define PXENV_STATUS_DHCP_NO_IP_ADDRESS 0x52
551 #define PXENV_STATUS_DHCP_NO_BOOTFILE_NAME 0x53
552 #define PXENV_STATUS_DHCP_BAD_IP_ADDRESS 0x54
553 #define PXENV_STATUS_UNDI_INVALID_FUNCTION 0x60
554 #define PXENV_STATUS_UNDI_MEDIATEST_FAILED 0x61
555 #define PXENV_STATUS_UNDI_CANNOT_INIT_NIC_FOR_MCAST 0x62
556 #define PXENV_STATUS_UNDI_CANNOT_INITIALIZE_NIC 0x63
557 #define PXENV_STATUS_UNDI_CANNOT_INITIALIZE_PHY 0x64
558 #define PXENV_STATUS_UNDI_CANNOT_READ_CONFIG_DATA 0x65
559 #define PXENV_STATUS_UNDI_CANNOT_READ_INIT_DATA 0x66
560 #define PXENV_STATUS_UNDI_BAD_MAC_ADDRESS 0x67
561 #define PXENV_STATUS_UNDI_BAD_EEPROM_CHECKSUM 0x68
562 #define PXENV_STATUS_UNDI_ERROR_SETTING_ISR 0x69
563 #define PXENV_STATUS_UNDI_INVALID_STATE 0x6a
564 #define PXENV_STATUS_UNDI_TRANSMIT_ERROR 0x6b
565 #define PXENV_STATUS_UNDI_INVALID_PARAMETER 0x6c
566 #define PXENV_STATUS_BSTRAP_PROMPT_MENU 0x74
567 #define PXENV_STATUS_BSTRAP_MCAST_ADDR 0x76
568 #define PXENV_STATUS_BSTRAP_MISSING_LIST 0x77
569 #define PXENV_STATUS_BSTRAP_NO_RESPONSE 0x78
570 #define PXENV_STATUS_BSTRAP_FILE_TOO_BIG 0x79
571 #define PXENV_STATUS_BINL_CANCELED_BY_KEYSTROKE 0xa0
572 #define PXENV_STATUS_BINL_NO_PXE_SERVER 0xa1
573 #define PXENV_STATUS_NOT_AVAILABLE_IN_PMODE 0xa2
574 #define PXENV_STATUS_NOT_AVAILABLE_IN_RMODE 0xa3
575 #define PXENV_STATUS_BUSD_DEVICE_NOT_SUPPORTED 0xb0
576 #define PXENV_STATUS_LOADER_NO_FREE_BASE_MEMORY 0xc0
577 #define PXENV_STATUS_LOADER_NO_BC_ROMID 0xc1
578 #define PXENV_STATUS_LOADER_BAD_BC_ROMID 0xc2
579 #define PXENV_STATUS_LOADER_BAD_BC_RUNTIME_IMAGE 0xc3
580 #define PXENV_STATUS_LOADER_NO_UNDI_ROMID 0xc4
581 #define PXENV_STATUS_LOADER_BAD_UNDI_ROMID 0xc5
582 #define PXENV_STATUS_LOADER_BAD_UNDI_DRIVER_IMAGE 0xc6
583 #define PXENV_STATUS_LOADER_NO_PXE_STRUCT 0xc8
584 #define PXENV_STATUS_LOADER_NO_PXENV_STRUCT 0xc9
585 #define PXENV_STATUS_LOADER_UNDI_START 0xca
586 #define PXENV_STATUS_LOADER_BC_START 0xcb
588 #endif /* _SYSLINUX_PXE_API_H */