/** @file PS2 Mouse Communication Interface Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _COMMPS2_H_ #define _COMMPS2_H_ #define PS2_PACKET_LENGTH 3 #define PS2_SYNC_MASK 0xc #define PS2_SYNC_BYTE 0x8 #define IS_PS2_SYNC_BYTE(byte) ((byte & PS2_SYNC_MASK) == PS2_SYNC_BYTE) #define PS2_READ_BYTE_ONE 0 #define PS2_READ_DATA_BYTE 1 #define PS2_PROCESS_PACKET 2 #define TIMEOUT 50000 #define BAT_TIMEOUT 500000 // // 8042 I/O Port // #define KBC_DATA_PORT 0x60 #define KBC_CMD_STS_PORT 0x64 // // 8042 Command // #define READ_CMD_BYTE 0x20 #define WRITE_CMD_BYTE 0x60 #define DISABLE_AUX 0xa7 #define ENABLE_AUX 0xa8 #define SELF_TEST 0xaa #define DISABLE_KB 0xad #define ENABLE_KB 0xae #define WRITE_AUX_DEV 0xd4 #define CMD_SYS_FLAG 0x04 #define CMD_KB_STS 0x10 #define CMD_KB_DIS 0x10 #define CMD_KB_EN 0x0 // // 8042 Auxiliary Device Command // #define SETSF1_CMD 0xe6 #define SETSF2_CMD 0xe7 #define SETRE_CMD 0xe8 #define READ_CMD 0xeb #define SETRM_CMD 0xf0 #define SETSR_CMD 0xf3 #define ENABLE_CMD 0xf4 #define DISABLE_CMD 0xf5 #define RESET_CMD 0xff // // return code // #define PS2_ACK 0xfa #define PS2_RESEND 0xfe #define PS2MOUSE_BAT1 0xaa #define PS2MOUSE_BAT2 0x0 // // Keyboard Controller Status // /// /// Parity Error /// #define KBC_PARE 0x80 /// /// General Time Out /// #define KBC_TIM 0x40 /// /// Output buffer for auxiliary device (PS/2): /// 0 - Holds keyboard data /// 1 - Holds data for auxiliary device /// #define KBC_AUXB 0x20 /// /// Keyboard lock status: /// 0 - keyboard locked /// 1 - keyboard free /// #define KBC_KEYL 0x10 /// /// Command/Data: /// 0 - data byte written via port 60h /// 1 - command byte written via port 64h /// #define KBC_CD 0x08 /// /// System Flag: /// 0 - power-on reset /// 1 - self-test successful /// #define KBC_SYSF 0x04 /// /// Input Buffer Status : /// 0 - input buffer empty /// 1 - CPU data in input buffer /// #define KBC_INPB 0x02 /// /// Output Buffer Status : /// 0 - output buffer empty /// 1 - keyboard controller data in output buffer /// #define KBC_OUTB 0x01 /** Issue self test command via IsaIo interface. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return EFI_SUCCESS Success to do keyboard self testing. @return others Fail to do keyboard self testing. **/ EFI_STATUS KbcSelfTest ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to enable keyboard AUX functionality. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS KbcEnableAux ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to disable keyboard AUX functionality. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS KbcDisableAux ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to enable keyboard. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS KbcEnableKb ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to disable keyboard. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS KbcDisableKb ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to check keyboard status. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param KeyboardEnable return whether keyboard is enable. @return Status of command issuing. **/ EFI_STATUS CheckKbStatus ( IN EFI_ISA_IO_PROTOCOL *IsaIo, OUT BOOLEAN *KeyboardEnable ); /** Issue command to reset keyboard. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS PS2MouseReset ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Issue command to set mouse's sample rate @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param SampleRate value of sample rate @return Status of command issuing. **/ EFI_STATUS PS2MouseSetSampleRate ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN MOUSE_SR SampleRate ); /** Issue command to set mouse's resolution. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Resolution value of resolution @return Status of command issuing. **/ EFI_STATUS PS2MouseSetResolution ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN MOUSE_RE Resolution ); /** Issue command to set mouse's scaling. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Scaling value of scaling @return Status of command issuing. **/ EFI_STATUS PS2MouseSetScaling ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN MOUSE_SF Scaling ); /** Issue command to enable Ps2 mouse. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @return Status of command issuing. **/ EFI_STATUS PS2MouseEnable ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** Get mouse packet . Only care first 3 bytes @param MouseDev Pointer of PS2 Mouse Private Data Structure @retval EFI_NOT_READY Mouse Device not ready to input data packet, or some error happened during getting the packet @retval EFI_SUCCESS The data packet is gotten successfully. **/ EFI_STATUS PS2MouseGetPacket ( PS2_MOUSE_DEV *MouseDev ); /** Read data via IsaIo protocol with given number. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Buffer Buffer receive data of mouse @param BufSize The size of buffer @param State Check input or read data @return status of reading mouse data. **/ EFI_STATUS PS2MouseRead ( IN EFI_ISA_IO_PROTOCOL *IsaIo, OUT VOID *Buffer, IN OUT UINTN *BufSize, IN UINTN State ); // // 8042 I/O function // /** I/O work flow of outing 8042 command. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Command I/O command. @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS Out8042Command ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINT8 Command ); /** I/O work flow of in 8042 data. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Data Data value @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS In8042Data ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN OUT UINT8 *Data ); /** I/O work flow of outing 8042 data. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Data Data value @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS Out8042Data ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINT8 Data ); /** I/O work flow of outing 8042 Aux command. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Command Aux I/O command @param Resend Whether need resend the Aux command. @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS Out8042AuxCommand ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINT8 Command, IN BOOLEAN Resend ); /** I/O work flow of in 8042 Aux data. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Data Buffer holding return value. @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS In8042AuxData ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN OUT UINT8 *Data ); /** I/O work flow of outing 8042 Aux data. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Data Buffer holding return value @retval EFI_SUCCESS Success to execute I/O work flow @retval EFI_TIMEOUT Keyboard controller time out. **/ EFI_STATUS Out8042AuxData ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINT8 Data ); /** Check keyboard controller status, if it is output buffer full and for auxiliary device. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @retval EFI_SUCCESS Keyboard controller is ready @retval EFI_NOT_READY Keyboard controller is not ready **/ EFI_STATUS CheckForInput ( IN EFI_ISA_IO_PROTOCOL *IsaIo ); /** I/O work flow to wait input buffer empty in given time. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Timeout Wating time. @retval EFI_TIMEOUT if input is still not empty in given time. @retval EFI_SUCCESS input is empty. **/ EFI_STATUS WaitInputEmpty ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINTN Timeout ); /** I/O work flow to wait output buffer full in given time. @param IsaIo Pointer to instance of EFI_ISA_IO_PROTOCOL @param Timeout given time @retval EFI_TIMEOUT output is not full in given time @retval EFI_SUCCESS output is full in given time. **/ EFI_STATUS WaitOutputFull ( IN EFI_ISA_IO_PROTOCOL *IsaIo, IN UINTN Timeout ); #endif