blob: 3f7c4018c14472ada08ce376afeb410ecf595091 [file] [log] [blame]
/*
// Copyright (c) 2017 2018 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
*/
#pragma once
#include <cstdint>
#include <phosphor-ipmi-host/sensorhandler.hpp>
static constexpr uint8_t ipmiSdrVersion = 0x51;
namespace intel_oem::ipmi::sel
{
// ID string generated using journalctl to include in the MESSAGE_ID field for
// SEL entries. Helps with filtering SEL entries in the journal.
static constexpr const char* selMessageId = "b370836ccf2f4850ac5bee185b77893a";
static constexpr uint8_t selOperationSupport = 0x02;
static constexpr uint8_t systemEvent = 0x02;
static constexpr size_t systemEventSize = 3;
static constexpr uint8_t oemTsEventFirst = 0xC0;
static constexpr uint8_t oemTsEventLast = 0xDF;
static constexpr size_t oemTsEventSize = 9;
static constexpr uint8_t oemEventFirst = 0xE0;
static constexpr uint8_t oemEventLast = 0xFF;
static constexpr size_t oemEventSize = 13;
static constexpr uint8_t eventMsgRev = 0x04;
} // namespace intel_oem::ipmi::sel
#pragma pack(push, 1)
struct GetSDRInfoResp
{
uint8_t sdrVersion;
uint8_t recordCountLS;
uint8_t recordCountMS;
uint8_t freeSpace[2];
uint32_t mostRecentAddition;
uint32_t mostRecentErase;
uint8_t operationSupport;
};
struct GetSDRReq
{
uint16_t reservationID;
uint16_t recordID;
uint8_t offset;
uint8_t bytesToRead;
};
#pragma pack(pop)
enum class SdrRepositoryInfoOps : uint8_t
{
allocCommandSupported = 0x1,
reserveSDRRepositoryCommandSupported = 0x2,
partialAddSDRSupported = 0x4,
deleteSDRSupported = 0x8,
reserved = 0x10,
modalLSB = 0x20,
modalMSB = 0x40,
overflow = 0x80
};
#pragma pack(push, 1)
struct GetAllocInfoResp
{
uint8_t allocUnitsLSB;
uint8_t allocUnitsMSB;
uint8_t allocUnitSizeLSB;
uint8_t allocUnitSizeMSB;
uint8_t allocUnitFreeLSB;
uint8_t allocUnitFreeMSB;
uint8_t allocUnitLargestFreeLSB;
uint8_t allocUnitLargestFreeMSB;
uint8_t maxRecordSize;
};
struct GetFRUAreaReq
{
uint8_t fruDeviceID;
uint16_t fruInventoryOffset;
uint8_t countToRead;
};
struct GetFRUAreaResp
{
uint8_t inventorySizeLSB;
uint8_t inventorySizeMSB;
uint8_t accessType;
};
struct WriteFRUDataReq
{
uint8_t fruDeviceID;
uint16_t fruInventoryOffset;
uint8_t data[];
};
struct GetSELEntryResponse
{
uint16_t nextRecordID;
uint16_t recordID;
uint8_t recordType;
union
{
struct
{
uint32_t timestamp;
uint16_t generatorID;
uint8_t eventMsgRevision;
uint8_t sensorType;
uint8_t sensorNum;
uint8_t eventType;
uint8_t eventData[intel_oem::ipmi::sel::systemEventSize];
} system;
struct
{
uint32_t timestamp;
uint8_t eventData[intel_oem::ipmi::sel::oemTsEventSize];
} oemTs;
struct
{
uint8_t eventData[intel_oem::ipmi::sel::oemEventSize];
} oem;
} record;
};
struct AddSELRequest
{
uint16_t recordID;
uint8_t recordType;
union
{
struct
{
uint32_t timestamp;
uint16_t generatorID;
uint8_t eventMsgRevision;
uint8_t sensorType;
uint8_t sensorNum;
uint8_t eventType;
uint8_t eventData[intel_oem::ipmi::sel::systemEventSize];
} system;
struct
{
uint32_t timestamp;
uint8_t eventData[intel_oem::ipmi::sel::oemTsEventSize];
} oemTs;
struct
{
uint8_t eventData[intel_oem::ipmi::sel::oemEventSize];
} oem;
} record;
};
#pragma pack(pop)
enum class GetFRUAreaAccessType : uint8_t
{
byte = 0x0,
words = 0x1
};
enum class SensorUnits : uint8_t
{
unspecified = 0x0,
degreesC = 0x1,
volts = 0x4,
amps = 0x5,
watts = 0x6,
rpm = 0x12,
};
enum class IPMINetfnStorageCmds : ipmi_cmd_t
{
ipmiCmdGetFRUInvAreaInfo = 0x10,
ipmiCmdReadFRUData = 0x11,
ipmiCmdWriteFRUData = 0x12,
ipmiCmdGetRepositoryInfo = 0x20,
ipmiCmdGetSDRAllocationInfo = 0x21,
ipmiCmdReserveSDR = 0x22,
ipmiCmdGetSDR = 0x23,
ipmiCmdGetSELInfo = 0x40,
ipmiCmdReserveSEL = 0x42,
ipmiCmdGetSELEntry = 0x43,
ipmiCmdAddSEL = 0x44,
ipmiCmdDeleteSEL = 0x46,
ipmiCmdClearSEL = 0x47,
ipmiCmdGetSELTime = 0x48,
ipmiCmdSetSELTime = 0x49,
};
#pragma pack(push, 1)
struct FRUHeader
{
uint8_t commonHeaderFormat;
uint8_t internalOffset;
uint8_t chassisOffset;
uint8_t boardOffset;
uint8_t productOffset;
uint8_t multiRecordOffset;
uint8_t pad;
uint8_t checksum;
};
#pragma pack(pop)
namespace ipmi
{
namespace storage
{
ipmi_ret_t getFruSdrs(size_t index, get_sdr::SensorDataFruRecord& resp);
ipmi_ret_t getFruSdrCount(size_t& count);
} // namespace storage
} // namespace ipmi