summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Jeffery <andrew@aj.id.au>2018-02-21 15:29:38 +1030
committerAndrew Jeffery <andrew@aj.id.au>2018-03-24 13:59:32 +1030
commit581a4f2c267ebad0b1cbf554a7b23ebf25ececfd (patch)
tree0fec5afe047042e4ace62e4d0f1b5b85ee9c366d
parentf34db31d768e38c3add58a83cd943609771fd212 (diff)
downloadphosphor-mboxd-581a4f2c267ebad0b1cbf554a7b23ebf25ececfd.tar.gz
phosphor-mboxd-581a4f2c267ebad0b1cbf554a7b23ebf25ececfd.zip
pnor_partition_table: Extract preparePartitions() loop body
Create a new private method, parseTocLine(), to handle the function of the loop body. The eventual goal is to extract the function from the class completely and simply have parseTocLine() as a public function in the openpower::virtual_pnor namespace. This will facilitate testing of the virtual PNOR parts of the codebase. Change-Id: Ib8c3b39eb9390cfc088a54abd45aab6f551775d3 Signed-off-by: Andrew Jeffery <andrew@aj.id.au>
-rw-r--r--pnor_partition_table.cpp74
-rw-r--r--pnor_partition_table.hpp14
2 files changed, 56 insertions, 32 deletions
diff --git a/pnor_partition_table.cpp b/pnor_partition_table.cpp
index 7f00f31..ab72b5c 100644
--- a/pnor_partition_table.cpp
+++ b/pnor_partition_table.cpp
@@ -151,18 +151,16 @@ inline void Table::writeNameAndId(pnor_partition& part, std::string&& name,
part.data.id = std::stoul(id);
}
-void Table::preparePartitions()
+bool Table::parseTocLine(fs::path& dir, const std::string& line,
+ pnor_partition& part)
{
- fs::path tocFile = directory;
- tocFile /= PARTITION_TOC_FILE;
- allocateMemory(tocFile);
-
- std::ifstream file(tocFile.c_str());
static constexpr auto ID_MATCH = 1;
static constexpr auto NAME_MATCH = 2;
static constexpr auto START_ADDR_MATCH = 4;
static constexpr auto END_ADDR_MATCH = 6;
static constexpr auto VERSION_MATCH = 8;
+ constexpr auto versionShift = 24;
+
// Parse PNOR toc (table of contents) file, which has lines like :
// partition01=HBB,0x00010000,0x000a0000,0x80,ECC,PRESERVED, to indicate
// partition information
@@ -170,39 +168,51 @@ void Table::preparePartitions()
"^partition([0-9]+)=([A-Za-z0-9_]+),"
"(0x)?([0-9a-fA-F]+),(0x)?([0-9a-fA-F]+),(0x)?([A-Fa-f0-9]{2})",
std::regex::extended};
+
std::smatch match;
- std::string line;
- constexpr auto versionShift = 24;
+ if (std::regex_search(line, match, regex))
+ {
+ fs::path partitionFile = dir;
+ partitionFile /= match[NAME_MATCH].str();
+ if (!fs::exists(partitionFile))
+ {
+ MSG_ERR("Partition file %s does not exist", partitionFile.c_str());
+ return false;
+ }
+
+ writeNameAndId(part, match[NAME_MATCH].str(), match[ID_MATCH].str());
+ writeDefaults(part);
+ unsigned long start =
+ std::stoul(match[START_ADDR_MATCH].str(), nullptr, 16);
+ unsigned long end =
+ std::stoul(match[END_ADDR_MATCH].str(), nullptr, 16);
+ writeSizes(part, start, end);
+
+ // Use the shift to convert "80" to 0x80000000
+ unsigned long version =
+ std::stoul(match[VERSION_MATCH].str(), nullptr, 16);
+ writeUserdata(part, version << versionShift, match.suffix().str());
+ part.checksum = details::checksum(part.data);
+ }
+
+ return true;
+}
+
+void Table::preparePartitions()
+{
+ fs::path tocFile = directory;
+ tocFile /= PARTITION_TOC_FILE;
+ allocateMemory(tocFile);
+
+ std::ifstream file(tocFile.c_str());
+ std::string line;
decltype(auto) table = getNativeTable();
while (std::getline(file, line))
{
- if (std::regex_search(line, match, regex))
+ if (parseTocLine(directory, line, table.partitions[numParts]))
{
- fs::path partitionFile = directory;
- partitionFile /= match[NAME_MATCH].str();
- if (!fs::exists(partitionFile))
- {
- MSG_ERR("Partition file %s does not exist",
- partitionFile.c_str());
- continue;
- }
-
- writeNameAndId(table.partitions[numParts], match[NAME_MATCH].str(),
- match[ID_MATCH].str());
- writeDefaults(table.partitions[numParts]);
- writeSizes(table.partitions[numParts],
- std::stoul(match[START_ADDR_MATCH].str(), nullptr, 16),
- std::stoul(match[END_ADDR_MATCH].str(), nullptr, 16));
- writeUserdata(
- table.partitions[numParts],
- std::stoul(match[VERSION_MATCH].str(), nullptr, 16)
- << versionShift, // For eg, convert "80" to 0x80000000
- match.suffix().str());
- table.partitions[numParts].checksum =
- details::checksum(table.partitions[numParts].data);
-
++numParts;
}
}
diff --git a/pnor_partition_table.hpp b/pnor_partition_table.hpp
index d3d7fa4..6e9d2fa 100644
--- a/pnor_partition_table.hpp
+++ b/pnor_partition_table.hpp
@@ -144,6 +144,20 @@ class Table
const pnor_partition& partition(const std::string& name) const;
private:
+ /** @brief Parse a ToC line (entry) into the corresponding FFS partition
+ * object.
+ *
+ * @param[in] dir - The parent directory of the FFS partition files
+ * described in the ToC.
+ * @param[in] line - The ToC line to parse
+ * @param[out] part - The partition object to populate with the information
+ * parsed from the provided ToC line
+ *
+ * @returns True on success, false on failure.
+ */
+ bool parseTocLine(fs::path& dir, const std::string& line,
+ pnor_partition& part);
+
/** @brief Prepares a vector of PNOR partition structures.
*/
void preparePartitions();
OpenPOWER on IntegriCloud