diff options
author | cyang29 <cheng.c.yang@intel.com> | 2018-10-16 05:43:10 +0300 |
---|---|---|
committer | cyang29 <cheng.c.yang@intel.com> | 2018-10-16 05:43:10 +0300 |
commit | a1c921909056c5df7ca523ffcf96ab4b2470dd7b (patch) | |
tree | 152cb537c824b21f001b0f962062e6da59056966 /services | |
parent | 95ef585c9602b29f97a349b74a1dc0cd6007129f (diff) | |
download | provingground-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.cpp | 77 |
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, |