xref: /freebsd/sys/contrib/edk2/Include/Protocol/DebugPort.h (revision 3245fa215aca18d135839a15c80ae1c905666a37)
10d1ba665SWarner Losh /** @file
20d1ba665SWarner Losh 
30d1ba665SWarner Losh   The file defines the EFI Debugport protocol.
40d1ba665SWarner Losh   This protocol is used by debug agent to communicate with the
50d1ba665SWarner Losh   remote debug host.
60d1ba665SWarner Losh 
7*3245fa21SMitchell Horne   Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
8*3245fa21SMitchell Horne   SPDX-License-Identifier: BSD-2-Clause-Patent
90d1ba665SWarner Losh 
100d1ba665SWarner Losh **/
110d1ba665SWarner Losh 
120d1ba665SWarner Losh #ifndef __DEBUG_PORT_H__
130d1ba665SWarner Losh #define __DEBUG_PORT_H__
140d1ba665SWarner Losh 
150d1ba665SWarner Losh 
160d1ba665SWarner Losh ///
170d1ba665SWarner Losh /// DebugPortIo protocol {EBA4E8D2-3858-41EC-A281-2647BA9660D0}
180d1ba665SWarner Losh ///
190d1ba665SWarner Losh #define EFI_DEBUGPORT_PROTOCOL_GUID \
200d1ba665SWarner Losh   { \
210d1ba665SWarner Losh     0xEBA4E8D2, 0x3858, 0x41EC, {0xA2, 0x81, 0x26, 0x47, 0xBA, 0x96, 0x60, 0xD0 } \
220d1ba665SWarner Losh   }
230d1ba665SWarner Losh 
240d1ba665SWarner Losh extern EFI_GUID gEfiDebugPortProtocolGuid;
250d1ba665SWarner Losh 
260d1ba665SWarner Losh typedef struct _EFI_DEBUGPORT_PROTOCOL EFI_DEBUGPORT_PROTOCOL;
270d1ba665SWarner Losh 
280d1ba665SWarner Losh //
290d1ba665SWarner Losh // DebugPort member functions
300d1ba665SWarner Losh //
310d1ba665SWarner Losh 
320d1ba665SWarner Losh /**
330d1ba665SWarner Losh   Resets the debugport.
340d1ba665SWarner Losh 
350d1ba665SWarner Losh   @param  This                  A pointer to the EFI_DEBUGPORT_PROTOCOL instance.
360d1ba665SWarner Losh 
370d1ba665SWarner Losh   @retval EFI_SUCCESS           The debugport device was reset and is in usable state.
380d1ba665SWarner Losh   @retval EFI_DEVICE_ERROR      The debugport device could not be reset and is unusable.
390d1ba665SWarner Losh 
400d1ba665SWarner Losh **/
410d1ba665SWarner Losh typedef
420d1ba665SWarner Losh EFI_STATUS
430d1ba665SWarner Losh (EFIAPI *EFI_DEBUGPORT_RESET)(
440d1ba665SWarner Losh   IN EFI_DEBUGPORT_PROTOCOL               *This
450d1ba665SWarner Losh   );
460d1ba665SWarner Losh 
470d1ba665SWarner Losh /**
480d1ba665SWarner Losh   Writes data to the debugport.
490d1ba665SWarner Losh 
500d1ba665SWarner Losh   @param  This                  A pointer to the EFI_DEBUGPORT_PROTOCOL instance.
510d1ba665SWarner Losh   @param  Timeout               The number of microseconds to wait before timing out a write operation.
520d1ba665SWarner Losh   @param  BufferSize            On input, the requested number of bytes of data to write. On output, the
530d1ba665SWarner Losh                                 number of bytes of data actually written.
540d1ba665SWarner Losh   @param  Buffer                A pointer to a buffer containing the data to write.
550d1ba665SWarner Losh 
560d1ba665SWarner Losh   @retval EFI_SUCCESS           The data was written.
570d1ba665SWarner Losh   @retval EFI_DEVICE_ERROR      The device reported an error.
580d1ba665SWarner Losh   @retval EFI_TIMEOUT           The data write was stopped due to a timeout.
590d1ba665SWarner Losh 
600d1ba665SWarner Losh **/
610d1ba665SWarner Losh typedef
620d1ba665SWarner Losh EFI_STATUS
630d1ba665SWarner Losh (EFIAPI *EFI_DEBUGPORT_WRITE)(
640d1ba665SWarner Losh   IN EFI_DEBUGPORT_PROTOCOL               *This,
650d1ba665SWarner Losh   IN UINT32                               Timeout,
660d1ba665SWarner Losh   IN OUT UINTN                            *BufferSize,
670d1ba665SWarner Losh   IN VOID                                 *Buffer
680d1ba665SWarner Losh   );
690d1ba665SWarner Losh 
700d1ba665SWarner Losh /**
710d1ba665SWarner Losh   Reads data from the debugport.
720d1ba665SWarner Losh 
730d1ba665SWarner Losh   @param  This                  A pointer to the EFI_DEBUGPORT_PROTOCOL instance.
740d1ba665SWarner Losh   @param  Timeout               The number of microseconds to wait before timing out a read operation.
750d1ba665SWarner Losh   @param  BufferSize            On input, the requested number of bytes of data to read. On output, the
760d1ba665SWarner Losh                                 number of bytes of data actually number of bytes
770d1ba665SWarner Losh                                 of data read and returned in Buffer.
780d1ba665SWarner Losh   @param  Buffer                A pointer to a buffer into which the data read will be saved.
790d1ba665SWarner Losh 
800d1ba665SWarner Losh   @retval EFI_SUCCESS           The data was read.
810d1ba665SWarner Losh   @retval EFI_DEVICE_ERROR      The device reported an error.
820d1ba665SWarner Losh   @retval EFI_TIMEOUT           The operation was stopped due to a timeout or overrun.
830d1ba665SWarner Losh 
840d1ba665SWarner Losh **/
850d1ba665SWarner Losh typedef
860d1ba665SWarner Losh EFI_STATUS
870d1ba665SWarner Losh (EFIAPI *EFI_DEBUGPORT_READ)(
880d1ba665SWarner Losh   IN EFI_DEBUGPORT_PROTOCOL               *This,
890d1ba665SWarner Losh   IN UINT32                               Timeout,
900d1ba665SWarner Losh   IN OUT UINTN                            *BufferSize,
910d1ba665SWarner Losh   OUT VOID                                *Buffer
920d1ba665SWarner Losh   );
930d1ba665SWarner Losh 
940d1ba665SWarner Losh /**
950d1ba665SWarner Losh   Checks to see if any data is available to be read from the debugport device.
960d1ba665SWarner Losh 
970d1ba665SWarner Losh   @param  This                  A pointer to the EFI_DEBUGPORT_PROTOCOL instance.
980d1ba665SWarner Losh 
990d1ba665SWarner Losh   @retval EFI_SUCCESS           At least one byte of data is available to be read.
1000d1ba665SWarner Losh   @retval EFI_DEVICE_ERROR      The debugport device is not functioning correctly.
1010d1ba665SWarner Losh   @retval EFI_NOT_READY         No data is available to be read.
1020d1ba665SWarner Losh 
1030d1ba665SWarner Losh **/
1040d1ba665SWarner Losh typedef
1050d1ba665SWarner Losh EFI_STATUS
1060d1ba665SWarner Losh (EFIAPI *EFI_DEBUGPORT_POLL)(
1070d1ba665SWarner Losh   IN EFI_DEBUGPORT_PROTOCOL               *This
1080d1ba665SWarner Losh   );
1090d1ba665SWarner Losh 
1100d1ba665SWarner Losh ///
1110d1ba665SWarner Losh /// This protocol provides the communication link between the debug agent and the remote host.
1120d1ba665SWarner Losh ///
1130d1ba665SWarner Losh struct _EFI_DEBUGPORT_PROTOCOL {
1140d1ba665SWarner Losh   EFI_DEBUGPORT_RESET Reset;
1150d1ba665SWarner Losh   EFI_DEBUGPORT_WRITE Write;
1160d1ba665SWarner Losh   EFI_DEBUGPORT_READ  Read;
1170d1ba665SWarner Losh   EFI_DEBUGPORT_POLL  Poll;
1180d1ba665SWarner Losh };
1190d1ba665SWarner Losh 
1200d1ba665SWarner Losh //
1210d1ba665SWarner Losh // DEBUGPORT variable definitions...
1220d1ba665SWarner Losh //
1230d1ba665SWarner Losh #define EFI_DEBUGPORT_VARIABLE_NAME L"DEBUGPORT"
1240d1ba665SWarner Losh #define EFI_DEBUGPORT_VARIABLE_GUID EFI_DEBUGPORT_PROTOCOL_GUID
1250d1ba665SWarner Losh 
1260d1ba665SWarner Losh extern EFI_GUID  gEfiDebugPortVariableGuid;
1270d1ba665SWarner Losh 
1280d1ba665SWarner Losh //
1290d1ba665SWarner Losh // DebugPort device path definitions...
1300d1ba665SWarner Losh //
1310d1ba665SWarner Losh #define DEVICE_PATH_MESSAGING_DEBUGPORT EFI_DEBUGPORT_PROTOCOL_GUID
1320d1ba665SWarner Losh 
1330d1ba665SWarner Losh extern EFI_GUID  gEfiDebugPortDevicePathGuid;
1340d1ba665SWarner Losh 
1350d1ba665SWarner Losh typedef struct {
1360d1ba665SWarner Losh   EFI_DEVICE_PATH_PROTOCOL  Header;
1370d1ba665SWarner Losh   EFI_GUID                  Guid;
1380d1ba665SWarner Losh } DEBUGPORT_DEVICE_PATH;
1390d1ba665SWarner Losh 
1400d1ba665SWarner Losh #endif
141