efiser.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #ifndef _EFI_SER_H
  2. #define _EFI_SER_H
  3. /*++
  4. Copyright (c) 1998 Intel Corporation
  5. Module Name:
  6. efiser.h
  7. Abstract:
  8. EFI serial protocol
  9. Revision History
  10. --*/
  11. //
  12. // Serial protocol
  13. //
  14. #define SERIAL_IO_PROTOCOL \
  15. { 0xBB25CF6F, 0xF1D4, 0x11D2, {0x9A, 0x0C, 0x00, 0x90, 0x27, 0x3F, 0xC1, 0xFD} }
  16. INTERFACE_DECL(_SERIAL_IO_INTERFACE);
  17. typedef enum {
  18. DefaultParity,
  19. NoParity,
  20. EvenParity,
  21. OddParity,
  22. MarkParity,
  23. SpaceParity
  24. } EFI_PARITY_TYPE;
  25. typedef enum {
  26. DefaultStopBits,
  27. OneStopBit, // 1 stop bit
  28. OneFiveStopBits, // 1.5 stop bits
  29. TwoStopBits // 2 stop bits
  30. } EFI_STOP_BITS_TYPE;
  31. #define EFI_SERIAL_CLEAR_TO_SEND 0x0010 // RO
  32. #define EFI_SERIAL_DATA_SET_READY 0x0020 // RO
  33. #define EFI_SERIAL_RING_INDICATE 0x0040 // RO
  34. #define EFI_SERIAL_CARRIER_DETECT 0x0080 // RO
  35. #define EFI_SERIAL_REQUEST_TO_SEND 0x0002 // WO
  36. #define EFI_SERIAL_DATA_TERMINAL_READY 0x0001 // WO
  37. #define EFI_SERIAL_INPUT_BUFFER_EMPTY 0x0100 // RO
  38. #define EFI_SERIAL_OUTPUT_BUFFER_EMPTY 0x0200 // RO
  39. #define EFI_SERIAL_HARDWARE_LOOPBACK_ENABLE 0x1000 // RW
  40. #define EFI_SERIAL_SOFTWARE_LOOPBACK_ENABLE 0x2000 // RW
  41. #define EFI_SERIAL_HARDWARE_FLOW_CONTROL_ENABLE 0x4000 // RW
  42. typedef
  43. EFI_STATUS
  44. (EFIAPI *EFI_SERIAL_RESET) (
  45. IN struct _SERIAL_IO_INTERFACE *This
  46. );
  47. typedef
  48. EFI_STATUS
  49. (EFIAPI *EFI_SERIAL_SET_ATTRIBUTES) (
  50. IN struct _SERIAL_IO_INTERFACE *This,
  51. IN UINT64 BaudRate,
  52. IN UINT32 ReceiveFifoDepth,
  53. IN UINT32 Timeout,
  54. IN EFI_PARITY_TYPE Parity,
  55. IN UINT8 DataBits,
  56. IN EFI_STOP_BITS_TYPE StopBits
  57. );
  58. typedef
  59. EFI_STATUS
  60. (EFIAPI *EFI_SERIAL_SET_CONTROL_BITS) (
  61. IN struct _SERIAL_IO_INTERFACE *This,
  62. IN UINT32 Control
  63. );
  64. typedef
  65. EFI_STATUS
  66. (EFIAPI *EFI_SERIAL_GET_CONTROL_BITS) (
  67. IN struct _SERIAL_IO_INTERFACE *This,
  68. OUT UINT32 *Control
  69. );
  70. typedef
  71. EFI_STATUS
  72. (EFIAPI *EFI_SERIAL_WRITE) (
  73. IN struct _SERIAL_IO_INTERFACE *This,
  74. IN OUT UINTN *BufferSize,
  75. IN VOID *Buffer
  76. );
  77. typedef
  78. EFI_STATUS
  79. (EFIAPI *EFI_SERIAL_READ) (
  80. IN struct _SERIAL_IO_INTERFACE *This,
  81. IN OUT UINTN *BufferSize,
  82. OUT VOID *Buffer
  83. );
  84. typedef struct {
  85. UINT32 ControlMask;
  86. // current Attributes
  87. UINT32 Timeout;
  88. UINT64 BaudRate;
  89. UINT32 ReceiveFifoDepth;
  90. UINT32 DataBits;
  91. UINT32 Parity;
  92. UINT32 StopBits;
  93. } SERIAL_IO_MODE;
  94. #define SERIAL_IO_INTERFACE_REVISION 0x00010000
  95. typedef struct _SERIAL_IO_INTERFACE {
  96. UINT32 Revision;
  97. EFI_SERIAL_RESET Reset;
  98. EFI_SERIAL_SET_ATTRIBUTES SetAttributes;
  99. EFI_SERIAL_SET_CONTROL_BITS SetControl;
  100. EFI_SERIAL_GET_CONTROL_BITS GetControl;
  101. EFI_SERIAL_WRITE Write;
  102. EFI_SERIAL_READ Read;
  103. SERIAL_IO_MODE *Mode;
  104. } SERIAL_IO_INTERFACE;
  105. #endif