2007-06-29 05:02:40 +02:00
|
|
|
/*++
|
|
|
|
|
|
|
|
Copyright (c) 2006, Intel Corporation
|
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
Module Name:
|
|
|
|
|
|
|
|
CpuDriver.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
NT Emulation Architectural Protocol Driver as defined in Tiano.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
|
|
|
|
#ifndef _CPU_ARCHITECTURAL_PROTOCOL_DRIVER_H_
|
|
|
|
#define _CPU_ARCHITECTURAL_PROTOCOL_DRIVER_H_
|
|
|
|
|
|
|
|
|
2007-07-10 19:16:14 +02:00
|
|
|
#include <FrameworkDxe.h>
|
|
|
|
#include <Protocol/Cpu.h>
|
|
|
|
#include <Protocol/DataHub.h>
|
|
|
|
#include <Protocol/HiiFramework.h>
|
|
|
|
#include <Guid/DataHubRecords.h>
|
2007-08-16 05:15:36 +02:00
|
|
|
#include <Guid/DataHubProducer.h>
|
2007-07-10 19:16:14 +02:00
|
|
|
#include <Protocol/CpuIo.h>
|
|
|
|
#include <Protocol/WinNtIo.h>
|
2007-07-26 23:33:37 +02:00
|
|
|
#include <Library/BaseLib.h>
|
2007-07-10 19:16:14 +02:00
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/HiiLibFramework.h>
|
|
|
|
#include <Library/UefiDriverEntryPoint.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
2007-07-26 23:33:37 +02:00
|
|
|
#include <Library/PcdLib.h>
|
2007-06-29 05:02:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
extern UINT8 CpuStrings[];
|
|
|
|
|
|
|
|
//
|
|
|
|
// Internal Data Structures
|
|
|
|
//
|
|
|
|
#define CPU_ARCH_PROT_PRIVATE_SIGNATURE EFI_SIGNATURE_32 ('c', 'a', 'p', 'd')
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINTN Signature;
|
|
|
|
EFI_HANDLE Handle;
|
|
|
|
|
|
|
|
EFI_CPU_ARCH_PROTOCOL Cpu;
|
|
|
|
EFI_CPU_IO_PROTOCOL CpuIo;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Local Data for CPU interface goes here
|
|
|
|
//
|
|
|
|
CRITICAL_SECTION NtCriticalSection;
|
|
|
|
BOOLEAN InterruptState;
|
|
|
|
|
|
|
|
} CPU_ARCH_PROTOCOL_PRIVATE;
|
|
|
|
|
|
|
|
#define CPU_ARCH_PROTOCOL_PRIVATE_DATA_FROM_THIS(a) \
|
|
|
|
CR (a, \
|
|
|
|
CPU_ARCH_PROTOCOL_PRIVATE, \
|
|
|
|
Cpu, \
|
|
|
|
CPU_ARCH_PROT_PRIVATE_SIGNATURE \
|
|
|
|
)
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
CpuMemoryServiceRead (
|
|
|
|
IN EFI_CPU_IO_PROTOCOL *This,
|
|
|
|
IN EFI_CPU_IO_PROTOCOL_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
CpuMemoryServiceWrite (
|
|
|
|
IN EFI_CPU_IO_PROTOCOL *This,
|
|
|
|
IN EFI_CPU_IO_PROTOCOL_WIDTH Width,
|
|
|
|
IN UINT64 Address,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *Buffer
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
CpuIoServiceRead (
|
|
|
|
IN EFI_CPU_IO_PROTOCOL *This,
|
|
|
|
IN EFI_CPU_IO_PROTOCOL_WIDTH Width,
|
|
|
|
IN UINT64 UserAddress,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *UserBuffer
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
CpuIoServiceWrite (
|
|
|
|
IN EFI_CPU_IO_PROTOCOL *This,
|
|
|
|
IN EFI_CPU_IO_PROTOCOL_WIDTH Width,
|
|
|
|
IN UINT64 UserAddress,
|
|
|
|
IN UINTN Count,
|
|
|
|
IN OUT VOID *UserBuffer
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2007-07-26 23:33:37 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InitializeCpu (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtFlushCpuDataCache (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS Start,
|
|
|
|
IN UINT64 Length,
|
|
|
|
IN EFI_CPU_FLUSH_TYPE FlushType
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtEnableInterrupt (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtDisableInterrupt (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGetInterruptState (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
OUT BOOLEAN *State
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtInit (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
IN EFI_CPU_INIT_TYPE InitType
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtRegisterInterruptHandler (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
IN EFI_EXCEPTION_TYPE InterruptType,
|
|
|
|
IN EFI_CPU_INTERRUPT_HANDLER InterruptHandler
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtGetTimerValue (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
IN UINT32 TimerIndex,
|
|
|
|
OUT UINT64 *TimerValue,
|
|
|
|
OUT UINT64 *TimerPeriod OPTIONAL
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
WinNtSetMemoryAttributes (
|
|
|
|
IN EFI_CPU_ARCH_PROTOCOL *This,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS BaseAddress,
|
|
|
|
IN UINT64 Length,
|
|
|
|
IN UINT64 Attributes
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2007-06-29 05:02:40 +02:00
|
|
|
#endif
|