]> git.proxmox.com Git - mirror_edk2.git/blob - Nt32Pkg/MiscSubClassPlatformDxe/MiscChassisManufacturerFunction.c
Nt32Pkg: Replace BSD License with BSD+Patent License
[mirror_edk2.git] / Nt32Pkg / MiscSubClassPlatformDxe / MiscChassisManufacturerFunction.c
1 /** @file
2 Chassis manufacturer information boot time changes.
3 SMBIOS type 3.
4
5 Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>
6 (C) Copyright 2017 Hewlett Packard Enterprise Development LP<BR>
7 SPDX-License-Identifier: BSD-2-Clause-Patent
8
9 **/
10
11 #include "MiscSubclassDriver.h"
12
13 /**
14 This function makes boot time changes to the contents of the
15 MiscChassisManufacturer (Type 3).
16
17 @param RecordData Pointer to copy of RecordData from the Data Table.
18
19 @retval EFI_SUCCESS All parameters were valid.
20 @retval EFI_UNSUPPORTED Unexpected RecordType value.
21 @retval EFI_INVALID_PARAMETER Invalid parameter was found.
22
23 **/
24 MISC_SMBIOS_TABLE_FUNCTION(MiscChassisManufacturer)
25 {
26 CHAR8 *OptionalStrStart;
27 UINTN ManuStrLen;
28 UINTN VerStrLen;
29 UINTN AssetTagStrLen;
30 UINTN SerialNumStrLen;
31 UINTN SkuNumberStrLen;
32 EFI_STATUS Status;
33 EFI_STRING Manufacturer;
34 EFI_STRING Version;
35 EFI_STRING SerialNumber;
36 EFI_STRING AssetTag;
37 EFI_STRING SkuNumber;
38 STRING_REF TokenToGet;
39 EFI_SMBIOS_HANDLE SmbiosHandle;
40 SMBIOS_TABLE_TYPE3 *SmbiosRecord;
41 EFI_MISC_CHASSIS_MANUFACTURER *ForType3InputData;
42 UINT8 *Buffer;
43
44 ForType3InputData = (EFI_MISC_CHASSIS_MANUFACTURER *)RecordData;
45
46 //
47 // First check for invalid parameters.
48 //
49 if (RecordData == NULL) {
50 return EFI_INVALID_PARAMETER;
51 }
52
53 TokenToGet = STRING_TOKEN (STR_MISC_CHASSIS_MANUFACTURER);
54 Manufacturer = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);
55 ManuStrLen = StrLen(Manufacturer);
56 if (ManuStrLen > SMBIOS_STRING_MAX_LENGTH) {
57 return EFI_UNSUPPORTED;
58 }
59
60 TokenToGet = STRING_TOKEN (STR_MISC_CHASSIS_VERSION);
61 Version = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);
62 VerStrLen = StrLen(Version);
63 if (VerStrLen > SMBIOS_STRING_MAX_LENGTH) {
64 return EFI_UNSUPPORTED;
65 }
66
67 TokenToGet = STRING_TOKEN (STR_MISC_CHASSIS_SERIAL_NUMBER);
68 SerialNumber = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);
69 SerialNumStrLen = StrLen(SerialNumber);
70 if (SerialNumStrLen > SMBIOS_STRING_MAX_LENGTH) {
71 return EFI_UNSUPPORTED;
72 }
73
74 TokenToGet = STRING_TOKEN (STR_MISC_CHASSIS_ASSET_TAG);
75 AssetTag = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);
76 AssetTagStrLen = StrLen(AssetTag);
77 if (AssetTagStrLen > SMBIOS_STRING_MAX_LENGTH) {
78 return EFI_UNSUPPORTED;
79 }
80
81 TokenToGet = STRING_TOKEN (STR_MISC_CHASSIS_SKU_NUMBER);
82 SkuNumber = HiiGetPackageString(&gEfiCallerIdGuid, TokenToGet, NULL);
83 SkuNumberStrLen = StrLen(SkuNumber);
84 if (SkuNumberStrLen > SMBIOS_STRING_MAX_LENGTH) {
85 return EFI_UNSUPPORTED;
86 }
87
88 //
89 // Two zeros following the last string.
90 //
91 // Since we set ContainedElementCount = 0 and ContainedElementRecordLength = 0,
92 // remove sizeof (CONTAINED_ELEMENT) for ContainedElements[1].
93 //
94 // Add sizeof (SMBIOS_TABLE_STRING) for SKU Number, since not contained in SMBIOS_TABLE_TYPE3.
95 //
96 SmbiosRecord = AllocatePool(sizeof (SMBIOS_TABLE_TYPE3) - sizeof (CONTAINED_ELEMENT) + sizeof (SMBIOS_TABLE_STRING) + ManuStrLen + 1 + VerStrLen + 1 + SerialNumStrLen + 1 + AssetTagStrLen + 1 + SkuNumberStrLen + 1 + 1);
97 ZeroMem(SmbiosRecord, sizeof (SMBIOS_TABLE_TYPE3) - sizeof (CONTAINED_ELEMENT) + sizeof (SMBIOS_TABLE_STRING) + ManuStrLen + 1 + VerStrLen + 1 + SerialNumStrLen + 1 + AssetTagStrLen + 1 + SkuNumberStrLen + 1 + 1);
98
99 Buffer = (UINT8 *) SmbiosRecord;
100
101 SmbiosRecord->Hdr.Type = EFI_SMBIOS_TYPE_SYSTEM_ENCLOSURE;
102 //
103 // Since we set ContainedElementCount = 0 and ContainedElementRecordLength = 0,
104 // remove sizeof (CONTAINED_ELEMENT) for ContainedElements[1].
105 //
106 // Add sizeof (SMBIOS_TABLE_STRING) for SKU Number, since not contained in SMBIOS_TABLE_TYPE3.
107 //
108 SmbiosRecord->Hdr.Length = sizeof (SMBIOS_TABLE_TYPE3) - sizeof (CONTAINED_ELEMENT) + sizeof (SMBIOS_TABLE_STRING);
109 //
110 // Make handle chosen by smbios protocol.add automatically.
111 //
112 SmbiosRecord->Hdr.Handle = 0;
113 //
114 // Manu will be the 1st optional string following the formatted structure.
115 //
116 SmbiosRecord->Manufacturer = 1;
117 SmbiosRecord->Type = (UINT8)ForType3InputData->ChassisType.ChassisType;
118 //
119 // Version will be the 2nd optional string following the formatted structure.
120 //
121 SmbiosRecord->Version = 2;
122 //
123 // SerialNumber will be the 3rd optional string following the formatted structure.
124 //
125 SmbiosRecord->SerialNumber = 3;
126 //
127 // AssetTag will be the 4th optional string following the formatted structure.
128 //
129 SmbiosRecord->AssetTag = 4;
130
131 SmbiosRecord->BootupState = (UINT8)ForType3InputData->ChassisBootupState;
132 SmbiosRecord->PowerSupplyState = (UINT8)ForType3InputData->ChassisPowerSupplyState;
133 SmbiosRecord->ThermalState = (UINT8)ForType3InputData->ChassisThermalState;
134 SmbiosRecord->SecurityStatus = (UINT8)ForType3InputData->ChassisSecurityState;
135 CopyMem (SmbiosRecord->OemDefined,(UINT8*)&ForType3InputData->ChassisOemDefined, 4);
136 SmbiosRecord->Height = (UINT8)ForType3InputData->ChassisHeight;
137 SmbiosRecord->NumberofPowerCords = (UINT8)ForType3InputData->ChassisNumberPowerCords;
138 SmbiosRecord->ContainedElementCount = 0;
139 SmbiosRecord->ContainedElementRecordLength = 0;
140
141 //
142 // SKU Number will be the 5th optional string following the formatted structure.
143 //
144 // Since SKU Number is not in SMBIOS_TABLE_TYPE3 structure, must locate it after ContainedElementRecordLength.
145 //
146 Buffer[sizeof (SMBIOS_TABLE_TYPE3) - sizeof (CONTAINED_ELEMENT)] = 5;
147
148 OptionalStrStart = (CHAR8 *)(SmbiosRecord + 1);
149 //
150 // Since we set ContainedElementCount = 0 and ContainedElementRecordLength = 0,
151 // remove sizeof (CONTAINED_ELEMENT) for ContainedElements[1].
152 //
153 OptionalStrStart -= sizeof (CONTAINED_ELEMENT);
154 //
155 // Add sizeof (SMBIOS_TABLE_STRING) for SKU Number, since not contained in SMBIOS_TABLE_TYPE3.
156 //
157 OptionalStrStart += sizeof (SMBIOS_TABLE_STRING);
158 UnicodeStrToAsciiStr (Manufacturer, OptionalStrStart);
159 UnicodeStrToAsciiStr (Version, OptionalStrStart + ManuStrLen + 1);
160 UnicodeStrToAsciiStr (SerialNumber, OptionalStrStart + ManuStrLen + 1 + VerStrLen + 1);
161 UnicodeStrToAsciiStr (AssetTag, OptionalStrStart + ManuStrLen + 1 + VerStrLen + 1 + SerialNumStrLen + 1);
162 UnicodeStrToAsciiStr (SkuNumber, OptionalStrStart + ManuStrLen + 1 + VerStrLen + 1 + SerialNumStrLen + 1 + AssetTagStrLen + 1);
163
164 //
165 // Now we have got the full smbios record, call smbios protocol to add this record.
166 //
167 Status = AddSmbiosRecord (Smbios, &SmbiosHandle, (EFI_SMBIOS_TABLE_HEADER *) SmbiosRecord);
168
169 FreePool(SmbiosRecord);
170 return Status;
171 }