blob: 6a4c60814eb66e2cca4cd67ade07985213b0cb6b [file] [log] [blame]
#include "memory_vpd_parser.hpp"
#include <iostream>
#include <numeric>
#include <string>
namespace openpower
{
namespace vpd
{
namespace memory
{
namespace parser
{
using namespace inventory;
using namespace constants;
using namespace std;
using namespace openpower::vpd::parser;
kwdVpdMap memoryVpdParser::readKeywords(Binary::const_iterator iterator)
{
KeywordVpdMap map{};
vector<uint8_t> partNumber(iterator, iterator + PART_NUM_LEN);
advance(iterator, PART_NUM_LEN);
vector<uint8_t> serialNumber(iterator, iterator + SERIAL_NUM_LEN);
advance(iterator, SERIAL_NUM_LEN);
vector<uint8_t> ccin(iterator, iterator + CCIN_LEN);
map.emplace("PN", move(partNumber));
map.emplace("SN", move(serialNumber));
map.emplace("CC", move(ccin));
return map;
}
variant<kwdVpdMap, Store> memoryVpdParser::parse()
{
// check if vpd file is empty
if (memVpd.empty())
{
throw runtime_error("VPD file is empty.");
}
// Read the data and return the map
auto iterator = memVpd.cbegin();
// point the iterator to DIMM data and skip "11S"
advance(iterator, MEMORY_VPD_DATA_START + 3);
auto vpdDataMap = readKeywords(iterator);
return vpdDataMap;
}
std::string memoryVpdParser::getInterfaceName() const
{
return memVpdInf;
}
} // namespace parser
} // namespace memory
} // namespace vpd
} // namespace openpower