mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-25 20:01:48 +00:00 
			
		
		
		
	Clean up the Ps2keyboardDxe module
1) Use MicroSecondDelay() produced by TimerLib to replace gBS->Stall 2) Add more command/register/status definition for 8042/8048 chipset and remove hard code value used in driver's source code; 3) Remove some unused function declaration before function implementation. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@8604 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
		
							parent
							
								
									273d2d3f08
								
							
						
					
					
						commit
						b6763e03bd
					
				| @ -1,5 +1,4 @@ | |||||||
| /**@file
 | /**@file
 | ||||||
|   PS/2 Keyboard driver |  | ||||||
|   Routines that access 8042 keyboard controller |   Routines that access 8042 keyboard controller | ||||||
| 
 | 
 | ||||||
| Copyright (c) 2006 - 2007, Intel Corporation | Copyright (c) 2006 - 2007, Intel Corporation | ||||||
| @ -567,64 +566,6 @@ UINTN  mWaitForValueTimeOut = KEYBOARD_WAITFORVALUE_TIMEOUT; | |||||||
| 
 | 
 | ||||||
| BOOLEAN          mEnableMouseInterface; | BOOLEAN          mEnableMouseInterface; | ||||||
| 
 | 
 | ||||||
| //
 |  | ||||||
| // Function declarations
 |  | ||||||
| //
 |  | ||||||
| UINT8 |  | ||||||
| KeyReadDataRegister ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| VOID |  | ||||||
| KeyWriteDataRegister ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn, |  | ||||||
|   IN UINT8                   Data |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| VOID |  | ||||||
| KeyWriteCommandRegister ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn, |  | ||||||
|   IN UINT8                   Data |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| VOID |  | ||||||
| KeyboardError ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV*ConsoleIn, |  | ||||||
|   IN CHAR16                 *ErrMsg // should be a unicode string
 |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| GetScancodeBufHead ( |  | ||||||
|   KEYBOARD_CONSOLE_IN_DEV  *ConsoleIn, |  | ||||||
|   IN UINT32                Count, |  | ||||||
|   OUT UINT8                *Buf |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| PopScancodeBufHead ( |  | ||||||
|   KEYBOARD_CONSOLE_IN_DEV  *ConsoleIn, |  | ||||||
|   IN UINT32                Count, |  | ||||||
|   OUT UINT8                *Buf |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| KeyboardWrite ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn, |  | ||||||
|   IN UINT8                   Data |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| KeyboardCommand ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn, |  | ||||||
|   IN UINT8                   Data |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| KeyboardWaitForValue ( |  | ||||||
|   IN KEYBOARD_CONSOLE_IN_DEV *ConsoleIn, |  | ||||||
|   IN UINT8                   Value |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|   Read data register  |   Read data register  | ||||||
| 
 | 
 | ||||||
| @ -687,9 +628,6 @@ KeyWriteDataRegister ( | |||||||
|               &Data |               &Data | ||||||
|               ); |               ); | ||||||
| 
 | 
 | ||||||
|   //
 |  | ||||||
|   // outp(ConsoleIn->DataRegisterAddress, Data);
 |  | ||||||
|   //
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
| @ -770,11 +708,6 @@ KeyboardError ( | |||||||
|   ) |   ) | ||||||
| { | { | ||||||
|   ConsoleIn->KeyboardErr = TRUE; |   ConsoleIn->KeyboardErr = TRUE; | ||||||
| 
 |  | ||||||
|   //
 |  | ||||||
|   // gST -> ConOut -> OutputString (gST -> ConOut, L"Keyboard Driver: ");
 |  | ||||||
|   // gST -> ConOut -> OutputString (gST -> ConOut, ErrMsg);
 |  | ||||||
|   //
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
| @ -784,8 +717,8 @@ KeyboardError ( | |||||||
|   the memory buffer or empty the keyboard buffer. |   the memory buffer or empty the keyboard buffer. | ||||||
|   It is registered as running under TPL_NOTIFY |   It is registered as running under TPL_NOTIFY | ||||||
| 
 | 
 | ||||||
|   @param Event - The timer event |   @param Event       The timer event | ||||||
|   @param Context - A KEYBOARD_CONSOLE_IN_DEV pointer |   @param Context     A KEYBOARD_CONSOLE_IN_DEV pointer | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| VOID | VOID | ||||||
| @ -814,6 +747,7 @@ KeyboardTimerHandler ( | |||||||
|     gBS->RestoreTPL (OldTpl); |     gBS->RestoreTPL (OldTpl); | ||||||
|     return ; |     return ; | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|   //
 |   //
 | ||||||
|   // To let KB driver support Hot plug, here should skip the 'resend' command  for the case that
 |   // To let KB driver support Hot plug, here should skip the 'resend' command  for the case that
 | ||||||
|   // KB is not connected to system. If KB is not connected to system, driver will find there's  something
 |   // KB is not connected to system. If KB is not connected to system, driver will find there's  something
 | ||||||
| @ -827,7 +761,7 @@ KeyboardTimerHandler ( | |||||||
|   //
 |   //
 | ||||||
|   // if there is no key present, just return
 |   // if there is no key present, just return
 | ||||||
|   //
 |   //
 | ||||||
|   if ((KeyReadStatusRegister (Context) & 0x21) != 0x1) { |   if ((KeyReadStatusRegister (Context) & (KEYBOARD_STATUS_REGISTER_TRANSMIT_TIMEOUT|KEYBOARD_STATUS_REGISTER_HAS_OUTPUT_DATA)) != KEYBOARD_STATUS_REGISTER_HAS_OUTPUT_DATA) { | ||||||
|     //
 |     //
 | ||||||
|     // Leave critical section and return
 |     // Leave critical section and return
 | ||||||
|     //
 |     //
 | ||||||
| @ -1019,13 +953,13 @@ KeyboardRead ( | |||||||
|   // wait till output buffer full then perform the read
 |   // wait till output buffer full then perform the read
 | ||||||
|   //
 |   //
 | ||||||
|   for (TimeOut = 0; TimeOut < KEYBOARD_TIMEOUT; TimeOut += 30) { |   for (TimeOut = 0; TimeOut < KEYBOARD_TIMEOUT; TimeOut += 30) { | ||||||
|     if (KeyReadStatusRegister (ConsoleIn) & 0x01) { |     if (KeyReadStatusRegister (ConsoleIn) & KEYBOARD_STATUS_REGISTER_HAS_OUTPUT_DATA) { | ||||||
|       RegFilled = 1; |       RegFilled = 1; | ||||||
|       *Data     = KeyReadDataRegister (ConsoleIn); |       *Data     = KeyReadDataRegister (ConsoleIn); | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     gBS->Stall (30); |     MicroSecondDelay (30); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (!RegFilled) { |   if (!RegFilled) { | ||||||
| @ -1041,8 +975,8 @@ KeyboardRead ( | |||||||
|   @param ConsoleIn Pointer to instance of KEYBOARD_CONSOLE_IN_DEV |   @param ConsoleIn Pointer to instance of KEYBOARD_CONSOLE_IN_DEV | ||||||
|   @param Data      value wanted to be written |   @param Data      value wanted to be written | ||||||
| 
 | 
 | ||||||
|   @retval EFI_TIMEOUT - GC_TODO: Add description for return value |   @retval EFI_TIMEOUT   The input buffer register is full for putting new value util timeout | ||||||
|   @retval EFI_SUCCESS - GC_TODO: Add description for return value |   @retval EFI_SUCCESS   The new value is sucess put into input buffer register. | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -1066,7 +1000,7 @@ KeyboardWrite ( | |||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     gBS->Stall (30); |     MicroSecondDelay (30); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (!RegEmptied) { |   if (!RegEmptied) { | ||||||
| @ -1111,7 +1045,7 @@ KeyboardCommand ( | |||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     gBS->Stall (30); |     MicroSecondDelay (30); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (!RegEmptied) { |   if (!RegEmptied) { | ||||||
| @ -1132,7 +1066,7 @@ KeyboardCommand ( | |||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     gBS->Stall (30); |     MicroSecondDelay (30); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (!RegEmptied) { |   if (!RegEmptied) { | ||||||
| @ -1191,7 +1125,7 @@ KeyboardWaitForValue ( | |||||||
|         break; |         break; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       gBS->Stall (30); |       MicroSecondDelay (30); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     SumTimeOut += TimeOut; |     SumTimeOut += TimeOut; | ||||||
| @ -1208,7 +1142,7 @@ KeyboardWaitForValue ( | |||||||
|   //
 |   //
 | ||||||
|   // Check results
 |   // Check results
 | ||||||
|   //
 |   //
 | ||||||
|   if (GotIt) { |   if (GotIt == 1) { | ||||||
|     return EFI_SUCCESS; |     return EFI_SUCCESS; | ||||||
|   } else { |   } else { | ||||||
|     return EFI_TIMEOUT; |     return EFI_TIMEOUT; | ||||||
| @ -1222,7 +1156,7 @@ KeyboardWaitForValue ( | |||||||
| 
 | 
 | ||||||
|   @param ConsoleIn Pointer to instance of KEYBOARD_CONSOLE_IN_DEV |   @param ConsoleIn Pointer to instance of KEYBOARD_CONSOLE_IN_DEV | ||||||
|    |    | ||||||
|   @return status |   @return status of updating keyboard register | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -1276,8 +1210,8 @@ UpdateStatusLights ( | |||||||
| 
 | 
 | ||||||
|   @param ConsoleIn KEYBOARD_CONSOLE_IN_DEV instance pointer |   @param ConsoleIn KEYBOARD_CONSOLE_IN_DEV instance pointer | ||||||
| 
 | 
 | ||||||
|   @retval EFI_NOT_READY - Input from console not ready yet. |   @retval EFI_NOT_READY  Input from console not ready yet. | ||||||
|   @retval EFI_SUCCESS   - Function executed successfully. |   @retval EFI_SUCCESS    Function executed successfully. | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -1365,7 +1299,7 @@ KeyGetchar ( | |||||||
|   // Check if there are enough bytes of scancode representing a single key
 |   // Check if there are enough bytes of scancode representing a single key
 | ||||||
|   // available in the buffer
 |   // available in the buffer
 | ||||||
|   //
 |   //
 | ||||||
|   while (1) { |   while (TRUE) { | ||||||
| 
 | 
 | ||||||
|     Status          = GetScancodeBufHead (ConsoleIn, 1, ScancodeArr); |     Status          = GetScancodeBufHead (ConsoleIn, 1, ScancodeArr); | ||||||
|     ScancodeArrPos  = 0; |     ScancodeArrPos  = 0; | ||||||
| @ -1516,7 +1450,7 @@ KeyGetchar ( | |||||||
|   //
 |   //
 | ||||||
|   if (Extended && ScanCode == 0x35) { |   if (Extended && ScanCode == 0x35) { | ||||||
|     ConsoleIn->Key.ScanCode     = SCAN_NULL; |     ConsoleIn->Key.ScanCode     = SCAN_NULL; | ||||||
|     ConsoleIn->Key.UnicodeChar  = '/'; |     ConsoleIn->Key.UnicodeChar  = L'/'; | ||||||
|     return EFI_SUCCESS; |     return EFI_SUCCESS; | ||||||
|   } |   } | ||||||
|   //
 |   //
 | ||||||
| @ -1531,7 +1465,7 @@ KeyGetchar ( | |||||||
|         // Need not return associated shift state if a class of printable characters that
 |         // Need not return associated shift state if a class of printable characters that
 | ||||||
|         // are normally adjusted by shift modifiers. e.g. Shift Key + 'f' key = 'F'
 |         // are normally adjusted by shift modifiers. e.g. Shift Key + 'f' key = 'F'
 | ||||||
|         //
 |         //
 | ||||||
|         if (ConsoleIn->Key.UnicodeChar >= 'A' && ConsoleIn->Key.UnicodeChar <= 'Z') { |         if (ConsoleIn->Key.UnicodeChar >= L'A' && ConsoleIn->Key.UnicodeChar <= L'Z') { | ||||||
|           ConsoleIn->LeftShift  = FALSE; |           ConsoleIn->LeftShift  = FALSE; | ||||||
|           ConsoleIn->RightShift = FALSE; |           ConsoleIn->RightShift = FALSE; | ||||||
|         } |         } | ||||||
| @ -1542,9 +1476,9 @@ KeyGetchar ( | |||||||
|       // alphabetic key is affected by CapsLock State
 |       // alphabetic key is affected by CapsLock State
 | ||||||
|       //
 |       //
 | ||||||
|       if (ConsoleIn->CapsLock) { |       if (ConsoleIn->CapsLock) { | ||||||
|         if (ConsoleIn->Key.UnicodeChar >= 'a' && ConsoleIn->Key.UnicodeChar <= 'z') { |         if (ConsoleIn->Key.UnicodeChar >= L'a' && ConsoleIn->Key.UnicodeChar <= L'z') { | ||||||
|           ConsoleIn->Key.UnicodeChar = ConvertKeyboardScanCodeToEfiKey[Index].ShiftUnicodeChar; |           ConsoleIn->Key.UnicodeChar = ConvertKeyboardScanCodeToEfiKey[Index].ShiftUnicodeChar; | ||||||
|         } else if (ConsoleIn->Key.UnicodeChar >= 'A' && ConsoleIn->Key.UnicodeChar <= 'Z') { |         } else if (ConsoleIn->Key.UnicodeChar >= L'A' && ConsoleIn->Key.UnicodeChar <= L'Z') { | ||||||
|           ConsoleIn->Key.UnicodeChar = ConvertKeyboardScanCodeToEfiKey[Index].UnicodeChar; |           ConsoleIn->Key.UnicodeChar = ConvertKeyboardScanCodeToEfiKey[Index].UnicodeChar; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @ -1552,10 +1486,10 @@ KeyGetchar ( | |||||||
|       // Translate the CTRL-Alpha characters to their corresponding control value (ctrl-a = 0x0001 through ctrl-Z = 0x001A)
 |       // Translate the CTRL-Alpha characters to their corresponding control value (ctrl-a = 0x0001 through ctrl-Z = 0x001A)
 | ||||||
|       //
 |       //
 | ||||||
|       if (ConsoleIn->Ctrled) { |       if (ConsoleIn->Ctrled) { | ||||||
|         if (ConsoleIn->Key.UnicodeChar >= 'a' && ConsoleIn->Key.UnicodeChar <= 'z') { |         if (ConsoleIn->Key.UnicodeChar >= L'a' && ConsoleIn->Key.UnicodeChar <= L'z') { | ||||||
|           ConsoleIn->Key.UnicodeChar = (UINT16) (ConsoleIn->Key.UnicodeChar - 'a' + 1); |           ConsoleIn->Key.UnicodeChar = (UINT16) (ConsoleIn->Key.UnicodeChar - L'a' + 1); | ||||||
|         } else if (ConsoleIn->Key.UnicodeChar >= 'A' && ConsoleIn->Key.UnicodeChar <= 'Z') { |         } else if (ConsoleIn->Key.UnicodeChar >= L'A' && ConsoleIn->Key.UnicodeChar <= L'Z') { | ||||||
|           ConsoleIn->Key.UnicodeChar = (UINT16) (ConsoleIn->Key.UnicodeChar - 'A' + 1); |           ConsoleIn->Key.UnicodeChar = (UINT16) (ConsoleIn->Key.UnicodeChar - L'A' + 1); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -1571,13 +1505,13 @@ KeyGetchar ( | |||||||
|     if (ConsoleIn->NumLock && !ConsoleIn->Shift && !Extended) { |     if (ConsoleIn->NumLock && !ConsoleIn->Shift && !Extended) { | ||||||
|       ConsoleIn->Key.ScanCode = SCAN_NULL; |       ConsoleIn->Key.ScanCode = SCAN_NULL; | ||||||
|     } else if (ScanCode != 0x4a && ScanCode != 0x4e) { |     } else if (ScanCode != 0x4a && ScanCode != 0x4e) { | ||||||
|       ConsoleIn->Key.UnicodeChar = 0x00; |       ConsoleIn->Key.UnicodeChar = 0x0000; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   //
 |   //
 | ||||||
|   // If the key can not be converted then just return.
 |   // If the key can not be converted then just return.
 | ||||||
|   //
 |   //
 | ||||||
|   if (ConsoleIn->Key.ScanCode == SCAN_NULL && ConsoleIn->Key.UnicodeChar == 0x00) { |   if (ConsoleIn->Key.ScanCode == SCAN_NULL && ConsoleIn->Key.UnicodeChar == 0x0000) { | ||||||
|     return EFI_NOT_READY; |     return EFI_NOT_READY; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| @ -1690,7 +1624,7 @@ InitKeyboard ( | |||||||
|   // Test the system flag in to determine whether this is the first
 |   // Test the system flag in to determine whether this is the first
 | ||||||
|   // time initialization
 |   // time initialization
 | ||||||
|   //
 |   //
 | ||||||
|   if ((KeyReadStatusRegister (ConsoleIn) & 0x04)) { |   if ((KeyReadStatusRegister (ConsoleIn) & KEYBOARD_STATUS_REGISTER_SYSTEM_FLAG)) { | ||||||
|     //
 |     //
 | ||||||
|     // 8042 controller is already setup (by myself or by mouse driver):
 |     // 8042 controller is already setup (by myself or by mouse driver):
 | ||||||
|     //   See whether mouse interface is already enabled
 |     //   See whether mouse interface is already enabled
 | ||||||
| @ -1699,7 +1633,7 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // Read the command byte of 8042 controller
 |     // Read the command byte of 8042 controller
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardCommand (ConsoleIn, 0x20); |     Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_READ); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"\n\r"); |       KeyboardError (ConsoleIn, L"\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1728,13 +1662,13 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // Disable keyboard and mouse interfaces
 |     // Disable keyboard and mouse interfaces
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardCommand (ConsoleIn, 0xad); |     Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_DISABLE_KEYBOARD_INTERFACE); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"\n\r"); |       KeyboardError (ConsoleIn, L"\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Status = KeyboardCommand (ConsoleIn, 0xa7); |     Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_DISABLE_MOUSE_INTERFACE); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"\n\r"); |       KeyboardError (ConsoleIn, L"\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1748,7 +1682,7 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // 8042 Controller Self Test
 |     // 8042 Controller Self Test
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardCommand (ConsoleIn, 0xaa); |     Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_CONTROLLER_SELF_TEST); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); |       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1787,7 +1721,7 @@ InitKeyboard ( | |||||||
|   //  1: Enable Auxiliary device interrupt
 |   //  1: Enable Auxiliary device interrupt
 | ||||||
|   //  0: Enable Keyboard interrupt )
 |   //  0: Enable Keyboard interrupt )
 | ||||||
|   //
 |   //
 | ||||||
|   Status = KeyboardCommand (ConsoleIn, 0x60); |   Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_WRITE); | ||||||
|   if (EFI_ERROR (Status)) { |   if (EFI_ERROR (Status)) { | ||||||
|     KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); |     KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); | ||||||
|     goto Done; |     goto Done; | ||||||
| @ -1837,7 +1771,7 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // Keyboard Interface Test
 |     // Keyboard Interface Test
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardCommand (ConsoleIn, 0xab); |     Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_KEYBOARD_INTERFACE_SELF_TEST); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); |       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1854,13 +1788,13 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // Keyboard reset with a BAT(Basic Assurance Test)
 |     // Keyboard reset with a BAT(Basic Assurance Test)
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardWrite (ConsoleIn, 0xff); |     Status = KeyboardWrite (ConsoleIn, KEYBOARD_8048_COMMAND_RESET); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); |       KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Status = KeyboardWaitForValue (ConsoleIn, 0xfa); |     Status = KeyboardWaitForValue (ConsoleIn, KEYBOARD_8048_RETURN_8042_ACK); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); |       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1870,7 +1804,7 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     mWaitForValueTimeOut  = KEYBOARD_BAT_TIMEOUT; |     mWaitForValueTimeOut  = KEYBOARD_BAT_TIMEOUT; | ||||||
| 
 | 
 | ||||||
|     Status                = KeyboardWaitForValue (ConsoleIn, 0xaa); |     Status                = KeyboardWaitForValue (ConsoleIn, KEYBOARD_8048_RETURN_8042_BAT_SUCCESS); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"Keyboard self test failed!\n\r"); |       KeyboardError (ConsoleIn, L"Keyboard self test failed!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1881,13 +1815,13 @@ InitKeyboard ( | |||||||
|     //
 |     //
 | ||||||
|     // Set Keyboard to use Scan Code Set 2
 |     // Set Keyboard to use Scan Code Set 2
 | ||||||
|     //
 |     //
 | ||||||
|     Status = KeyboardWrite (ConsoleIn, 0xf0); |     Status = KeyboardWrite (ConsoleIn, KEYBOARD_8048_COMMAND_SELECT_SCAN_CODE_SET); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); |       KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Status = KeyboardWaitForValue (ConsoleIn, 0xfa); |     Status = KeyboardWaitForValue (ConsoleIn, KEYBOARD_8048_RETURN_8042_ACK); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); |       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1899,7 +1833,7 @@ InitKeyboard ( | |||||||
|       goto Done; |       goto Done; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Status = KeyboardWaitForValue (ConsoleIn, 0xfa); |     Status = KeyboardWaitForValue (ConsoleIn, KEYBOARD_8048_RETURN_8042_ACK); | ||||||
|     if (EFI_ERROR (Status)) { |     if (EFI_ERROR (Status)) { | ||||||
|       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); |       KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); | ||||||
|       goto Done; |       goto Done; | ||||||
| @ -1908,13 +1842,13 @@ InitKeyboard ( | |||||||
|   //
 |   //
 | ||||||
|   // Clear Keyboard Scancode Buffer
 |   // Clear Keyboard Scancode Buffer
 | ||||||
|   //
 |   //
 | ||||||
|   Status = KeyboardWrite (ConsoleIn, 0xf4); |   Status = KeyboardWrite (ConsoleIn, KEYBOARD_8048_COMMAND_CLEAR_OUTPUT_DATA); | ||||||
|   if (EFI_ERROR (Status)) { |   if (EFI_ERROR (Status)) { | ||||||
|     KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); |     KeyboardError (ConsoleIn, L"8042 controller data write error!\n\r"); | ||||||
|     goto Done; |     goto Done; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   Status = KeyboardWaitForValue (ConsoleIn, 0xfa); |   Status = KeyboardWaitForValue (ConsoleIn, KEYBOARD_8048_RETURN_8042_ACK); | ||||||
|   if (EFI_ERROR (Status)) { |   if (EFI_ERROR (Status)) { | ||||||
|     KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); |     KeyboardError (ConsoleIn, L"Some specific value not aquired from 8042 controller!\n\r"); | ||||||
|     goto Done; |     goto Done; | ||||||
| @ -1951,7 +1885,7 @@ Done: | |||||||
|     //
 |     //
 | ||||||
|     // Enable mouse interface
 |     // Enable mouse interface
 | ||||||
|     //
 |     //
 | ||||||
|     Status1 = KeyboardCommand (ConsoleIn, 0xa8); |     Status1 = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_ENABLE_MOUSE_INTERFACE); | ||||||
|     if (EFI_ERROR (Status1)) { |     if (EFI_ERROR (Status1)) { | ||||||
|       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); |       KeyboardError (ConsoleIn, L"8042 controller command write error!\n\r"); | ||||||
|       return EFI_DEVICE_ERROR; |       return EFI_DEVICE_ERROR; | ||||||
| @ -1984,7 +1918,7 @@ DisableKeyboard ( | |||||||
|   //
 |   //
 | ||||||
|   // Disable keyboard interface
 |   // Disable keyboard interface
 | ||||||
|   //
 |   //
 | ||||||
|   Status = KeyboardCommand (ConsoleIn, 0xad); |   Status = KeyboardCommand (ConsoleIn, KEYBOARD_8042_COMMAND_DISABLE_KEYBOARD_INTERFACE); | ||||||
|   if (EFI_ERROR (Status)) { |   if (EFI_ERROR (Status)) { | ||||||
|     KeyboardError (ConsoleIn, L"\n\r"); |     KeyboardError (ConsoleIn, L"\n\r"); | ||||||
|     return EFI_DEVICE_ERROR; |     return EFI_DEVICE_ERROR; | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| /**@file
 | /**@file
 | ||||||
|   PS/2 Keyboard  driver |   Routines implements SIMPLE_TEXT_IN protocol's interfaces based on 8042 interfaces | ||||||
|   Routines that support SIMPLE_TEXT_IN protocol |   provided by Ps2KbdCtrller.c. | ||||||
| 
 | 
 | ||||||
| Copyright (c) 2006 - 2007, Intel Corporation | Copyright (c) 2006 - 2007, Intel Corporation | ||||||
| All rights reserved. This program and the accompanying materials | All rights reserved. This program and the accompanying materials | ||||||
| @ -16,66 +16,89 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
| 
 | 
 | ||||||
| #include "Ps2Keyboard.h" | #include "Ps2Keyboard.h" | ||||||
| 
 | 
 | ||||||
| //
 | /**
 | ||||||
| // function declarations
 |   Check keyboard for given key value | ||||||
| //
 |    | ||||||
| EFI_STATUS |   @param  This  Point to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL | ||||||
| EFIAPI |    | ||||||
| KeyboardEfiReset ( |   @retval EFI_SUCCESS   success check keyboard value | ||||||
|   IN  EFI_SIMPLE_TEXT_INPUT_PROTOCOL  *This, |   @retval !EFI_SUCCESS  Fail to get char from keyboard | ||||||
|   IN  BOOLEAN                         ExtendedVerification | **/ | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS |  | ||||||
| EFIAPI |  | ||||||
| KeyboardReadKeyStroke ( |  | ||||||
|   IN  EFI_SIMPLE_TEXT_INPUT_PROTOCOL  *This, |  | ||||||
|   OUT EFI_INPUT_KEY                   *Key |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| VOID |  | ||||||
| EFIAPI |  | ||||||
| KeyboardWaitForKey ( |  | ||||||
|   IN  EFI_EVENT               Event, |  | ||||||
|   IN  VOID                    *Context |  | ||||||
|   ); |  | ||||||
| 
 |  | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| KeyboardCheckForKey ( | KeyboardCheckForKey ( | ||||||
|   IN  EFI_SIMPLE_TEXT_INPUT_PROTOCOL *This |   IN  EFI_SIMPLE_TEXT_INPUT_PROTOCOL *This | ||||||
|   ); |   ) | ||||||
|  | { | ||||||
|  |   KEYBOARD_CONSOLE_IN_DEV *ConsoleIn; | ||||||
|  | 
 | ||||||
|  |   ConsoleIn = KEYBOARD_CONSOLE_IN_DEV_FROM_THIS (This); | ||||||
|  | 
 | ||||||
|  |   //
 | ||||||
|  |   // If ready to read next key, check it
 | ||||||
|  |   //
 | ||||||
|  |   if (ConsoleIn->Key.ScanCode == SCAN_NULL && ConsoleIn->Key.UnicodeChar == 0x00) { | ||||||
|  |     return KeyGetchar (ConsoleIn); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return EFI_SUCCESS; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|   @param RegsiteredData    - A pointer to a buffer that is filled in with the keystroke  |   Judge whether is a registed key | ||||||
|                       state data for the key that was registered. |  | ||||||
|   @param InputData         - A pointer to a buffer that is filled in with the keystroke  |  | ||||||
|                       state data for the key that was pressed. |  | ||||||
| 
 | 
 | ||||||
|   @retval TRUE              - Key be pressed matches a registered key. |   @param RegsiteredData       A pointer to a buffer that is filled in with the keystroke  | ||||||
|   @retval FALSE             - Match failed.  |                               state data for the key that was registered. | ||||||
|  |   @param InputData            A pointer to a buffer that is filled in with the keystroke  | ||||||
|  |                               state data for the key that was pressed. | ||||||
|  | 
 | ||||||
|  |   @retval TRUE                Key be pressed matches a registered key. | ||||||
|  |   @retval FLASE               Match failed.  | ||||||
|    |    | ||||||
| **/ | **/ | ||||||
| BOOLEAN | BOOLEAN | ||||||
| IsKeyRegistered ( | IsKeyRegistered ( | ||||||
|   IN EFI_KEY_DATA  *RegsiteredData, |   IN EFI_KEY_DATA  *RegsiteredData, | ||||||
|   IN EFI_KEY_DATA  *InputData |   IN EFI_KEY_DATA  *InputData | ||||||
|   ); |   ) | ||||||
|  | 
 | ||||||
|  | { | ||||||
|  |   ASSERT (RegsiteredData != NULL && InputData != NULL); | ||||||
|  |    | ||||||
|  |   if ((RegsiteredData->Key.ScanCode    != InputData->Key.ScanCode) || | ||||||
|  |       (RegsiteredData->Key.UnicodeChar != InputData->Key.UnicodeChar)) { | ||||||
|  |     return FALSE;   | ||||||
|  |   }       | ||||||
|  |    | ||||||
|  |   //
 | ||||||
|  |   // Assume KeyShiftState/KeyToggleState = 0 in Registered key data means these state could be ignored.
 | ||||||
|  |   //
 | ||||||
|  |   if (RegsiteredData->KeyState.KeyShiftState != 0 && | ||||||
|  |       RegsiteredData->KeyState.KeyShiftState != InputData->KeyState.KeyShiftState) { | ||||||
|  |     return FALSE;     | ||||||
|  |   }    | ||||||
|  |   if (RegsiteredData->KeyState.KeyToggleState != 0 && | ||||||
|  |       RegsiteredData->KeyState.KeyToggleState != InputData->KeyState.KeyToggleState) { | ||||||
|  |     return FALSE;     | ||||||
|  |   }      | ||||||
|  |    | ||||||
|  |   return TRUE; | ||||||
|  | 
 | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|     Reads the next keystroke from the input device. The WaitForKey Event can  |     Reads the next keystroke from the input device. The WaitForKey Event can  | ||||||
|     be used to test for existance of a keystroke via WaitForEvent () call. |     be used to test for existance of a keystroke via WaitForEvent () call. | ||||||
|  |    | ||||||
|  |     @param ConsoleInDev          Ps2 Keyboard private structure | ||||||
|  |     @param KeyData               A pointer to a buffer that is filled in with the keystroke  | ||||||
|  |                                  state data for the key that was pressed. | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
|     @param ConsoleInDev          - Ps2 Keyboard private structure |     @retval EFI_SUCCESS             The keystroke information was returned. | ||||||
|     @param KeyData               - A pointer to a buffer that is filled in with the keystroke  |     @retval EFI_NOT_READY           There was no keystroke data availiable. | ||||||
|                             state data for the key that was pressed. |     @retval EFI_DEVICE_ERROR        The keystroke information was not returned due to  | ||||||
| 
 |                                     hardware errors. | ||||||
|    |     @retval EFI_INVALID_PARAMETER   KeyData is NULL.                         | ||||||
|     @retval EFI_SUCCESS           - The keystroke information was returned. |  | ||||||
|     @retval EFI_NOT_READY         - There was no keystroke data availiable. |  | ||||||
|     @retval EFI_DEVICE_ERROR      - The keystroke information was not returned due to  |  | ||||||
|                             hardware errors. |  | ||||||
|     @retval EFI_INVALID_PARAMETER - KeyData is NULL.                         |  | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -90,6 +113,7 @@ KeyboardReadKeyStrokeWorker ( | |||||||
|   LIST_ENTRY                            *Link; |   LIST_ENTRY                            *Link; | ||||||
|   KEYBOARD_CONSOLE_IN_EX_NOTIFY         *CurrentNotify; |   KEYBOARD_CONSOLE_IN_EX_NOTIFY         *CurrentNotify; | ||||||
|   EFI_KEY_DATA                          OriginalKeyData; |   EFI_KEY_DATA                          OriginalKeyData; | ||||||
|  |    | ||||||
|   if (KeyData == NULL) { |   if (KeyData == NULL) { | ||||||
|     return EFI_INVALID_PARAMETER; |     return EFI_INVALID_PARAMETER; | ||||||
|   } |   } | ||||||
| @ -111,6 +135,7 @@ KeyboardReadKeyStrokeWorker ( | |||||||
|     gBS->RestoreTPL (OldTpl); |     gBS->RestoreTPL (OldTpl); | ||||||
|     return EFI_NOT_READY; |     return EFI_NOT_READY; | ||||||
|   } |   } | ||||||
|  |    | ||||||
|   CopyMem (&KeyData->Key, &ConsoleInDev->Key, sizeof (EFI_INPUT_KEY)); |   CopyMem (&KeyData->Key, &ConsoleInDev->Key, sizeof (EFI_INPUT_KEY)); | ||||||
| 
 | 
 | ||||||
|   ConsoleInDev->Key.ScanCode    = SCAN_NULL;           |   ConsoleInDev->Key.ScanCode    = SCAN_NULL;           | ||||||
| @ -128,9 +153,9 @@ KeyboardReadKeyStrokeWorker ( | |||||||
|   if (ConsoleInDev->Ctrled) { |   if (ConsoleInDev->Ctrled) { | ||||||
|     if (OriginalKeyData.Key.UnicodeChar >= 0x01 && OriginalKeyData.Key.UnicodeChar <= 0x1A) { |     if (OriginalKeyData.Key.UnicodeChar >= 0x01 && OriginalKeyData.Key.UnicodeChar <= 0x1A) { | ||||||
|       if (ConsoleInDev->CapsLock) { |       if (ConsoleInDev->CapsLock) { | ||||||
|         OriginalKeyData.Key.UnicodeChar = (CHAR16)(OriginalKeyData.Key.UnicodeChar + 'A' - 1); |         OriginalKeyData.Key.UnicodeChar = (CHAR16)(OriginalKeyData.Key.UnicodeChar + L'A' - 1); | ||||||
|       } else { |       } else { | ||||||
|         OriginalKeyData.Key.UnicodeChar = (CHAR16)(OriginalKeyData.Key.UnicodeChar + 'a' - 1); |         OriginalKeyData.Key.UnicodeChar = (CHAR16)(OriginalKeyData.Key.UnicodeChar + L'a' - 1); | ||||||
|       }  |       }  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -153,11 +178,9 @@ KeyboardReadKeyStrokeWorker ( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|   logic reset keyboard |   Perform 8042 controller and keyboard initialization which implement SIMPLE_TEXT_IN.Reset() | ||||||
|   Implement SIMPLE_TEXT_IN.Reset() |  | ||||||
|   Perform 8042 controller and keyboard initialization |  | ||||||
| 
 | 
 | ||||||
|   @param This    Pointer to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL |   @param This                 Pointer to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL | ||||||
|   @param ExtendedVerification Indicate that the driver may perform a more  |   @param ExtendedVerification Indicate that the driver may perform a more  | ||||||
|                               exhaustive verification operation of the device during  |                               exhaustive verification operation of the device during  | ||||||
|                               reset, now this par is ignored in this driver     |                               reset, now this par is ignored in this driver     | ||||||
| @ -237,8 +260,7 @@ KeyboardEfiReset ( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|   Implement SIMPLE_TEXT_IN.ReadKeyStroke(). |   Retrieve key values for driver user which implement SIMPLE_TEXT_IN.ReadKeyStroke(). | ||||||
|   Retrieve key values for driver user. |  | ||||||
| 
 | 
 | ||||||
|   @param This    Pointer to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL |   @param This    Pointer to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL | ||||||
|   @param Key     The output buffer for key value  |   @param Key     The output buffer for key value  | ||||||
| @ -314,74 +336,6 @@ KeyboardWaitForKey ( | |||||||
|   return ; |   return ; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 |  | ||||||
|   Check keyboard for given key value |  | ||||||
|    |  | ||||||
|   @param  This  Point to instance of EFI_SIMPLE_TEXT_INPUT_PROTOCOL |  | ||||||
|    |  | ||||||
|   @retval EFI_SUCCESS success check keyboard value |  | ||||||
| **/ |  | ||||||
| EFI_STATUS |  | ||||||
| KeyboardCheckForKey ( |  | ||||||
|   IN  EFI_SIMPLE_TEXT_INPUT_PROTOCOL *This |  | ||||||
|   ) |  | ||||||
| { |  | ||||||
|   KEYBOARD_CONSOLE_IN_DEV *ConsoleIn; |  | ||||||
| 
 |  | ||||||
|   ConsoleIn = KEYBOARD_CONSOLE_IN_DEV_FROM_THIS (This); |  | ||||||
| 
 |  | ||||||
|   //
 |  | ||||||
|   // If ready to read next key, check it
 |  | ||||||
|   //
 |  | ||||||
|   if (ConsoleIn->Key.ScanCode == SCAN_NULL && ConsoleIn->Key.UnicodeChar == 0x00) { |  | ||||||
|     return KeyGetchar (ConsoleIn); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   return EFI_SUCCESS; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /**
 |  | ||||||
|   Judge whether is a registed key |  | ||||||
| 
 |  | ||||||
|   @param RegsiteredData    - A pointer to a buffer that is filled in with the keystroke  |  | ||||||
|                       state data for the key that was registered. |  | ||||||
|   @param InputData         - A pointer to a buffer that is filled in with the keystroke  |  | ||||||
|                       state data for the key that was pressed. |  | ||||||
| 
 |  | ||||||
|   @retval TRUE              - Key be pressed matches a registered key. |  | ||||||
|   @retval FLASE             - Match failed.  |  | ||||||
|    |  | ||||||
| **/ |  | ||||||
| BOOLEAN |  | ||||||
| IsKeyRegistered ( |  | ||||||
|   IN EFI_KEY_DATA  *RegsiteredData, |  | ||||||
|   IN EFI_KEY_DATA  *InputData |  | ||||||
|   ) |  | ||||||
| 
 |  | ||||||
| { |  | ||||||
|   ASSERT (RegsiteredData != NULL && InputData != NULL); |  | ||||||
|    |  | ||||||
|   if ((RegsiteredData->Key.ScanCode    != InputData->Key.ScanCode) || |  | ||||||
|       (RegsiteredData->Key.UnicodeChar != InputData->Key.UnicodeChar)) { |  | ||||||
|     return FALSE;   |  | ||||||
|   }       |  | ||||||
|    |  | ||||||
|   //
 |  | ||||||
|   // Assume KeyShiftState/KeyToggleState = 0 in Registered key data means these state could be ignored.
 |  | ||||||
|   //
 |  | ||||||
|   if (RegsiteredData->KeyState.KeyShiftState != 0 && |  | ||||||
|       RegsiteredData->KeyState.KeyShiftState != InputData->KeyState.KeyShiftState) { |  | ||||||
|     return FALSE;     |  | ||||||
|   }    |  | ||||||
|   if (RegsiteredData->KeyState.KeyToggleState != 0 && |  | ||||||
|       RegsiteredData->KeyState.KeyToggleState != InputData->KeyState.KeyToggleState) { |  | ||||||
|     return FALSE;     |  | ||||||
|   }      |  | ||||||
|    |  | ||||||
|   return TRUE; |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|   Event notification function for SIMPLE_TEXT_INPUT_EX_PROTOCOL.WaitForKeyEx event |   Event notification function for SIMPLE_TEXT_INPUT_EX_PROTOCOL.WaitForKeyEx event | ||||||
|   Signal the event if there is key available |   Signal the event if there is key available | ||||||
| @ -408,11 +362,11 @@ KeyboardWaitForKeyEx ( | |||||||
| /**
 | /**
 | ||||||
|   Reset the input device and optionaly run diagnostics |   Reset the input device and optionaly run diagnostics | ||||||
| 
 | 
 | ||||||
|   @param This                 - Protocol instance pointer. |   @param This                     Protocol instance pointer. | ||||||
|   @param ExtendedVerification - Driver may perform diagnostics on reset. |   @param ExtendedVerification     Driver may perform diagnostics on reset. | ||||||
| 
 | 
 | ||||||
|   @retval EFI_SUCCESS           - The device was reset. |   @retval EFI_SUCCESS             The device was reset. | ||||||
|   @retval EFI_DEVICE_ERROR      - The device is not functioning properly and could  |   @retval EFI_DEVICE_ERROR        The device is not functioning properly and could  | ||||||
|                                   not be reset. |                                   not be reset. | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| @ -456,15 +410,15 @@ KeyboardEfiResetEx ( | |||||||
|     be used to test for existance of a keystroke via WaitForEvent () call. |     be used to test for existance of a keystroke via WaitForEvent () call. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     @param This       - Protocol instance pointer. |     @param This         Protocol instance pointer. | ||||||
|     @param KeyData    - A pointer to a buffer that is filled in with the keystroke  |     @param KeyData      A pointer to a buffer that is filled in with the keystroke  | ||||||
|                  state data for the key that was pressed. |                         state data for the key that was pressed. | ||||||
| 
 | 
 | ||||||
|     @retval EFI_SUCCESS           - The keystroke information was returned. |     @retval EFI_SUCCESS           The keystroke information was returned. | ||||||
|     @retval EFI_NOT_READY         - There was no keystroke data availiable. |     @retval EFI_NOT_READY         There was no keystroke data availiable. | ||||||
|     @retval EFI_DEVICE_ERROR      - The keystroke information was not returned due to  |     @retval EFI_DEVICE_ERROR      The keystroke information was not returned due to  | ||||||
|                             hardware errors. |                                   hardware errors. | ||||||
|     @retval EFI_INVALID_PARAMETER - KeyData is NULL.                         |     @retval EFI_INVALID_PARAMETER KeyData is NULL.                         | ||||||
| 
 | 
 | ||||||
| **/ | **/ | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -489,15 +443,15 @@ KeyboardReadKeyStrokeEx ( | |||||||
| /**
 | /**
 | ||||||
|   Set certain state for the input device. |   Set certain state for the input device. | ||||||
| 
 | 
 | ||||||
|   @param This              - Protocol instance pointer. |   @param This               Protocol instance pointer. | ||||||
|   @param KeyToggleState    - A pointer to the EFI_KEY_TOGGLE_STATE to set the  |   @param KeyToggleState     A pointer to the EFI_KEY_TOGGLE_STATE to set the  | ||||||
|                         state for the input device. |                             state for the input device. | ||||||
| 
 | 
 | ||||||
|   @retval EFI_SUCCESS           - The device state was set successfully. |   @retval EFI_SUCCESS           The device state was set successfully. | ||||||
|   @retval EFI_DEVICE_ERROR      - The device is not functioning correctly and could  |   @retval EFI_DEVICE_ERROR      The device is not functioning correctly and could  | ||||||
|                             not have the setting adjusted. |                                 not have the setting adjusted. | ||||||
|   @retval EFI_UNSUPPORTED       - The device does not have the ability to set its state. |   @retval EFI_UNSUPPORTED       The device does not have the ability to set its state. | ||||||
|   @retval EFI_INVALID_PARAMETER - KeyToggleState is NULL.                        |   @retval EFI_INVALID_PARAMETER KeyToggleState is NULL.                        | ||||||
| 
 | 
 | ||||||
| **/    | **/    | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -571,16 +525,16 @@ Exit: | |||||||
| /**
 | /**
 | ||||||
|     Register a notification function for a particular keystroke for the input device. |     Register a notification function for a particular keystroke for the input device. | ||||||
| 
 | 
 | ||||||
|     @param This                    - Protocol instance pointer. |     @param This                       Protocol instance pointer. | ||||||
|     @param KeyData                 - A pointer to a buffer that is filled in with the keystroke  |     @param KeyData                    A pointer to a buffer that is filled in with the keystroke  | ||||||
|                               information data for the key that was pressed. |                                       information data for the key that was pressed. | ||||||
|     @param KeyNotificationFunction - Points to the function to be called when the key  |     @param KeyNotificationFunction    Points to the function to be called when the key  | ||||||
|                               sequence is typed specified by KeyData.                         |                                       sequence is typed specified by KeyData.                         | ||||||
|     @param NotifyHandle            - Points to the unique handle assigned to the registered notification.                           |     @param NotifyHandle               Points to the unique handle assigned to the registered notification.                           | ||||||
| 
 | 
 | ||||||
|     @retval EFI_SUCCESS             - The notification function was registered successfully. |     @retval EFI_SUCCESS               The notification function was registered successfully. | ||||||
|     @retval EFI_OUT_OF_RESOURCES    - Unable to allocate resources for necesssary data structures. |     @retval EFI_OUT_OF_RESOURCES      Unable to allocate resources for necesssary data structures. | ||||||
|     @retval EFI_INVALID_PARAMETER   - KeyData or NotifyHandle is NULL.                        |     @retval EFI_INVALID_PARAMETER     KeyData or NotifyHandle or KeyNotificationFunction is NULL.                        | ||||||
|                                |                                | ||||||
| **/    | **/    | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| @ -659,12 +613,12 @@ Exit: | |||||||
| /**
 | /**
 | ||||||
|     Remove a registered notification function from a particular keystroke. |     Remove a registered notification function from a particular keystroke. | ||||||
| 
 | 
 | ||||||
|     @param This                    - Protocol instance pointer.     |     @param This                       Protocol instance pointer.     | ||||||
|     @param NotificationHandle      - The handle of the notification function being unregistered. |     @param NotificationHandle         The handle of the notification function being unregistered. | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
|     @retval EFI_SUCCESS             - The notification function was unregistered successfully. |     @retval EFI_SUCCESS               The notification function was unregistered successfully. | ||||||
|     @retval EFI_INVALID_PARAMETER   - The NotificationHandle is invalid. |     @retval EFI_INVALID_PARAMETER     The NotificationHandle is invalid. | ||||||
|                                |                                | ||||||
| **/    | **/    | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
|  | |||||||
| @ -555,7 +555,7 @@ KbdFreeNotifyList ( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|   The user Entry Point for module Ps2Keyboard. The user code starts with this function. |   The module Entry Point for module Ps2Keyboard.  | ||||||
| 
 | 
 | ||||||
|   @param[in] ImageHandle    The firmware allocated handle for the EFI image.   |   @param[in] ImageHandle    The firmware allocated handle for the EFI image.   | ||||||
|   @param[in] SystemTable    A pointer to the EFI System Table. |   @param[in] SystemTable    A pointer to the EFI System Table. | ||||||
|  | |||||||
| @ -33,6 +33,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
| #include <Library/MemoryAllocationLib.h> | #include <Library/MemoryAllocationLib.h> | ||||||
| #include <Library/BaseLib.h> | #include <Library/BaseLib.h> | ||||||
| #include <Library/BaseMemoryLib.h> | #include <Library/BaseMemoryLib.h> | ||||||
|  | #include <Library/TimerLib.h> | ||||||
| 
 | 
 | ||||||
| //
 | //
 | ||||||
| // Global Variables
 | // Global Variables
 | ||||||
| @ -180,6 +181,32 @@ InstallPs2KeyboardDriver ( | |||||||
| #define SCANCODE_SYS_REQ_MAKE           0x37 | #define SCANCODE_SYS_REQ_MAKE           0x37 | ||||||
| #define SCANCODE_MAX_MAKE               0x60 | #define SCANCODE_MAX_MAKE               0x60 | ||||||
| 
 | 
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_HAS_OUTPUT_DATA     BIT0        ///< 0 - Output register has no data; 1 - Output register has data
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_HAS_INPUT_DATA      BIT1        ///< 0 - Input register has no data;  1 - Input register has data
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_SYSTEM_FLAG         BIT2        ///< Set to 0 after power on reset
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_INPUT_DATA_TYPE     BIT3        ///< 0 - Data in input register is data; 1 - Data in input register is command
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_ENABLE_FLAG         BIT4        ///< 0 - Keyboard is disable; 1 - Keyboard is enable
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_TRANSMIT_TIMEOUT    BIT5        ///< 0 - Transmit is complete without timeout; 1 - Transmit is timeout without complete
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_RECEIVE_TIMEOUT     BIT6        ///< 0 - Receive is complete without timeout; 1 - Receive is timeout without complete
 | ||||||
|  | #define KEYBOARD_STATUS_REGISTER_PARITY              BIT7        ///< 0 - Odd parity; 1 - Even parity
 | ||||||
|  | 
 | ||||||
|  | #define KEYBOARD_8042_COMMAND_READ                          0x20 | ||||||
|  | #define KEYBOARD_8042_COMMAND_WRITE                         0x60 | ||||||
|  | #define KEYBOARD_8042_COMMAND_DISABLE_MOUSE_INTERFACE       0xA7 | ||||||
|  | #define KEYBOARD_8042_COMMAND_ENABLE_MOUSE_INTERFACE        0xA8 | ||||||
|  | #define KEYBOARD_8042_COMMAND_CONTROLLER_SELF_TEST          0xAA | ||||||
|  | #define KEYBOARD_8042_COMMAND_KEYBOARD_INTERFACE_SELF_TEST  0xAB | ||||||
|  | #define KEYBOARD_8042_COMMAND_DISABLE_KEYBOARD_INTERFACE    0xAD | ||||||
|  | 
 | ||||||
|  | #define KEYBOARD_8048_COMMAND_CLEAR_OUTPUT_DATA             0xF4 | ||||||
|  | #define KEYBOARD_8048_COMMAND_RESET                         0xFF | ||||||
|  | #define KEYBOARD_8048_COMMAND_SELECT_SCAN_CODE_SET          0xF0 | ||||||
|  | 
 | ||||||
|  | #define KEYBOARD_8048_RETURN_8042_BAT_SUCCESS               0xAA | ||||||
|  | #define KEYBOARD_8048_RETURN_8042_BAT_ERROR                 0xFC | ||||||
|  | #define KEYBOARD_8048_RETURN_8042_ACK                       0xFA | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| //
 | //
 | ||||||
| // Keyboard Controller Status
 | // Keyboard Controller Status
 | ||||||
| //
 | //
 | ||||||
|  | |||||||
| @ -54,7 +54,8 @@ | |||||||
|   UefiDriverEntryPoint |   UefiDriverEntryPoint | ||||||
|   BaseLib |   BaseLib | ||||||
|   BaseMemoryLib |   BaseMemoryLib | ||||||
| 
 |   TimerLib | ||||||
|  |    | ||||||
| [Protocols] | [Protocols] | ||||||
|   gEfiPs2PolicyProtocolGuid                     # PROTOCOL TO_START |   gEfiPs2PolicyProtocolGuid                     # PROTOCOL TO_START | ||||||
|   gEfiIsaIoProtocolGuid                         # PROTOCOL TO_START |   gEfiIsaIoProtocolGuid                         # PROTOCOL TO_START | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 klu2
						klu2