|
| 1 | +/** @file |
| 2 | + System Firmware descriptor. |
| 3 | + |
| 4 | + Copyright (c) 2016, Intel Corporation. All rights reserved.<BR> |
| 5 | + Copyright (c) 2017, Linaro, Ltd. All rights reserved.<BR> |
| 6 | + |
| 7 | + This program and the accompanying materials |
| 8 | + are licensed and made available under the terms and conditions of the BSD License |
| 9 | + which accompanies this distribution. The full text of the license may be found at |
| 10 | + http://opensource.org/licenses/bsd-license.php |
| 11 | + |
| 12 | + THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, |
| 13 | + WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. |
| 14 | + |
| 15 | +**/ |
| 16 | + |
| 17 | +#include <PiPei.h> |
| 18 | +#include <Protocol/FirmwareManagement.h> |
| 19 | +#include <Guid/EdkiiSystemFmpCapsule.h> |
| 20 | + |
| 21 | +#define PACKAGE_VERSION 0xFFFFFFFF |
| 22 | +#define PACKAGE_VERSION_STRING L"Unknown" |
| 23 | + |
| 24 | +#define CURRENT_FIRMWARE_VERSION 0x00000001 |
| 25 | +#define CURRENT_FIRMWARE_VERSION_STRING L"0x00000001" |
| 26 | +#define LOWEST_SUPPORTED_FIRMWARE_VERSION 0x00000001 |
| 27 | + |
| 28 | +#define IMAGE_ID SIGNATURE_64('O', 'V', 'R', 'D', 'R', 'I', 'V', 'E') |
| 29 | +#define IMAGE_ID_STRING L"AMD Seattle Overdrive UEFI" |
| 30 | + |
| 31 | +// PcdSystemFmpCapsuleImageTypeIdGuid |
| 32 | +#define IMAGE_TYPE_ID_GUID { 0xd34b3d29, 0x0085, 0x4ab3, { 0x8b, 0xe8, 0x84, 0x18, 0x8c, 0xc5, 0x04, 0x89 } } |
| 33 | + |
| 34 | +typedef struct { |
| 35 | + EDKII_SYSTEM_FIRMWARE_IMAGE_DESCRIPTOR Descriptor; |
| 36 | + // real string data |
| 37 | + CHAR16 ImageIdNameStr[sizeof(IMAGE_ID_STRING)/sizeof(CHAR16)]; |
| 38 | + CHAR16 VersionNameStr[sizeof(CURRENT_FIRMWARE_VERSION_STRING)/sizeof(CHAR16)]; |
| 39 | + CHAR16 PackageVersionNameStr[sizeof(PACKAGE_VERSION_STRING)/sizeof(CHAR16)]; |
| 40 | +} IMAGE_DESCRIPTOR; |
| 41 | + |
| 42 | +STATIC IMAGE_DESCRIPTOR mImageDescriptor = |
| 43 | +{ |
| 44 | + { |
| 45 | + EDKII_SYSTEM_FIRMWARE_IMAGE_DESCRIPTOR_SIGNATURE, |
| 46 | + sizeof(EDKII_SYSTEM_FIRMWARE_IMAGE_DESCRIPTOR), |
| 47 | + sizeof(IMAGE_DESCRIPTOR), |
| 48 | + PACKAGE_VERSION, // PackageVersion |
| 49 | + OFFSET_OF (IMAGE_DESCRIPTOR, PackageVersionNameStr), // PackageVersionName |
| 50 | + 1, // ImageIndex; |
| 51 | + {0x0}, // Reserved |
| 52 | + IMAGE_TYPE_ID_GUID, // ImageTypeId; |
| 53 | + IMAGE_ID, // ImageId; |
| 54 | + OFFSET_OF (IMAGE_DESCRIPTOR, ImageIdNameStr), // ImageIdName; |
| 55 | + CURRENT_FIRMWARE_VERSION, // Version; |
| 56 | + OFFSET_OF (IMAGE_DESCRIPTOR, VersionNameStr), // VersionName; |
| 57 | + {0x0}, // Reserved2 |
| 58 | + FixedPcdGet32(PcdFdSize), // Size; |
| 59 | + IMAGE_ATTRIBUTE_IMAGE_UPDATABLE | |
| 60 | + IMAGE_ATTRIBUTE_RESET_REQUIRED | |
| 61 | + IMAGE_ATTRIBUTE_AUTHENTICATION_REQUIRED | |
| 62 | + IMAGE_ATTRIBUTE_IN_USE, // AttributesSupported; |
| 63 | + IMAGE_ATTRIBUTE_IMAGE_UPDATABLE | |
| 64 | + IMAGE_ATTRIBUTE_RESET_REQUIRED | |
| 65 | + IMAGE_ATTRIBUTE_AUTHENTICATION_REQUIRED | |
| 66 | + IMAGE_ATTRIBUTE_IN_USE, // AttributesSetting; |
| 67 | + 0x0, // Compatibilities; |
| 68 | + LOWEST_SUPPORTED_FIRMWARE_VERSION, // LowestSupportedImageVersion; |
| 69 | + 0x00000000, // LastAttemptVersion; |
| 70 | + 0, // LastAttemptStatus; |
| 71 | + {0x0}, // Reserved3 |
| 72 | + 0, // HardwareInstance; |
| 73 | + }, |
| 74 | + // real string data |
| 75 | + IMAGE_ID_STRING, |
| 76 | + CURRENT_FIRMWARE_VERSION_STRING, |
| 77 | + PACKAGE_VERSION_STRING, |
| 78 | +}; |
| 79 | + |
| 80 | +VOID* CONST ReferenceAcpiTable = &mImageDescriptor; |
0 commit comments