2007-06-27 08:48:58 +02:00
|
|
|
/** @file
|
|
|
|
|
2012-07-30 05:50:42 +02:00
|
|
|
Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:18 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
Module Name:
|
|
|
|
|
|
|
|
WinNtGop.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
Private data for the Gop driver that is bound to the WinNt Thunk protocol
|
|
|
|
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _WIN_NT_GOP_H_
|
|
|
|
#define _WIN_NT_GOP_H_
|
|
|
|
|
|
|
|
|
2007-10-19 04:36:33 +02:00
|
|
|
#include <Uefi.h>
|
|
|
|
#include <WinNtDxe.h>
|
|
|
|
|
|
|
|
#include <Guid/EventGroup.h>
|
|
|
|
#include <Protocol/WinNtIo.h>
|
|
|
|
#include <Protocol/ComponentName.h>
|
|
|
|
#include <Protocol/SimpleTextIn.h>
|
|
|
|
#include <Protocol/SimpleTextInEx.h>
|
|
|
|
#include <Protocol/DriverBinding.h>
|
|
|
|
#include <Protocol/GraphicsOutput.h>
|
|
|
|
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/UefiDriverEntryPoint.h>
|
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
//
|
2007-10-19 04:36:33 +02:00
|
|
|
// WM_SYSKEYDOWN/WM_SYSKEYUP Notification
|
|
|
|
// lParam
|
2011-09-30 09:30:20 +02:00
|
|
|
// bit 24: Specifies whether the key is an extended key,
|
|
|
|
// such as the right-hand ALT and CTRL keys that appear on
|
|
|
|
// an enhanced 101- or 102-key keyboard.
|
2007-10-19 04:36:33 +02:00
|
|
|
// The value is 1 if it is an extended key; otherwise, it is 0.
|
2011-09-30 09:30:20 +02:00
|
|
|
// bit 29:Specifies the context code.
|
|
|
|
// The value is 1 if the ALT key is down while the key is pressed/released;
|
|
|
|
// it is 0 if the WM_SYSKEYDOWN message is posted to the active window
|
2007-10-19 04:36:33 +02:00
|
|
|
// because no window has the keyboard focus.
|
|
|
|
#define GOP_EXTENDED_KEY (0x1 << 24)
|
|
|
|
#define GOP_ALT_KEY_PRESSED (0x1 << 29)
|
|
|
|
|
2011-04-19 08:46:55 +02:00
|
|
|
#define KEYBOARD_TIMER_INTERVAL 200000 // 0.02s
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
#define MAX_Q 256
|
|
|
|
|
|
|
|
typedef struct {
|
2011-04-19 08:46:55 +02:00
|
|
|
UINTN Front;
|
|
|
|
UINTN Rear;
|
|
|
|
EFI_KEY_DATA Q[MAX_Q];
|
|
|
|
CRITICAL_SECTION Cs;
|
2007-06-27 08:48:58 +02:00
|
|
|
} GOP_QUEUE_FIXED;
|
|
|
|
|
|
|
|
#define WIN_NT_GOP_CLASS_NAME L"WinNtGopWindow"
|
|
|
|
|
2008-12-16 16:17:02 +01:00
|
|
|
#define GOP_PRIVATE_DATA_SIGNATURE SIGNATURE_32 ('S', 'g', 'o', 'N')
|
2007-06-27 08:48:58 +02:00
|
|
|
|
2008-12-16 16:17:02 +01:00
|
|
|
#define WIN_NT_GOP_SIMPLE_TEXTIN_EX_NOTIFY_SIGNATURE SIGNATURE_32 ('W', 'g', 'S', 'n')
|
2007-10-19 04:36:33 +02:00
|
|
|
|
|
|
|
typedef struct _WIN_NT_GOP_SIMPLE_TEXTIN_EX_NOTIFY {
|
|
|
|
UINTN Signature;
|
|
|
|
EFI_KEY_DATA KeyData;
|
|
|
|
EFI_KEY_NOTIFY_FUNCTION KeyNotificationFn;
|
|
|
|
LIST_ENTRY NotifyEntry;
|
|
|
|
} WIN_NT_GOP_SIMPLE_TEXTIN_EX_NOTIFY;
|
|
|
|
|
2007-06-27 08:48:58 +02:00
|
|
|
#define GRAPHICS_OUTPUT_INVALIDE_MODE_NUMBER 0xffff
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT32 HorizontalResolution;
|
|
|
|
UINT32 VerticalResolution;
|
|
|
|
UINT32 ColorDepth;
|
|
|
|
UINT32 RefreshRate;
|
|
|
|
} GOP_MODE_DATA;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT64 Signature;
|
|
|
|
|
|
|
|
EFI_HANDLE Handle;
|
|
|
|
EFI_GRAPHICS_OUTPUT_PROTOCOL GraphicsOutput;
|
|
|
|
EFI_SIMPLE_TEXT_INPUT_PROTOCOL SimpleTextIn;
|
|
|
|
|
|
|
|
EFI_WIN_NT_THUNK_PROTOCOL *WinNtThunk;
|
|
|
|
|
|
|
|
EFI_UNICODE_STRING_TABLE *ControllerNameTable;
|
|
|
|
|
|
|
|
//
|
|
|
|
// GOP Private Data for QueryMode ()
|
|
|
|
//
|
|
|
|
GOP_MODE_DATA *ModeData;
|
|
|
|
|
|
|
|
//
|
|
|
|
// GOP Private Data knowing when to start hardware
|
|
|
|
//
|
|
|
|
BOOLEAN HardwareNeedsStarting;
|
|
|
|
|
|
|
|
CHAR16 *WindowName;
|
|
|
|
CHAR16 Buffer[160];
|
|
|
|
|
|
|
|
HANDLE ThreadInited; // Semaphore
|
|
|
|
HANDLE ThreadHandle; // Thread
|
|
|
|
DWORD ThreadId;
|
|
|
|
|
|
|
|
HWND WindowHandle;
|
|
|
|
WNDCLASSEX WindowsClass;
|
|
|
|
|
|
|
|
//
|
|
|
|
// This screen is used to redraw the scree when windows events happen. It's
|
|
|
|
// updated in the main thread and displayed in the windows thread.
|
|
|
|
//
|
|
|
|
BITMAPV4HEADER *VirtualScreenInfo;
|
|
|
|
RGBQUAD *VirtualScreen;
|
|
|
|
|
|
|
|
EFI_GRAPHICS_OUTPUT_BLT_PIXEL *FillLine;
|
|
|
|
|
|
|
|
//
|
2011-09-30 09:30:20 +02:00
|
|
|
// Keyboard Queue used by Simple Text In.
|
2011-04-19 08:46:55 +02:00
|
|
|
// QueueForRead: WinProc thread adds, and main thread removes.
|
|
|
|
// QueueForNotify: WinProc thread adds, and timer thread removes.
|
2007-06-27 08:48:58 +02:00
|
|
|
//
|
2011-04-19 08:46:55 +02:00
|
|
|
GOP_QUEUE_FIXED QueueForRead;
|
|
|
|
GOP_QUEUE_FIXED QueueForNotify;
|
2007-06-27 08:48:58 +02:00
|
|
|
|
2007-10-19 04:36:33 +02:00
|
|
|
EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL SimpleTextInEx;
|
|
|
|
EFI_KEY_STATE KeyState;
|
|
|
|
LIST_ENTRY NotifyList;
|
|
|
|
BOOLEAN LeftShift;
|
2011-09-30 09:30:20 +02:00
|
|
|
BOOLEAN RightShift;
|
2007-10-19 04:36:33 +02:00
|
|
|
BOOLEAN LeftAlt;
|
|
|
|
BOOLEAN RightAlt;
|
|
|
|
BOOLEAN LeftCtrl;
|
|
|
|
BOOLEAN RightCtrl;
|
|
|
|
BOOLEAN LeftLogo;
|
|
|
|
BOOLEAN RightLogo;
|
|
|
|
BOOLEAN Menu;
|
2011-09-30 09:30:20 +02:00
|
|
|
BOOLEAN SysReq;
|
2007-10-19 04:36:33 +02:00
|
|
|
BOOLEAN NumLock;
|
|
|
|
BOOLEAN ScrollLock;
|
2011-04-19 08:46:55 +02:00
|
|
|
BOOLEAN CapsLock;
|
2011-09-30 09:30:20 +02:00
|
|
|
BOOLEAN IsPartialKeySupport;
|
2011-04-19 08:46:55 +02:00
|
|
|
EFI_EVENT TimerEvent;
|
2007-06-27 08:48:58 +02:00
|
|
|
} GOP_PRIVATE_DATA;
|
|
|
|
|
|
|
|
#define GOP_PRIVATE_DATA_FROM_THIS(a) \
|
|
|
|
CR(a, GOP_PRIVATE_DATA, GraphicsOutput, GOP_PRIVATE_DATA_SIGNATURE)
|
|
|
|
|
|
|
|
#define GOP_PRIVATE_DATA_FROM_TEXT_IN_THIS(a) \
|
|
|
|
CR(a, GOP_PRIVATE_DATA, SimpleTextIn, GOP_PRIVATE_DATA_SIGNATURE)
|
|
|
|
|
2007-10-19 04:36:33 +02:00
|
|
|
#define GOP_PRIVATE_DATA_FROM_TEXT_IN_EX_THIS(a) \
|
|
|
|
CR(a, GOP_PRIVATE_DATA, SimpleTextInEx, GOP_PRIVATE_DATA_SIGNATURE)
|
|
|
|
|
2007-06-27 08:48:58 +02:00
|
|
|
//
|
|
|
|
// Global Protocol Variables
|
|
|
|
//
|
2007-09-29 13:22:46 +02:00
|
|
|
extern EFI_DRIVER_BINDING_PROTOCOL gWinNtGopDriverBinding;
|
|
|
|
extern EFI_COMPONENT_NAME_PROTOCOL gWinNtGopComponentName;
|
|
|
|
extern EFI_COMPONENT_NAME2_PROTOCOL gWinNtGopComponentName2;
|
2007-06-27 08:48:58 +02:00
|
|
|
|
2007-10-19 04:36:33 +02:00
|
|
|
|
2007-06-27 08:48:58 +02:00
|
|
|
//
|
|
|
|
// Gop Hardware abstraction internal worker functions
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param WinNtIo TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
WinNtGopSupported (
|
|
|
|
IN EFI_WIN_NT_IO_PROTOCOL *WinNtIo
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param Private TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
WinNtGopConstructor (
|
|
|
|
IN GOP_PRIVATE_DATA *Private
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param Private TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
WinNtGopDestructor (
|
|
|
|
IN GOP_PRIVATE_DATA *Private
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
//
|
2007-11-22 07:00:39 +01:00
|
|
|
// UEFI 2.0 driver model prototypes for Win NT GOP
|
2007-06-27 08:48:58 +02:00
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param ImageHandle TODO: add argument description
|
|
|
|
@param SystemTable TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGopInitialize (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param This TODO: add argument description
|
|
|
|
@param Handle TODO: add argument description
|
|
|
|
@param RemainingDevicePath TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGopDriverBindingSupported (
|
|
|
|
IN EFI_DRIVER_BINDING_PROTOCOL *This,
|
|
|
|
IN EFI_HANDLE Handle,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param This TODO: add argument description
|
|
|
|
@param Handle TODO: add argument description
|
|
|
|
@param RemainingDevicePath TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGopDriverBindingStart (
|
|
|
|
IN EFI_DRIVER_BINDING_PROTOCOL *This,
|
|
|
|
IN EFI_HANDLE Handle,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param This TODO: add argument description
|
|
|
|
@param Handle TODO: add argument description
|
|
|
|
@param NumberOfChildren TODO: add argument description
|
|
|
|
@param ChildHandleBuffer TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGopDriverBindingStop (
|
|
|
|
IN EFI_DRIVER_BINDING_PROTOCOL *This,
|
|
|
|
IN EFI_HANDLE Handle,
|
|
|
|
IN UINTN NumberOfChildren,
|
|
|
|
IN EFI_HANDLE *ChildHandleBuffer
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param Private TODO: add argument description
|
|
|
|
@param Key TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
2011-04-19 08:46:55 +02:00
|
|
|
GopPrivateAddKey (
|
2007-06-27 08:48:58 +02:00
|
|
|
IN GOP_PRIVATE_DATA *Private,
|
|
|
|
IN EFI_INPUT_KEY Key
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param Private TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
WinNtGopInitializeSimpleTextInForWindow (
|
|
|
|
IN GOP_PRIVATE_DATA *Private
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
TODO: Add function description
|
|
|
|
|
|
|
|
@param Private TODO: add argument description
|
|
|
|
|
|
|
|
@return TODO: add return values
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
WinNtGopDestroySimpleTextInForWindow (
|
|
|
|
IN GOP_PRIVATE_DATA *Private
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-27 08:48:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|