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