]> git.proxmox.com Git - mirror_edk2.git/blame - Nt32Pkg/MiscSubClassPlatformDxe/MiscOemStringFunction.c
Nt32Pkg: Replace BSD License with BSD+Patent License
[mirror_edk2.git] / Nt32Pkg / MiscSubClassPlatformDxe / MiscOemStringFunction.c
CommitLineData
5e973c96 1/** @file\r
1fdd39d3 2 boot information boot time changes.\r
3 SMBIOS type 11.\r
5e973c96 4 \r
7ee85aa2 5Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>\r
9d2eedba 6SPDX-License-Identifier: BSD-2-Clause-Patent\r
1fdd39d3 7\r
5e973c96 8**/\r
1fdd39d3 9\r
10\r
11#include "MiscSubclassDriver.h"\r
12/**\r
13 This function makes boot time changes to the contents of the\r
14 MiscOemString (Type 11).\r
15\r
16 @param RecordData Pointer to copy of RecordData from the Data Table. \r
17\r
18 @retval EFI_SUCCESS All parameters were valid.\r
19 @retval EFI_UNSUPPORTED Unexpected RecordType value.\r
20 @retval EFI_INVALID_PARAMETER Invalid parameter was found.\r
21\r
22**/\r
23MISC_SMBIOS_TABLE_FUNCTION(OemString)\r
24{\r
25 UINTN OemStrLen;\r
26 CHAR8 *OptionalStrStart;\r
27 EFI_STATUS Status;\r
28 EFI_STRING OemStr;\r
29 STRING_REF TokenToGet;\r
30 EFI_SMBIOS_HANDLE SmbiosHandle;\r
31 SMBIOS_TABLE_TYPE11 *SmbiosRecord;\r
32\r
33 //\r
34 // First check for invalid parameters.\r
35 //\r
36 if (RecordData == NULL) {\r
37 return EFI_INVALID_PARAMETER;\r
38 }\r
39\r
40 TokenToGet = STRING_TOKEN (STR_MISC_OEM_STRING);\r
41 OemStr = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);\r
42 OemStrLen = StrLen(OemStr);\r
43 if (OemStrLen > SMBIOS_STRING_MAX_LENGTH) {\r
44 return EFI_UNSUPPORTED;\r
45 }\r
46\r
47 //\r
48 // Two zeros following the last string.\r
49 //\r
50 SmbiosRecord = AllocatePool(sizeof (SMBIOS_TABLE_TYPE11) + OemStrLen + 1 + 1);\r
51 ZeroMem(SmbiosRecord, sizeof (SMBIOS_TABLE_TYPE11) + OemStrLen + 1 + 1);\r
52\r
53 SmbiosRecord->Hdr.Type = EFI_SMBIOS_TYPE_OEM_STRINGS;\r
54 SmbiosRecord->Hdr.Length = sizeof (SMBIOS_TABLE_TYPE11);\r
55 //\r
56 // Make handle chosen by smbios protocol.add automatically.\r
57 // \r
58 SmbiosRecord->Hdr.Handle = 0; \r
59 SmbiosRecord->StringCount = 1;\r
60 OptionalStrStart = (CHAR8 *)(SmbiosRecord + 1);\r
61 UnicodeStrToAsciiStr(OemStr, OptionalStrStart);\r
62\r
63 //\r
64 // Now we have got the full smbios record, call smbios protocol to add this record.\r
65 //\r
7ee85aa2
SZ
66 Status = AddSmbiosRecord (Smbios, &SmbiosHandle, (EFI_SMBIOS_TABLE_HEADER *) SmbiosRecord);\r
67\r
1fdd39d3 68 FreePool(SmbiosRecord);\r
69 return Status;\r
70}\r