]> git.proxmox.com Git - mirror_edk2.git/blobdiff - IntelFrameworkModulePkg/Bus/Isa/Ps2KeyboardDxe/Ps2Keyboard.c
Remove IntelFrameworkModulePkg
[mirror_edk2.git] / IntelFrameworkModulePkg / Bus / Isa / Ps2KeyboardDxe / Ps2Keyboard.c
diff --git a/IntelFrameworkModulePkg/Bus/Isa/Ps2KeyboardDxe/Ps2Keyboard.c b/IntelFrameworkModulePkg/Bus/Isa/Ps2KeyboardDxe/Ps2Keyboard.c
deleted file mode 100644 (file)
index 2dcb17f..0000000
+++ /dev/null
@@ -1,657 +0,0 @@
-/** @file\r
-\r
-  PS/2 Keyboard driver. Routines that interacts with callers,\r
-  conforming to EFI driver model\r
-\r
-Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>\r
-SPDX-License-Identifier: BSD-2-Clause-Patent\r
-\r
-**/\r
-\r
-#include "Ps2Keyboard.h"\r
-\r
-//\r
-// Function prototypes\r
-//\r
-/**\r
-  Test controller is a keyboard Controller.\r
-\r
-  @param This                 Pointer of EFI_DRIVER_BINDING_PROTOCOL\r
-  @param Controller           driver's controller\r
-  @param RemainingDevicePath  children device path\r
-\r
-  @retval EFI_UNSUPPORTED controller is not floppy disk\r
-  @retval EFI_SUCCESS     controller is floppy disk\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverSupported (\r
-  IN EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN EFI_HANDLE                     Controller,\r
-  IN EFI_DEVICE_PATH_PROTOCOL       *RemainingDevicePath\r
-  );\r
-\r
-/**\r
-  Create KEYBOARD_CONSOLE_IN_DEV instance on controller.\r
-\r
-  @param This         Pointer of EFI_DRIVER_BINDING_PROTOCOL\r
-  @param Controller   driver controller handle\r
-  @param RemainingDevicePath Children's device path\r
-\r
-  @retval whether success to create floppy control instance.\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverStart (\r
-  IN EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN EFI_HANDLE                     Controller,\r
-  IN EFI_DEVICE_PATH_PROTOCOL       *RemainingDevicePath\r
-  );\r
-\r
-/**\r
-  Stop this driver on ControllerHandle. Support stopping any child handles\r
-  created by this driver.\r
-\r
-  @param  This              Protocol instance pointer.\r
-  @param  ControllerHandle  Handle of device to stop driver on\r
-  @param  NumberOfChildren  Number of Handles in ChildHandleBuffer. If number of\r
-                            children is zero stop the entire bus driver.\r
-  @param  ChildHandleBuffer List of Child Handles to Stop.\r
-\r
-  @retval EFI_SUCCESS       This driver is removed ControllerHandle\r
-  @retval other             This driver was not removed from this device\r
-\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverStop (\r
-  IN  EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN  EFI_HANDLE                     Controller,\r
-  IN  UINTN                          NumberOfChildren,\r
-  IN  EFI_HANDLE                     *ChildHandleBuffer\r
-  );\r
-\r
-/**\r
-  Free the waiting key notify list.\r
-\r
-  @param ListHead  Pointer to list head\r
-\r
-  @retval EFI_INVALID_PARAMETER  ListHead is NULL\r
-  @retval EFI_SUCCESS            Sucess to free NotifyList\r
-**/\r
-EFI_STATUS\r
-KbdFreeNotifyList (\r
-  IN OUT LIST_ENTRY           *ListHead\r
-  );\r
-\r
-//\r
-// DriverBinding Protocol Instance\r
-//\r
-EFI_DRIVER_BINDING_PROTOCOL gKeyboardControllerDriver = {\r
-  KbdControllerDriverSupported,\r
-  KbdControllerDriverStart,\r
-  KbdControllerDriverStop,\r
-  0xa,\r
-  NULL,\r
-  NULL\r
-};\r
-\r
-/**\r
-  Test controller is a keyboard Controller.\r
-\r
-  @param This                 Pointer of EFI_DRIVER_BINDING_PROTOCOL\r
-  @param Controller           driver's controller\r
-  @param RemainingDevicePath  children device path\r
-\r
-  @retval EFI_UNSUPPORTED controller is not floppy disk\r
-  @retval EFI_SUCCESS     controller is floppy disk\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverSupported (\r
-  IN EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN EFI_HANDLE                     Controller,\r
-  IN EFI_DEVICE_PATH_PROTOCOL       *RemainingDevicePath\r
-  )\r
-{\r
-  EFI_STATUS                          Status;\r
-  EFI_ISA_IO_PROTOCOL                 *IsaIo;\r
-\r
-  //\r
-  // Open the IO Abstraction(s) needed to perform the supported test\r
-  //\r
-  Status = gBS->OpenProtocol (\r
-                  Controller,\r
-                  &gEfiIsaIoProtocolGuid,\r
-                  (VOID **) &IsaIo,\r
-                  This->DriverBindingHandle,\r
-                  Controller,\r
-                  EFI_OPEN_PROTOCOL_BY_DRIVER\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-  //\r
-  // Use the ISA I/O Protocol to see if Controller is the Keyboard controller\r
-  //\r
-  if (IsaIo->ResourceList->Device.HID != EISA_PNP_ID (0x303) || IsaIo->ResourceList->Device.UID != 0) {\r
-    Status = EFI_UNSUPPORTED;\r
-  }\r
-  //\r
-  // Close the I/O Abstraction(s) used to perform the supported test\r
-  //\r
-  gBS->CloseProtocol (\r
-         Controller,\r
-         &gEfiIsaIoProtocolGuid,\r
-         This->DriverBindingHandle,\r
-         Controller\r
-         );\r
-\r
-  return Status;\r
-}\r
-\r
-/**\r
-  Create KEYBOARD_CONSOLE_IN_DEV instance on controller.\r
-\r
-  @param This         Pointer of EFI_DRIVER_BINDING_PROTOCOL\r
-  @param Controller   driver controller handle\r
-  @param RemainingDevicePath Children's device path\r
-\r
-  @retval whether success to create floppy control instance.\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverStart (\r
-  IN EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN EFI_HANDLE                     Controller,\r
-  IN EFI_DEVICE_PATH_PROTOCOL       *RemainingDevicePath\r
-  )\r
-{\r
-  EFI_STATUS                                Status;\r
-  EFI_STATUS                                Status1;\r
-  EFI_ISA_IO_PROTOCOL                       *IsaIo;\r
-  KEYBOARD_CONSOLE_IN_DEV                   *ConsoleIn;\r
-  UINT8                                     Data;\r
-  EFI_STATUS_CODE_VALUE                     StatusCode;\r
-  EFI_DEVICE_PATH_PROTOCOL                  *ParentDevicePath;\r
-\r
-  StatusCode = 0;\r
-\r
-  Status = gBS->OpenProtocol (\r
-                  Controller,\r
-                  &gEfiDevicePathProtocolGuid,\r
-                  (VOID **) &ParentDevicePath,\r
-                  This->DriverBindingHandle,\r
-                  Controller,\r
-                  EFI_OPEN_PROTOCOL_BY_DRIVER\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-  //\r
-  // Report that the keyboard is being enabled\r
-  //\r
-  REPORT_STATUS_CODE_WITH_DEVICE_PATH (\r
-    EFI_PROGRESS_CODE,\r
-    EFI_PERIPHERAL_KEYBOARD | EFI_P_PC_ENABLE,\r
-    ParentDevicePath\r
-    );\r
-\r
-  //\r
-  // Get the ISA I/O Protocol on Controller's handle\r
-  //\r
-  Status = gBS->OpenProtocol (\r
-                  Controller,\r
-                  &gEfiIsaIoProtocolGuid,\r
-                  (VOID **) &IsaIo,\r
-                  This->DriverBindingHandle,\r
-                  Controller,\r
-                  EFI_OPEN_PROTOCOL_BY_DRIVER\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    gBS->CloseProtocol (\r
-           Controller,\r
-           &gEfiDevicePathProtocolGuid,\r
-           This->DriverBindingHandle,\r
-           Controller\r
-           );\r
-    return EFI_INVALID_PARAMETER;\r
-  }\r
-  //\r
-  // Allocate private data\r
-  //\r
-  ConsoleIn = AllocateZeroPool (sizeof (KEYBOARD_CONSOLE_IN_DEV));\r
-  if (ConsoleIn == NULL) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-  //\r
-  // Setup the device instance\r
-  //\r
-  ConsoleIn->Signature              = KEYBOARD_CONSOLE_IN_DEV_SIGNATURE;\r
-  ConsoleIn->Handle                 = Controller;\r
-  (ConsoleIn->ConIn).Reset          = KeyboardEfiReset;\r
-  (ConsoleIn->ConIn).ReadKeyStroke  = KeyboardReadKeyStroke;\r
-  ConsoleIn->DataRegisterAddress    = KEYBOARD_8042_DATA_REGISTER;\r
-  ConsoleIn->StatusRegisterAddress  = KEYBOARD_8042_STATUS_REGISTER;\r
-  ConsoleIn->CommandRegisterAddress = KEYBOARD_8042_COMMAND_REGISTER;\r
-  ConsoleIn->IsaIo                  = IsaIo;\r
-  ConsoleIn->DevicePath             = ParentDevicePath;\r
-\r
-  ConsoleIn->ConInEx.Reset               = KeyboardEfiResetEx;\r
-  ConsoleIn->ConInEx.ReadKeyStrokeEx     = KeyboardReadKeyStrokeEx;\r
-  ConsoleIn->ConInEx.SetState            = KeyboardSetState;\r
-  ConsoleIn->ConInEx.RegisterKeyNotify   = KeyboardRegisterKeyNotify;\r
-  ConsoleIn->ConInEx.UnregisterKeyNotify = KeyboardUnregisterKeyNotify;\r
-\r
-  InitializeListHead (&ConsoleIn->NotifyList);\r
-\r
-  //\r
-  // Fix for random hangs in System waiting for the Key if no KBC is present in BIOS.\r
-  // When KBC decode (IO port 0x60/0x64 decode) is not enabled,\r
-  // KeyboardRead will read back as 0xFF and return status is EFI_SUCCESS.\r
-  // So instead we read status register to detect after read if KBC decode is enabled.\r
-  //\r
-\r
-  //\r
-  // Return code is ignored on purpose.\r
-  //\r
-  if (!PcdGetBool (PcdFastPS2Detection)) {\r
-    KeyboardRead (ConsoleIn, &Data);\r
-    if ((KeyReadStatusRegister (ConsoleIn) & (KBC_PARE | KBC_TIM)) == (KBC_PARE | KBC_TIM)) {\r
-      //\r
-      // If nobody decodes KBC I/O port, it will read back as 0xFF.\r
-      // Check the Time-Out and Parity bit to see if it has an active KBC in system\r
-      //\r
-      Status      = EFI_DEVICE_ERROR;\r
-      StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_NOT_DETECTED;\r
-      goto ErrorExit;\r
-    }\r
-  }\r
-\r
-  //\r
-  // Setup the WaitForKey event\r
-  //\r
-  Status = gBS->CreateEvent (\r
-                  EVT_NOTIFY_WAIT,\r
-                  TPL_NOTIFY,\r
-                  KeyboardWaitForKey,\r
-                  ConsoleIn,\r
-                  &((ConsoleIn->ConIn).WaitForKey)\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-  //\r
-  // Setup the WaitForKeyEx event\r
-  //\r
-  Status = gBS->CreateEvent (\r
-                  EVT_NOTIFY_WAIT,\r
-                  TPL_NOTIFY,\r
-                  KeyboardWaitForKeyEx,\r
-                  ConsoleIn,\r
-                  &(ConsoleIn->ConInEx.WaitForKeyEx)\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  // Setup a periodic timer, used for reading keystrokes at a fixed interval\r
-  //\r
-  Status = gBS->CreateEvent (\r
-                  EVT_TIMER | EVT_NOTIFY_SIGNAL,\r
-                  TPL_NOTIFY,\r
-                  KeyboardTimerHandler,\r
-                  ConsoleIn,\r
-                  &ConsoleIn->TimerEvent\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  Status = gBS->SetTimer (\r
-                  ConsoleIn->TimerEvent,\r
-                  TimerPeriodic,\r
-                  KEYBOARD_TIMER_INTERVAL\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  Status = gBS->CreateEvent (\r
-                  EVT_NOTIFY_SIGNAL,\r
-                  TPL_CALLBACK,\r
-                  KeyNotifyProcessHandler,\r
-                  ConsoleIn,\r
-                  &ConsoleIn->KeyNotifyProcessEvent\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_OUT_OF_RESOURCES;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  REPORT_STATUS_CODE_WITH_DEVICE_PATH (\r
-    EFI_PROGRESS_CODE,\r
-    EFI_PERIPHERAL_KEYBOARD | EFI_P_PC_PRESENCE_DETECT,\r
-    ParentDevicePath\r
-    );\r
-\r
-  //\r
-  // Reset the keyboard device\r
-  //\r
-  Status = ConsoleIn->ConInEx.Reset (&ConsoleIn->ConInEx, FeaturePcdGet (PcdPs2KbdExtendedVerification));\r
-  if (EFI_ERROR (Status)) {\r
-    Status      = EFI_DEVICE_ERROR;\r
-    StatusCode  = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_NOT_DETECTED;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  REPORT_STATUS_CODE_WITH_DEVICE_PATH (\r
-    EFI_PROGRESS_CODE,\r
-    EFI_PERIPHERAL_KEYBOARD | EFI_P_PC_DETECTED,\r
-    ParentDevicePath\r
-    );\r
-\r
-  ConsoleIn->ControllerNameTable = NULL;\r
-  AddUnicodeString2 (\r
-    "eng",\r
-    gPs2KeyboardComponentName.SupportedLanguages,\r
-    &ConsoleIn->ControllerNameTable,\r
-    L"PS/2 Keyboard Device",\r
-    TRUE\r
-    );\r
-  AddUnicodeString2 (\r
-    "en",\r
-    gPs2KeyboardComponentName2.SupportedLanguages,\r
-    &ConsoleIn->ControllerNameTable,\r
-    L"PS/2 Keyboard Device",\r
-    FALSE\r
-    );\r
-\r
-\r
-  //\r
-  // Install protocol interfaces for the keyboard device.\r
-  //\r
-  Status = gBS->InstallMultipleProtocolInterfaces (\r
-                  &Controller,\r
-                  &gEfiSimpleTextInProtocolGuid,\r
-                  &ConsoleIn->ConIn,\r
-                  &gEfiSimpleTextInputExProtocolGuid,\r
-                  &ConsoleIn->ConInEx,\r
-                  NULL\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    StatusCode = EFI_PERIPHERAL_KEYBOARD | EFI_P_EC_CONTROLLER_ERROR;\r
-    goto ErrorExit;\r
-  }\r
-\r
-  return Status;\r
-\r
-ErrorExit:\r
-  //\r
-  // Report error code\r
-  //\r
-  if (StatusCode != 0) {\r
-    REPORT_STATUS_CODE_WITH_DEVICE_PATH (\r
-      EFI_ERROR_CODE | EFI_ERROR_MINOR,\r
-      StatusCode,\r
-      ParentDevicePath\r
-      );\r
-  }\r
-\r
-  if ((ConsoleIn != NULL) && (ConsoleIn->ConIn.WaitForKey != NULL)) {\r
-    gBS->CloseEvent (ConsoleIn->ConIn.WaitForKey);\r
-  }\r
-\r
-  if ((ConsoleIn != NULL) && (ConsoleIn->TimerEvent != NULL)) {\r
-    gBS->CloseEvent (ConsoleIn->TimerEvent);\r
-  }\r
-  if ((ConsoleIn != NULL) && (ConsoleIn->ConInEx.WaitForKeyEx != NULL)) {\r
-    gBS->CloseEvent (ConsoleIn->ConInEx.WaitForKeyEx);\r
-  }\r
-  if ((ConsoleIn != NULL) && (ConsoleIn->KeyNotifyProcessEvent != NULL)) {\r
-    gBS->CloseEvent (ConsoleIn->KeyNotifyProcessEvent);\r
-  }\r
-  KbdFreeNotifyList (&ConsoleIn->NotifyList);\r
-  if ((ConsoleIn != NULL) && (ConsoleIn->ControllerNameTable != NULL)) {\r
-    FreeUnicodeStringTable (ConsoleIn->ControllerNameTable);\r
-  }\r
-  //\r
-  // Since there will be no timer handler for keyboard input any more,\r
-  // exhaust input data just in case there is still keyboard data left\r
-  //\r
-  if (ConsoleIn != NULL) {\r
-    Status1 = EFI_SUCCESS;\r
-    while (!EFI_ERROR (Status1) && (Status != EFI_DEVICE_ERROR)) {\r
-      Status1 = KeyboardRead (ConsoleIn, &Data);;\r
-    }\r
-  }\r
-\r
-  if (ConsoleIn != NULL) {\r
-    gBS->FreePool (ConsoleIn);\r
-  }\r
-\r
-  gBS->CloseProtocol (\r
-         Controller,\r
-         &gEfiDevicePathProtocolGuid,\r
-         This->DriverBindingHandle,\r
-         Controller\r
-         );\r
-\r
-  gBS->CloseProtocol (\r
-         Controller,\r
-         &gEfiIsaIoProtocolGuid,\r
-         This->DriverBindingHandle,\r
-         Controller\r
-         );\r
-\r
-  return Status;\r
-}\r
-\r
-/**\r
-  Stop this driver on ControllerHandle. Support stopping any child handles\r
-  created by this driver.\r
-\r
-  @param  This              Protocol instance pointer.\r
-  @param  ControllerHandle  Handle of device to stop driver on\r
-  @param  NumberOfChildren  Number of Handles in ChildHandleBuffer. If number of\r
-                            children is zero stop the entire bus driver.\r
-  @param  ChildHandleBuffer List of Child Handles to Stop.\r
-\r
-  @retval EFI_SUCCESS       This driver is removed ControllerHandle\r
-  @retval other             This driver was not removed from this device\r
-\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-KbdControllerDriverStop (\r
-  IN  EFI_DRIVER_BINDING_PROTOCOL    *This,\r
-  IN  EFI_HANDLE                     Controller,\r
-  IN  UINTN                          NumberOfChildren,\r
-  IN  EFI_HANDLE                     *ChildHandleBuffer\r
-  )\r
-{\r
-  EFI_STATUS                     Status;\r
-  EFI_SIMPLE_TEXT_INPUT_PROTOCOL *ConIn;\r
-  KEYBOARD_CONSOLE_IN_DEV        *ConsoleIn;\r
-  UINT8                          Data;\r
-\r
-  //\r
-  // Disable Keyboard\r
-  //\r
-  Status = gBS->OpenProtocol (\r
-                  Controller,\r
-                  &gEfiSimpleTextInProtocolGuid,\r
-                  (VOID **) &ConIn,\r
-                  This->DriverBindingHandle,\r
-                  Controller,\r
-                  EFI_OPEN_PROTOCOL_GET_PROTOCOL\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-  Status = gBS->OpenProtocol (\r
-                  Controller,\r
-                  &gEfiSimpleTextInputExProtocolGuid,\r
-                  NULL,\r
-                  This->DriverBindingHandle,\r
-                  Controller,\r
-                  EFI_OPEN_PROTOCOL_TEST_PROTOCOL\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-\r
-  ConsoleIn = KEYBOARD_CONSOLE_IN_DEV_FROM_THIS (ConIn);\r
-\r
-  //\r
-  // Report that the keyboard is being disabled\r
-  //\r
-  REPORT_STATUS_CODE_WITH_DEVICE_PATH (\r
-    EFI_PROGRESS_CODE,\r
-    EFI_PERIPHERAL_KEYBOARD | EFI_P_PC_DISABLE,\r
-    ConsoleIn->DevicePath\r
-    );\r
-\r
-  if (ConsoleIn->TimerEvent != NULL) {\r
-    gBS->CloseEvent (ConsoleIn->TimerEvent);\r
-    ConsoleIn->TimerEvent = NULL;\r
-  }\r
-\r
-  //\r
-  // Since there will be no timer handler for keyboard input any more,\r
-  // exhaust input data just in case there is still keyboard data left\r
-  //\r
-  Status = EFI_SUCCESS;\r
-  while (!EFI_ERROR (Status)) {\r
-    Status = KeyboardRead (ConsoleIn, &Data);;\r
-  }\r
-  //\r
-  // Uninstall the SimpleTextIn and SimpleTextInEx protocols\r
-  //\r
-  Status = gBS->UninstallMultipleProtocolInterfaces (\r
-                  Controller,\r
-                  &gEfiSimpleTextInProtocolGuid,\r
-                  &ConsoleIn->ConIn,\r
-                  &gEfiSimpleTextInputExProtocolGuid,\r
-                  &ConsoleIn->ConInEx,\r
-                  NULL\r
-                  );\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-\r
-  gBS->CloseProtocol (\r
-         Controller,\r
-         &gEfiDevicePathProtocolGuid,\r
-         This->DriverBindingHandle,\r
-         Controller\r
-         );\r
-\r
-  gBS->CloseProtocol (\r
-         Controller,\r
-         &gEfiIsaIoProtocolGuid,\r
-         This->DriverBindingHandle,\r
-         Controller\r
-         );\r
-\r
-  //\r
-  // Free other resources\r
-  //\r
-  if ((ConsoleIn->ConIn).WaitForKey != NULL) {\r
-    gBS->CloseEvent ((ConsoleIn->ConIn).WaitForKey);\r
-    (ConsoleIn->ConIn).WaitForKey = NULL;\r
-  }\r
-  if (ConsoleIn->ConInEx.WaitForKeyEx != NULL) {\r
-    gBS->CloseEvent (ConsoleIn->ConInEx.WaitForKeyEx);\r
-    ConsoleIn->ConInEx.WaitForKeyEx = NULL;\r
-  }\r
-  if (ConsoleIn->KeyNotifyProcessEvent != NULL) {\r
-    gBS->CloseEvent (ConsoleIn->KeyNotifyProcessEvent);\r
-    ConsoleIn->KeyNotifyProcessEvent = NULL;\r
-  }\r
-  KbdFreeNotifyList (&ConsoleIn->NotifyList);\r
-  FreeUnicodeStringTable (ConsoleIn->ControllerNameTable);\r
-  gBS->FreePool (ConsoleIn);\r
-\r
-  return EFI_SUCCESS;\r
-}\r
-\r
-/**\r
-  Free the waiting key notify list.\r
-\r
-  @param ListHead  Pointer to list head\r
-\r
-  @retval EFI_INVALID_PARAMETER  ListHead is NULL\r
-  @retval EFI_SUCCESS            Sucess to free NotifyList\r
-**/\r
-EFI_STATUS\r
-KbdFreeNotifyList (\r
-  IN OUT LIST_ENTRY           *ListHead\r
-  )\r
-{\r
-  KEYBOARD_CONSOLE_IN_EX_NOTIFY *NotifyNode;\r
-\r
-  if (ListHead == NULL) {\r
-    return EFI_INVALID_PARAMETER;\r
-  }\r
-  while (!IsListEmpty (ListHead)) {\r
-    NotifyNode = CR (\r
-                   ListHead->ForwardLink,\r
-                   KEYBOARD_CONSOLE_IN_EX_NOTIFY,\r
-                   NotifyEntry,\r
-                   KEYBOARD_CONSOLE_IN_EX_NOTIFY_SIGNATURE\r
-                   );\r
-    RemoveEntryList (ListHead->ForwardLink);\r
-    gBS->FreePool (NotifyNode);\r
-  }\r
-\r
-  return EFI_SUCCESS;\r
-}\r
-\r
-/**\r
-  The module Entry Point for module Ps2Keyboard.\r
-\r
-  @param[in] ImageHandle    The firmware allocated handle for the EFI image.\r
-  @param[in] SystemTable    A pointer to the EFI System Table.\r
-\r
-  @retval EFI_SUCCESS       The entry point is executed successfully.\r
-  @retval other             Some error occurs when executing this entry point.\r
-\r
-**/\r
-EFI_STATUS\r
-EFIAPI\r
-InitializePs2Keyboard(\r
-  IN EFI_HANDLE           ImageHandle,\r
-  IN EFI_SYSTEM_TABLE     *SystemTable\r
-  )\r
-{\r
-  EFI_STATUS              Status;\r
-\r
-  //\r
-  // Install driver model protocol(s).\r
-  //\r
-  Status = EfiLibInstallDriverBindingComponentName2 (\r
-             ImageHandle,\r
-             SystemTable,\r
-             &gKeyboardControllerDriver,\r
-             ImageHandle,\r
-             &gPs2KeyboardComponentName,\r
-             &gPs2KeyboardComponentName2\r
-             );\r
-  ASSERT_EFI_ERROR (Status);\r
-\r
-\r
-  return Status;\r
-}\r
-\r