summaryrefslogtreecommitdiff
path: root/services
diff options
context:
space:
mode:
authorcyang29 <cheng.c.yang@intel.com>2018-10-16 05:43:10 +0300
committercyang29 <cheng.c.yang@intel.com>2018-10-16 05:43:10 +0300
commita1c921909056c5df7ca523ffcf96ab4b2470dd7b (patch)
tree152cb537c824b21f001b0f962062e6da59056966 /services
parent95ef585c9602b29f97a349b74a1dc0cd6007129f (diff)
downloadprovingground-a1c921909056c5df7ca523ffcf96ab4b2470dd7b.tar.xz
Add dbus service to support MDR V2 - part 2
Add send and get directory function for MDR V2 ipmi command store and get data through dbus interface. Change-Id: I079c5de18bb654179a5f017f4b50a2c9a6003cc4 Signed-off-by: cyang29 <cheng.c.yang@intel.com>
Diffstat (limited to 'services')
-rw-r--r--services/smbios-mdrv2/src/mdrv2.cpp77
1 files changed, 77 insertions, 0 deletions
diff --git a/services/smbios-mdrv2/src/mdrv2.cpp b/services/smbios-mdrv2/src/mdrv2.cpp
index 92492bb..dd3bad2 100644
--- a/services/smbios-mdrv2/src/mdrv2.cpp
+++ b/services/smbios-mdrv2/src/mdrv2.cpp
@@ -30,6 +30,36 @@ namespace smbios
std::vector<uint8_t> MDR_V2::getDirectoryInformation(uint8_t dirIndex)
{
+ std::vector<uint8_t> responseDir;
+ if (dirIndex > smbiosDir.dirEntries)
+ {
+ responseDir.push_back(0);
+ throw sdbusplus::xyz::openbmc_project::Smbios::MDR_V2::Error::
+ InvalidParameter();
+ }
+ responseDir.push_back(mdr2Version);
+ responseDir.push_back(smbiosDir.dirVersion);
+ uint8_t returnedEntries = smbiosDir.dirEntries - dirIndex;
+ responseDir.push_back(returnedEntries);
+ if ((dirIndex + returnedEntries) >= smbiosDir.dirEntries)
+ {
+ responseDir.push_back(0);
+ }
+ else
+ {
+ responseDir.push_back(smbiosDir.dirEntries - dirIndex -
+ returnedEntries);
+ }
+ for (uint8_t index = dirIndex; index < smbiosDir.dirEntries; index++)
+ {
+ for (uint8_t indexId = 0; indexId < sizeof(DataIdStruct); indexId++)
+ {
+ responseDir.push_back(
+ smbiosDir.dir[index].common.id.dataInfo[indexId]);
+ }
+ }
+
+ return responseDir;
}
bool MDR_V2::smbiosIsAvailForUpdate(uint8_t index)
@@ -153,6 +183,53 @@ bool MDR_V2::sendDirectoryInformation(uint8_t dirVersion, uint8_t dirIndex,
uint8_t remainingEntries,
std::vector<uint8_t> dirEntry)
{
+ bool teminate = false;
+ if ((dirIndex >= maxDirEntries) || (returnedEntries < 1))
+ {
+ phosphor::logging::log<phosphor::logging::level::ERR>(
+ "Send Dir info failed - input parameter invalid");
+ throw sdbusplus::xyz::openbmc_project::Smbios::MDR_V2::Error::
+ InvalidParameter();
+ }
+ if (dirEntry.size() < sizeof(Mdr2DirEntry))
+ {
+ phosphor::logging::log<phosphor::logging::level::ERR>(
+ "Directory size invalid");
+ throw sdbusplus::xyz::openbmc_project::Smbios::MDR_V2::Error::
+ InvalidParameter();
+ }
+ if (dirVersion == smbiosDir.dirVersion)
+ {
+ teminate = true;
+ }
+ else
+ {
+ if (remainingEntries > 0)
+ {
+ teminate = false;
+ }
+ else
+ {
+ teminate = true;
+ smbiosDir.dirVersion = dirVersion;
+ }
+ uint8_t idIndex = dirIndex;
+
+ uint8_t *pData = dirEntry.data();
+ for (uint8_t index = 0; index < returnedEntries; index++)
+ {
+ auto data = reinterpret_cast<const Mdr2DirEntry *>(pData);
+ smbiosDir.dir[idIndex + index].common.dataVersion =
+ data->dataVersion;
+ std::copy(data->id.dataInfo,
+ data->id.dataInfo + sizeof(DataIdStruct),
+ smbiosDir.dir[idIndex + index].common.id.dataInfo);
+ smbiosDir.dir[idIndex + index].common.dataSetSize = data->size;
+ smbiosDir.dir[idIndex + index].common.timestamp = data->timestamp;
+ pData += sizeof(returnedEntries);
+ }
+ }
+ return teminate;
}
bool MDR_V2::sendDataInformation(uint8_t idIndex, uint8_t flag,