blob: 49b66cd8a2edba3f2fc98fae7a0da4e7cd2bec01 [file] [log] [blame]
Jia, Chunhuia835eaa2018-09-05 09:00:41 +08001/*
2// Copyright (c) 2018 Intel Corporation
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15*/
16
17#pragma once
18
Vernon Mauery98bbf692019-09-16 11:14:59 -070019#include <ipmid/api-types.hpp>
Suryakanth Sekard509eb92018-11-15 17:44:11 +053020#include <user_channel/user_layer.hpp>
Vernon Mauery98bbf692019-09-16 11:14:59 -070021namespace ipmi
Jia, Chunhuia835eaa2018-09-05 09:00:41 +080022{
Vernon Mauery98bbf692019-09-16 11:14:59 -070023namespace intel
Yong Li23737fe2019-02-19 08:49:55 +080024{
Yong Li23737fe2019-02-19 08:49:55 +080025
Vernon Mauery98bbf692019-09-16 11:14:59 -070026static constexpr NetFn netFnGeneral = netFnOemOne;
27static constexpr NetFn netFnPlatform = netFnOemTwo;
28static constexpr NetFn netFnApp = netFnOemEight;
29
30namespace general
31{
Vernon Maueryaf652682023-08-04 13:37:21 -070032static constexpr Cmd cmdGetBmcVersionString = 0x01;
Vernon Mauery98bbf692019-09-16 11:14:59 -070033static constexpr Cmd cmdRestoreConfiguration = 0x02;
34static constexpr Cmd cmdGetSmSignal = 0x14;
35static constexpr Cmd cmdSetSmSignal = 0x15;
36static constexpr Cmd cmdSetBIOSID = 0x26;
37static constexpr Cmd cmdGetOEMDeviceInfo = 0x27;
38static constexpr Cmd cmdSetColdRedundancyConfig = 0x2d;
39static constexpr Cmd cmdGetColdRedundancyConfig = 0x2e;
40static constexpr Cmd cmdGetAICSlotFRUIDSlotPosRecords = 0x31;
41static constexpr Cmd cmdGetMultiNodeRole = 0x33;
42static constexpr Cmd cmdGetMultiNodeId = 0x36;
43static constexpr Cmd cmdSetSystemGUID = 0x41;
44static constexpr Cmd cmdDisableBMCSystemReset = 0x42;
45static constexpr Cmd cmdGetBMCResetDisables = 0x43;
46static constexpr Cmd cmdSendEmbeddedFWUpdStatus = 0x44;
Matt Simmering80d4d5f2023-02-15 15:18:51 -080047static constexpr Cmd cmdSlotI2CControllerWriteRead = 0x52;
Vernon Mauery98bbf692019-09-16 11:14:59 -070048static constexpr Cmd cmdSetPowerRestoreDelay = 0x54;
49static constexpr Cmd cmdGetPowerRestoreDelay = 0x55;
50static constexpr Cmd cmdSetFaultIndication = 0x57;
51static constexpr Cmd cmdSetOEMUser2Activation = 0x5A;
52static constexpr Cmd cmdSetSpecialUserPassword = 0x5F;
53static constexpr Cmd cmdSetShutdownPolicy = 0x60;
54static constexpr Cmd cmdGetShutdownPolicy = 0x62;
55static constexpr Cmd cmdGetMultiNodePresence = 0x63;
AppaRao Puli28972062019-11-11 02:04:45 +053056static constexpr Cmd cmdGetBufferSize = 0x66;
Vernon Mauery98bbf692019-09-16 11:14:59 -070057static constexpr Cmd cmdSetFanConfig = 0x89;
58static constexpr Cmd cmdGetFanConfig = 0x8a;
59static constexpr Cmd cmdSetFanSpeedOffset = 0x8c;
60static constexpr Cmd cmdGetFanSpeedOffset = 0x8d;
61static constexpr Cmd cmdSetDimmOffset = 0x8e;
62static constexpr Cmd cmdGetDimmOffset = 0x8f;
63static constexpr Cmd cmdSetFscParameter = 0x90;
64static constexpr Cmd cmdGetFscParameter = 0x91;
65static constexpr Cmd cmdGetChassisIdentifier = 0x92;
66static constexpr Cmd cmdReadBaseBoardProductId = 0x93;
67static constexpr Cmd cmdGetProcessorErrConfig = 0x9A;
68static constexpr Cmd cmdSetProcessorErrConfig = 0x9B;
69static constexpr Cmd cmdSetManufacturingData = 0xA1;
70static constexpr Cmd cmdGetManufacturingData = 0xA2;
Vernon Mauery27d23562021-08-12 10:43:39 -070071static constexpr Cmd cmdSetFITcLayout = 0xA3;
Arun P. Mohanan06584cd2021-08-13 20:56:01 +053072static constexpr Cmd cmdMTMBMCFeatureControl = 0xA4;
Vernon Mauery98bbf692019-09-16 11:14:59 -070073static constexpr Cmd cmdGetLEDStatus = 0xB0;
74static constexpr Cmd cmdControlBmcServices = 0xB1;
75static constexpr Cmd cmdGetBmcServiceStatus = 0xB2;
76static constexpr Cmd cmdGetSecurityMode = 0xB3;
77static constexpr Cmd cmdSetSecurityMode = 0xB4;
78static constexpr Cmd cmdMtmKeepAlive = 0xB5;
srikanta mondal2030d7c2020-05-03 17:25:25 +000079static constexpr Cmd cmdOEMGetReading = 0xE2;
Kuiying Wang6d6dc7a2020-04-02 10:15:19 +080080static constexpr Cmd cmdSetBIOSCap = 0xD3;
81static constexpr Cmd cmdGetBIOSCap = 0xD4;
82static constexpr Cmd cmdSetPayload = 0xD5;
83static constexpr Cmd cmdGetPayload = 0xD6;
84static constexpr Cmd cmdSetBIOSPwdHashInfo = 0xD7;
85static constexpr Cmd cmdGetBIOSPwdHash = 0xD8;
Vernon Mauery98bbf692019-09-16 11:14:59 -070086static constexpr Cmd cmdGetNmiStatus = 0xE5;
87static constexpr Cmd cmdSetEfiBootOptions = 0xEA;
88static constexpr Cmd cmdGetEfiBootOptions = 0xEB;
89static constexpr Cmd cmdSetNmiStatus = 0xED;
Cheng C Yang4e6ee152019-09-25 10:27:44 +080090static constexpr Cmd cmdGetPSUVersion = 0xEF;
Vernon Mauery98bbf692019-09-16 11:14:59 -070091} // namespace general
92
93namespace platform
94{
95static constexpr Cmd cmdCfgHostSerialPortSpeed = 0x90;
Yong Li068b4f22019-09-17 16:32:18 +080096static constexpr Cmd cmdClearCMOS = 0x91;
Vernon Mauery98bbf692019-09-16 11:14:59 -070097} // namespace platform
98
99namespace app
100{
101static constexpr Cmd cmdMdrStatus = 0x20;
102static constexpr Cmd cmdMdrComplete = 0x21;
103static constexpr Cmd cmdMdrEvent = 0x22;
104static constexpr Cmd cmdMdrRead = 0x23;
105static constexpr Cmd cmdMdrWrite = 0x24;
106static constexpr Cmd cmdMdrLock = 0x25;
107static constexpr Cmd cmdMdrIIAgentStatus = 0x30;
108static constexpr Cmd cmdMdrIIGetDir = 0x31;
109static constexpr Cmd cmdMdrIIGetDataInfo = 0x32;
110static constexpr Cmd cmdMdrIILockData = 0x33;
111static constexpr Cmd cmdMdrIIUnlockData = 0X34;
112static constexpr Cmd cmdMdrIIGetDataBlock = 0x35;
113static constexpr Cmd cmdMdrIISendDir = 0x38;
114static constexpr Cmd cmdMdrIISendDataInfoOffer = 0x39;
115static constexpr Cmd cmdMdrIISendDataInfo = 0x3a;
116static constexpr Cmd cmdMdrIIDataStart = 0x3b;
117static constexpr Cmd cmdMdrIIDataDone = 0x3c;
118static constexpr Cmd cmdMdrIISendDataBlock = 0x3d;
Rajashekar Gade Reddy2b664d52020-03-23 22:09:00 +0530119static constexpr Cmd cmdSlotIpmb = 0x51;
Ankita Vilas Gawadea1650382022-01-08 10:30:40 +0000120static constexpr Cmd cmdPFRMailboxRead = 0x84;
Vernon Mauery98bbf692019-09-16 11:14:59 -0700121} // namespace app
122
123} // namespace intel
124
125} // namespace ipmi
126
127// FIXME: put these in the cpp files that use them
Jason M. Bills64796042018-10-03 16:51:55 -0700128enum class IPMIIntelOEMReturnCodes
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800129{
130 ipmiCCPayloadActive = 0x80,
131 ipmiCCInvalidPCIESlotID = 0x80,
132 ipmiCCParameterNotSupported = 0x80,
133 ipmiCCPayloadAlreadyDeactivated = 0x80,
134 ipmiCCSetInProcess = 0x81,
135 ipmiCCPayloadDisable = 0x81,
136 ipmiCCLostArbitration = 0x81,
137 ipmiCCInvalidCablePortIndex = 0x81,
138 ipmiCCHealthStatusNotAvailable = 0x81,
139 ipmiCCBusError = 0x82,
140 ipmiCCReadOnly = 0x82,
141 ipmiCCWriteOnly = 0x82,
142 ipmiCCNoCablePresent = 0x82,
143 ipmiCCDataCollectionInProgress = 0x82,
144 ipmiCCPayloadActivationLimitReached = 0x82,
145 ipmiCCNACKOnWrite = 0x83,
146 ipmiCCDataCollectionFailed = 0x83,
147 ipmiCCCanNotActivateWithEncrption = 0x83,
148 ipmiCCCanNotActivateWithoutEncryption = 0x84,
149 ipmiCCInvalidChecksum = 0x85,
150 ipmiCCNoCabledPCIEPortsAvailable = 0xC2,
151
152};
153
Jason M. Bills64796042018-10-03 16:51:55 -0700154enum class IPMIReturnCodeExt
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800155{
156 ipmiCCInvalidLUN = 0xC2,
157 ipmiCCTimeout = 0xC3,
158 ipmiCCStorageLeak = 0xC4,
159 ipmiCCRequestDataTruncated = 0xC6,
160 ipmiCCRequestDataFieldLengthLimitExceeded = 0xC8,
161 ipmiCCCanNotReturnNumberOfRequestedDataBytes = 0xCA,
162 ipmiCCRequestSensorDataRecordNotFound = 0xCB,
163 ipmiCCDestinationUnavailable = 0xD3,
164 ipmiCCParamterNotSupportInPresentState = 0xD5,
165};
166
Jason M. Bills64796042018-10-03 16:51:55 -0700167static constexpr const uint8_t maxBIOSIDLength = 0xFF;
168static constexpr const uint8_t maxCPUNum = 4;
Chalapathi899bfd12020-04-15 15:07:02 +0000169static constexpr const char* biosActiveObjPath =
170 "/xyz/openbmc_project/software/bios_active";
Yong Li2742b852019-12-16 14:55:11 +0800171static constexpr const char* biosVersionIntf =
172 "xyz.openbmc_project.Software.Version";
173static constexpr const char* biosVersionProp = "Version";
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800174
Jason M. Bills64796042018-10-03 16:51:55 -0700175static constexpr const char* powerRestoreDelayObjPath =
Andrei Kartashevc42c7ed2022-01-10 12:17:34 +0300176 "/xyz/openbmc_project/control/host0/power_restore_policy";
Jason M. Bills64796042018-10-03 16:51:55 -0700177static constexpr const char* powerRestoreDelayIntf =
Andrei Kartashevc42c7ed2022-01-10 12:17:34 +0300178 "xyz.openbmc_project.Control.Power.RestorePolicy";
Jason M. Bills64796042018-10-03 16:51:55 -0700179static constexpr const char* powerRestoreDelayProp = "PowerRestoreDelay";
180static constexpr const char* processorErrConfigObjPath =
181 "/xyz/openbmc_project/control/processor_error_config";
182static constexpr const char* processorErrConfigIntf =
183 "xyz.openbmc_project.Control.Processor.ErrConfig";
Jason M. Billsb02bf092019-08-15 13:01:56 -0700184static constexpr const char* bmcResetDisablesPath =
185 "/xyz/openbmc_project/control/bmc_reset_disables";
186static constexpr const char* bmcResetDisablesIntf =
187 "xyz.openbmc_project.Control.ResetDisables";
Jason M. Bills64796042018-10-03 16:51:55 -0700188
Kuiying Wang45f04982018-12-26 09:23:08 +0800189static constexpr const char* identifyLEDObjPath =
190 "/xyz/openbmc_project/led/physical/identify";
191static constexpr const char* ledIntf = "xyz.openbmc_project.Led.Physical";
192static constexpr const char* statusAmberObjPath =
193 "/xyz/openbmc_project/led/physical/status_amber";
194static constexpr const char* statusGreenObjPath =
195 "/xyz/openbmc_project/led/physical/status_green";
196
Yong Li703922d2018-11-06 13:25:31 +0800197static constexpr const uint8_t noShutdownOnOCOT = 0;
198static constexpr const uint8_t shutdownOnOCOT = 1;
199static constexpr const uint8_t noShutdownPolicySupported = 0;
200static constexpr const uint8_t shutdownPolicySupported = 1;
201static constexpr const char* oemShutdownPolicyIntf =
Yong Li0669d192019-05-06 14:01:46 +0800202 "com.intel.Control.OCOTShutdownPolicy";
Yong Li703922d2018-11-06 13:25:31 +0800203static constexpr const char* oemShutdownPolicyObjPath =
Yong Li0669d192019-05-06 14:01:46 +0800204 "/com/intel/control/ocotshutdown_policy_config";
205static constexpr const char* oemShutdownPolicyObjPathProp = "OCOTPolicy";
Yong Li703922d2018-11-06 13:25:31 +0800206
Yong Li23737fe2019-02-19 08:49:55 +0800207static constexpr const char* fwGetEnvCmd = "/sbin/fw_printenv";
208static constexpr const char* fwSetEnvCmd = "/sbin/fw_setenv";
209static constexpr const char* fwHostSerailCfgEnvName = "hostserialcfg";
210
James Feist91244a62019-02-19 15:04:54 -0800211constexpr const char* settingsBusName = "xyz.openbmc_project.Settings";
212
Yong Li23737fe2019-02-19 08:49:55 +0800213static constexpr const uint8_t getHostSerialCfgCmd = 0;
214static constexpr const uint8_t setHostSerialCfgCmd = 1;
215
216// parameters:
217// 0: host serial port 1 and 2 normal speed
218// 1: host serial port 1 high spend, port 2 normal speed
219// 2: host serial port 1 normal spend, port 2 high speed
220// 3: host serial port 1 and 2 high speed
221static constexpr const uint8_t HostSerialCfgParamMax = 3;
Suryakanth Sekard509eb92018-11-15 17:44:11 +0530222static constexpr uint8_t ipmiDefaultUserId = 2;
Yong Li23737fe2019-02-19 08:49:55 +0800223
Jia, Chunhuicc49b542019-03-20 15:41:07 +0800224static constexpr const uint8_t selEvtTargetMask = 0xF0;
225static constexpr const uint8_t selEvtTargetShift = 4;
226
227static constexpr const uint8_t targetInstanceMask = 0x0E;
228static constexpr const uint8_t targetInstanceShift = 1;
229
Jason M. Bills64796042018-10-03 16:51:55 -0700230enum class IPMINetfnIntelOEMAppCmd
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800231{
232 mdrStatus = 0x20,
233 mdrComplete = 0x21,
234 mdrEvent = 0x22,
235 mdrRead = 0x23,
236 mdrWrite = 0x24,
237 mdrLock = 0x25,
238 mdr2AgentStatus = 0x30,
239 mdr2GetDir = 0x31,
240 mdr2GetDataInfo = 0x32,
241 mdr2LockData = 0x33,
242 mdr2UnlockData = 0x34,
243 mdr2GetDataBlock = 0x35,
244 mdr2SendDir = 0x38,
245 mdr2SendDataInfoOffer = 0x39,
246 mdr2SendDataInfo = 0x3a,
247 mdr2DataStart = 0x3b,
248 mdr2DataDone = 0x3c,
249 mdr2SendDataBlock = 0x3d,
250};
251
Jason M. Bills64796042018-10-03 16:51:55 -0700252enum class OEMDevEntityType
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800253{
254 biosId,
255 devVer,
256 sdrVer,
Jason M. Bills64796042018-10-03 16:51:55 -0700257};
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800258
Jia, Chunhuicc49b542019-03-20 15:41:07 +0800259enum class FWUpdateTarget : uint8_t
260{
261 targetBMC = 0x0,
262 targetBIOS = 0x1,
263 targetME = 0x2,
264 targetOEMEWS = 0x4,
265};
266
Jason M. Bills42bd9c82019-06-28 16:39:34 -0700267enum class CPUStatus
268{
269 disabled = 0x0,
270 enabled = 0x1,
271 notPresent = 0x3,
272};
273
Jason M. Bills64796042018-10-03 16:51:55 -0700274#pragma pack(push, 1)
275struct GUIDData
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800276{
277 uint8_t node1;
278 uint8_t node2;
279 uint8_t node3;
280 uint8_t node4;
281 uint8_t node5;
282 uint8_t node6;
283 uint8_t clock1;
284 uint8_t clock2;
285 uint8_t timeHigh1;
286 uint8_t timeHigh2;
287 uint8_t timeMid1;
288 uint8_t timeMid2;
289 uint8_t timeLow1;
290 uint8_t timeLow2;
291 uint8_t timeLow3;
292 uint8_t timeLow4;
Jason M. Bills64796042018-10-03 16:51:55 -0700293};
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800294
Jason M. Bills64796042018-10-03 16:51:55 -0700295struct DeviceInfo
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800296{
Jason M. Bills64796042018-10-03 16:51:55 -0700297 uint8_t biosIDLength;
298 uint8_t biosId[maxBIOSIDLength];
299};
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800300
Jason M. Bills64796042018-10-03 16:51:55 -0700301struct SetPowerRestoreDelayReq
302{
303 uint8_t byteMSB;
304 uint8_t byteLSB;
305};
306
307struct GetPowerRestoreDelayRes
308{
309 uint8_t byteMSB;
310 uint8_t byteLSB;
311};
312
Jason M. Bills64796042018-10-03 16:51:55 -0700313struct GetOemDeviceInfoRes
Jia, Chunhuia835eaa2018-09-05 09:00:41 +0800314{
315 uint8_t resDatalen;
Jason M. Bills64796042018-10-03 16:51:55 -0700316 uint8_t data[maxBIOSIDLength];
317};
318
Yong Li703922d2018-11-06 13:25:31 +0800319struct GetOEMShutdownPolicyRes
320{
321 uint8_t policy;
322 uint8_t policySupport;
323};
Kuiying Wang45f04982018-12-26 09:23:08 +0800324
Yong Li23737fe2019-02-19 08:49:55 +0800325struct CfgHostSerialReq
326{
327 uint8_t command;
328 uint8_t parameter;
329};
Kuiying Wang45f04982018-12-26 09:23:08 +0800330#pragma pack(pop)
James Feist91244a62019-02-19 15:04:54 -0800331
Zhu, Yungebe560b02019-04-21 21:19:21 -0400332//
333// Fault type enumeration
334//
335enum class RemoteFaultType
336{
337 fan, // 0
338 temperature, // 1
339 power, // 2
340 driveslot, // 3
341 software, // 4
342 memory, // 5
343 max = 6 // 6
344};
345
346// Enumeration for remote fault states as required by the HSC
347//
348enum class RemoteFaultState
349{
350 // fault indicators
351 fanLEDs,
352 cpu1DimmLeds,
353 cpu2DimmLeds,
354 cpu3DimmLeds,
355 cpu4DimmLeds,
356 maxFaultState,
357};
358
359enum class DimmFaultType
360{
361 cpu1cpu2Dimm,
362 cpu3cpu4Dimm,
363 maxFaultGroup,
364};
365
James Feist5f957ca2019-03-14 15:33:55 -0700366enum class setFscParamFlags : uint8_t
367{
368 tcontrol = 0x1,
369 pwmOffset = 0x2,
370 maxPwm = 0x3,
371 cfm = 0x4
Jia, Chunhuicc49b542019-03-20 15:41:07 +0800372};
Vernon Mauerya3702c12019-05-22 13:20:59 -0700373
James Feist63efafa2019-07-24 12:39:21 -0700374enum class dimmOffsetTypes : uint8_t
375{
376 staticCltt = 0x0,
377 dimmPower = 0x2
378};
379
Vernon Mauerya3702c12019-05-22 13:20:59 -0700380// FIXME: this stuff needs to be rewritten
381enum IPMI_INTEL_OEM_RETURN_CODES
382{
383 IPMI_CC_OEM_PAYLOAD_ACTIVE = 0x80,
384 IPMI_CC_OEM_INVALID_PCIE_SLOTID = 0x80,
385 IPMI_CC_OEM_PARAMETER_NOT_SUPPORTED = 0x80,
386 IPMI_CC_OEM_PAYLOAD_ALREADY_DEACTIVATED = 0x80,
387 IPMI_CC_OEM_SET_IN_PROCESS = 0x81,
388 IPMI_CC_OEM_PAYLOAD_DISABLE = 0x81,
389 IPMI_CC_OEM_LOST_ARBITRATION = 0x81,
390 IPMI_CC_OEM_INVALID_CABLE_PORT_INDEX = 0x81,
391 IPMI_CC_OEM_HEALTH_STATUS_NOT_AVAILABLE = 0x81,
392 IPMI_CC_OEM_BUS_ERROR = 0x82,
393 IPMI_CC_OEM_READ_ONLY = 0x82,
394 IPMI_CC_OEM_WRITE_ONLY = 0x82,
395 IPMI_CC_OEM_NO_CABLE_PRESENT = 0x82,
396 IPMI_CC_OEM_DATA_COLLECTION_IN_PROGRESS = 0x82,
397 IPMI_CC_OEM_PAYLOAD_ACTIVATION_LIMIT_REACH = 0x82,
398 IPMI_CC_OEM_NACK_ON_WRITE = 0x83,
399 IPMI_CC_OEM_DATA_COLLECTION_FAILED = 0x83,
400 IPMI_CC_OEM_CAN_NOT_ACTIVATE_WITH_ENCRYPTION = 0x83,
401 IPMI_CC_OEM_CAN_NOT_ACTIVATE_WITHOUT_ENCRYPTION = 0x84,
402 IPMI_CC_OEM_INVALID_CHECKSUM = 0x85,
403 IPMI_CC_OEM_NO_CABLED_PCIE_PORTS_AVAILABLE = 0xC2,
404};
405
406enum IPMI_RETURN_CODE_EXT
407{
408 IPMI_CC_INVALID_LUN = 0xC2,
409 IPMI_CC_STORGE_LEAK = 0xC4,
410 IPMI_CC_REQUEST_DATA_TRUNCATED = 0xC6,
411 IPMI_CC_REQUEST_DATA_FIELD_LENGTH_LIMIT_EXCEEDED = 0xC8,
412 IPMI_CC_CANNOT_RETURN_NUMBER_OF_REQUESTED_DATA_BYTES = 0xCA,
413 IPMI_CC_REQUEST_SENSOR_DATA_RECORD_NOT_FOUND = 0xCB,
414 IPMI_CC_DESTINATION_UNAVAILABLE = 0xD3,
415 IPMI_CC_PARAMETER_NOT_SUPPORT_IN_PRESENT_STATE = 0xD5,
416};