You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

pxe.h 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. #ifndef PXE_H
  2. #define PXE_H
  3. #include "pxe_types.h"
  4. #include "pxe_api.h"
  5. #include <gpxe/device.h>
  6. /* Parameter block for pxenv_unknown() */
  7. struct s_PXENV_UNKNOWN {
  8. PXENV_STATUS_t Status; /**< PXE status code */
  9. } PACKED;
  10. typedef struct s_PXENV_UNKNOWN PXENV_UNKNOWN_t;
  11. /* Union used for PXE API calls; we don't know the type of the
  12. * structure until we interpret the opcode. Also, Status is available
  13. * in the same location for any opcode, and it's convenient to have
  14. * non-specific access to it.
  15. */
  16. union u_PXENV_ANY {
  17. /* Make it easy to read status for any operation */
  18. PXENV_STATUS_t Status;
  19. struct s_PXENV_UNKNOWN unknown;
  20. struct s_PXENV_UNLOAD_STACK unload_stack;
  21. struct s_PXENV_GET_CACHED_INFO get_cached_info;
  22. struct s_PXENV_TFTP_READ_FILE restart_tftp;
  23. struct s_PXENV_START_UNDI start_undi;
  24. struct s_PXENV_STOP_UNDI stop_undi;
  25. struct s_PXENV_START_BASE start_base;
  26. struct s_PXENV_STOP_BASE stop_base;
  27. struct s_PXENV_TFTP_OPEN tftp_open;
  28. struct s_PXENV_TFTP_CLOSE tftp_close;
  29. struct s_PXENV_TFTP_READ tftp_read;
  30. struct s_PXENV_TFTP_READ_FILE tftp_read_file;
  31. struct s_PXENV_TFTP_GET_FSIZE tftp_get_fsize;
  32. struct s_PXENV_UDP_OPEN udp_open;
  33. struct s_PXENV_UDP_CLOSE udp_close;
  34. struct s_PXENV_UDP_WRITE udp_write;
  35. struct s_PXENV_UDP_READ udp_read;
  36. struct s_PXENV_UNDI_STARTUP undi_startup;
  37. struct s_PXENV_UNDI_CLEANUP undi_cleanup;
  38. struct s_PXENV_UNDI_INITIALIZE undi_initialize;
  39. struct s_PXENV_UNDI_RESET undi_reset_adapter;
  40. struct s_PXENV_UNDI_SHUTDOWN undi_shutdown;
  41. struct s_PXENV_UNDI_OPEN undi_open;
  42. struct s_PXENV_UNDI_CLOSE undi_close;
  43. struct s_PXENV_UNDI_TRANSMIT undi_transmit;
  44. struct s_PXENV_UNDI_SET_MCAST_ADDRESS undi_set_mcast_address;
  45. struct s_PXENV_UNDI_SET_STATION_ADDRESS undi_set_station_address;
  46. struct s_PXENV_UNDI_SET_PACKET_FILTER undi_set_packet_filter;
  47. struct s_PXENV_UNDI_GET_INFORMATION undi_get_information;
  48. struct s_PXENV_UNDI_GET_STATISTICS undi_get_statistics;
  49. struct s_PXENV_UNDI_CLEAR_STATISTICS undi_clear_statistics;
  50. struct s_PXENV_UNDI_INITIATE_DIAGS undi_initiate_diags;
  51. struct s_PXENV_UNDI_FORCE_INTERRUPT undi_force_interrupt;
  52. struct s_PXENV_UNDI_GET_MCAST_ADDRESS undi_get_mcast_address;
  53. struct s_PXENV_UNDI_GET_NIC_TYPE undi_get_nic_type;
  54. struct s_PXENV_UNDI_GET_IFACE_INFO undi_get_iface_info;
  55. struct s_PXENV_UNDI_GET_STATE undi_get_state;
  56. struct s_PXENV_UNDI_ISR undi_isr;
  57. };
  58. typedef union u_PXENV_ANY PXENV_ANY_t;
  59. /** An UNDI expansion ROM header */
  60. struct undi_rom_header {
  61. /** Signature
  62. *
  63. * Must be equal to @c ROM_SIGNATURE
  64. */
  65. UINT16_t Signature;
  66. /** ROM length in 512-byte blocks */
  67. UINT8_t ROMLength;
  68. /** Unused */
  69. UINT8_t unused[0x13];
  70. /** Offset of the PXE ROM ID structure */
  71. UINT16_t PXEROMID;
  72. /** Offset of the PCI ROM structure */
  73. UINT16_t PCIRHeader;
  74. } PACKED;
  75. /** Signature for an expansion ROM */
  76. #define ROM_SIGNATURE 0xaa55
  77. /** An UNDI ROM ID structure */
  78. struct undi_rom_id {
  79. /** Signature
  80. *
  81. * Must be equal to @c UNDI_ROM_ID_SIGNATURE
  82. */
  83. UINT32_t Signature;
  84. /** Length of structure */
  85. UINT8_t StructLength;
  86. /** Checksum */
  87. UINT8_t StructCksum;
  88. /** Structure revision
  89. *
  90. * Must be zero.
  91. */
  92. UINT8_t StructRev;
  93. /** UNDI revision
  94. *
  95. * Version 2.1.0 is encoded as the byte sequence 0x00, 0x01, 0x02.
  96. */
  97. UINT8_t UNDIRev[3];
  98. /** Offset to UNDI loader */
  99. UINT16_t UNDILoader;
  100. /** Minimum required stack segment size */
  101. UINT16_t StackSize;
  102. /** Minimum required data segment size */
  103. UINT16_t DataSize;
  104. /** Minimum required code segment size */
  105. UINT16_t CodeSize;
  106. } PACKED;
  107. /** Signature for an UNDI ROM ID structure */
  108. #define UNDI_ROM_ID_SIGNATURE \
  109. ( ( 'U' << 0 ) + ( 'N' << 8 ) + ( 'D' << 16 ) + ( 'I' << 24 ) )
  110. /** A PCI expansion header */
  111. struct pcir_header {
  112. /** Signature
  113. *
  114. * Must be equal to @c PCIR_SIGNATURE
  115. */
  116. uint32_t signature;
  117. /** PCI vendor ID */
  118. uint16_t vendor_id;
  119. /** PCI device ID */
  120. uint16_t device_id;
  121. } PACKED;
  122. /** Signature for an UNDI ROM ID structure */
  123. #define PCIR_SIGNATURE \
  124. ( ( 'P' << 0 ) + ( 'C' << 8 ) + ( 'I' << 16 ) + ( 'R' << 24 ) )
  125. extern struct net_device *pxe_netdev;
  126. #endif /* PXE_H */