3 Copyright (c) 2009 - 2014, Intel Corporation. All rights reserved.<BR>
5 SPDX-License-Identifier: BSD-2-Clause-Patent
12 MiscChassisManufacturerFunction.c
16 Chassis manufacturer information boot time changes.
22 #include "CommonHeader.h"
23 #include "MiscSubclassDriver.h"
24 #include <Guid/PlatformInfo.h>
27 extern EFI_PLATFORM_INFO_HOB
*mPlatformInfo
;
30 This function makes boot time changes to the contents of the
31 MiscChassisManufacturer (Type 3).
33 @param RecordData Pointer to copy of RecordData from the Data Table.
35 @retval EFI_SUCCESS All parameters were valid.
36 @retval EFI_UNSUPPORTED Unexpected RecordType value.
37 @retval EFI_INVALID_PARAMETER Invalid parameter was found.
40 MISC_SMBIOS_TABLE_FUNCTION(MiscChassisManufacturer
)
42 CHAR8
*OptionalStrStart
;
45 UINTN AssertTagStrLen
;
46 UINTN SerialNumStrLen
;
48 EFI_STRING Manufacturer
;
50 EFI_STRING SerialNumber
;
52 STRING_REF TokenToGet
;
53 EFI_SMBIOS_HANDLE SmbiosHandle
;
54 SMBIOS_TABLE_TYPE3
*SmbiosRecord
;
55 EFI_MISC_CHASSIS_MANUFACTURER
*ForType3InputData
;
58 ForType3InputData
= (EFI_MISC_CHASSIS_MANUFACTURER
*)RecordData
;
61 // First check for invalid parameters.
63 if (RecordData
== NULL
|| mPlatformInfo
== NULL
) {
64 return EFI_INVALID_PARAMETER
;
67 if (BOARD_ID_MINNOW2_TURBOT
== mPlatformInfo
->BoardId
) {
68 UnicodeSPrint (Buffer
, sizeof (Buffer
),L
"ADI");
69 HiiSetString(mHiiHandle
,STRING_TOKEN(STR_MISC_CHASSIS_MANUFACTURER
), Buffer
, NULL
);
71 TokenToGet
= STRING_TOKEN (STR_MISC_CHASSIS_MANUFACTURER
);
72 Manufacturer
= SmbiosMiscGetString (TokenToGet
);
73 ManuStrLen
= StrLen(Manufacturer
);
74 if (ManuStrLen
> SMBIOS_STRING_MAX_LENGTH
) {
75 return EFI_UNSUPPORTED
;
78 TokenToGet
= STRING_TOKEN (STR_MISC_CHASSIS_VERSION
);
79 Version
= SmbiosMiscGetString (TokenToGet
);
80 VerStrLen
= StrLen(Version
);
81 if (VerStrLen
> SMBIOS_STRING_MAX_LENGTH
) {
82 return EFI_UNSUPPORTED
;
85 TokenToGet
= STRING_TOKEN (STR_MISC_CHASSIS_SERIAL_NUMBER
);
86 SerialNumber
= SmbiosMiscGetString (TokenToGet
);
87 SerialNumStrLen
= StrLen(SerialNumber
);
88 if (SerialNumStrLen
> SMBIOS_STRING_MAX_LENGTH
) {
89 return EFI_UNSUPPORTED
;
92 TokenToGet
= STRING_TOKEN (STR_MISC_CHASSIS_ASSET_TAG
);
93 AssertTag
= SmbiosMiscGetString (TokenToGet
);
94 AssertTagStrLen
= StrLen(AssertTag
);
95 if (AssertTagStrLen
> SMBIOS_STRING_MAX_LENGTH
) {
96 return EFI_UNSUPPORTED
;
100 // Two zeros following the last string.
102 SmbiosRecord
= AllocatePool(sizeof (SMBIOS_TABLE_TYPE3
) + ManuStrLen
+ 1 + VerStrLen
+ 1 + SerialNumStrLen
+ 1 + AssertTagStrLen
+ 1 + 1);
103 ZeroMem(SmbiosRecord
, sizeof (SMBIOS_TABLE_TYPE3
) + ManuStrLen
+ 1 + VerStrLen
+ 1 + SerialNumStrLen
+ 1 + AssertTagStrLen
+ 1 + 1);
105 SmbiosRecord
->Hdr
.Type
= EFI_SMBIOS_TYPE_SYSTEM_ENCLOSURE
;
106 SmbiosRecord
->Hdr
.Length
= sizeof (SMBIOS_TABLE_TYPE3
);
109 // Make handle chosen by smbios protocol.add automatically.
111 SmbiosRecord
->Hdr
.Handle
= 0;
114 // Manu will be the 1st optional string following the formatted structure.
116 SmbiosRecord
->Manufacturer
= 1;
117 SmbiosRecord
->Type
= (UINT8
)ForType3InputData
->ChassisType
.ChassisType
;
120 // Version will be the 2nd optional string following the formatted structure.
122 SmbiosRecord
->Version
= 2;
125 // SerialNumber will be the 3rd optional string following the formatted structure.
127 SmbiosRecord
->SerialNumber
= 3;
130 // AssertTag will be the 4th optional string following the formatted structure.
132 SmbiosRecord
->AssetTag
= 4;
133 SmbiosRecord
->BootupState
= (UINT8
)ForType3InputData
->ChassisBootupState
;
134 SmbiosRecord
->PowerSupplyState
= (UINT8
)ForType3InputData
->ChassisPowerSupplyState
;
135 SmbiosRecord
->ThermalState
= (UINT8
)ForType3InputData
->ChassisThermalState
;
136 SmbiosRecord
->SecurityStatus
= (UINT8
)ForType3InputData
->ChassisSecurityState
;
137 CopyMem (SmbiosRecord
->OemDefined
,(UINT8
*)&ForType3InputData
->ChassisOemDefined
, 4);
139 OptionalStrStart
= (CHAR8
*)(SmbiosRecord
+ 1);
140 UnicodeStrToAsciiStr(Manufacturer
, OptionalStrStart
);
141 UnicodeStrToAsciiStr(Version
, OptionalStrStart
+ ManuStrLen
+ 1);
142 UnicodeStrToAsciiStr(SerialNumber
, OptionalStrStart
+ ManuStrLen
+ 1 + VerStrLen
+ 1);
143 UnicodeStrToAsciiStr(AssertTag
, OptionalStrStart
+ ManuStrLen
+ 1 + VerStrLen
+ 1 + SerialNumStrLen
+ 1);
146 // Now we have got the full smbios record, call smbios protocol to add this record.
148 SmbiosHandle
= SMBIOS_HANDLE_PI_RESERVED
;
149 Status
= Smbios
-> Add(
153 (EFI_SMBIOS_TABLE_HEADER
*) SmbiosRecord
156 FreePool(SmbiosRecord
);