blob: 384b94ba5410ac9cda0941deb7d5aeadeb5ab2b6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
/** @file
This file is the library for SA DXE Policy initialization.
Copyright (c) 2017, Intel Corporation. All rights reserved.<BR>
This program and the accompanying materials are licensed and made available under
the terms and conditions of the BSD License that 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.
**/
#include "SaPolicyInitDxe.h"
#define SA_VTD_RMRR_USB_LENGTH 0x20000
GLOBAL_REMOVE_IF_UNREFERENCED EFI_PHYSICAL_ADDRESS mAddress;
GLOBAL_REMOVE_IF_UNREFERENCED UINTN mSize;
/**
Update RMRR Base and Limit Address for USB.
**/
VOID
UpdateRmrrUsbAddress (
IN OUT SA_POLICY_PROTOCOL *SaPolicy
)
{
EFI_STATUS Status;
MISC_DXE_CONFIG *MiscDxeConfig;
Status = GetConfigBlock ((VOID *)SaPolicy, &gMiscDxeConfigGuid, (VOID *)&MiscDxeConfig);
ASSERT_EFI_ERROR (Status);
if (1) {
mSize = EFI_SIZE_TO_PAGES(SA_VTD_RMRR_USB_LENGTH);
mAddress = SIZE_4GB;
Status = (gBS->AllocatePages) (
AllocateMaxAddress,
EfiReservedMemoryType,
mSize,
&mAddress
);
ASSERT_EFI_ERROR (Status);
MiscDxeConfig->RmrrUsbBaseAddress[0] = mAddress;
MiscDxeConfig->RmrrUsbBaseAddress[1] = mAddress + SA_VTD_RMRR_USB_LENGTH - 1;
}
}
/**
Get data for platform policy from setup options.
@param[in] SaPolicy The pointer to get SA Policy protocol instance
@retval EFI_SUCCESS Operation success.
**/
EFI_STATUS
EFIAPI
UpdateDxeSaPolicy (
IN OUT SA_POLICY_PROTOCOL *SaPolicy
)
{
UpdateRmrrUsbAddress (SaPolicy);
return EFI_SUCCESS;
}
|