| // Copyright 2021 The Chromium OS Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef RMAD_UTILS_VPD_UTILS_H_ |
| #define RMAD_UTILS_VPD_UTILS_H_ |
| |
| #include <map> |
| #include <string> |
| #include <vector> |
| |
| namespace rmad { |
| |
| class VpdUtils { |
| public: |
| VpdUtils() = default; |
| virtual ~VpdUtils() = default; |
| |
| // Get the serial number of the device from vpd. |
| virtual bool GetSerialNumber(std::string* serial_number) const = 0; |
| |
| // Get the whitelabel tag of the device from vpd. |
| virtual bool GetWhitelabelTag(std::string* whitelabel_tag) const = 0; |
| |
| // Get the region of the device from vpd. |
| virtual bool GetRegion(std::string* region) const = 0; |
| |
| // Get values from |entries| of the device from vpd and save it to |
| // |calibbias|. If there are any errors, leave |calibbias| untouched. |
| // Return true if it succeeds for all entries, otherwise return false. |
| virtual bool GetCalibbias(const std::vector<std::string>& entries, |
| std::vector<int>* calibbias) const = 0; |
| |
| // Save the serial number in the cache until flush is called and set to vpd. |
| // Return true if it succeeds, otherwise return false. |
| virtual bool SetSerialNumber(const std::string& serial_number) = 0; |
| |
| // Save the whitelabel tag in the cache until flush is called and set to vpd. |
| // Return true if it succeeds, otherwise return false. |
| virtual bool SetWhitelabelTag(const std::string& whitelabel_tag) = 0; |
| |
| // Save the region tag in the cache until flush is called and set to vpd. |
| // Return true if it succeeds, otherwise return false. |
| virtual bool SetRegion(const std::string& region) = 0; |
| |
| // Save |calibbias| to |entries| of the device in the cache until flush is |
| // called and set to vpd. |
| // Return true if it succeeds, otherwise return false. |
| virtual bool SetCalibbias(const std::map<std::string, int>& calibbias) = 0; |
| |
| // Since setting the value to vpd requires a lot of overhead, we cache all |
| // (key, value) pairs and then flush it all at once. |
| virtual bool FlushOutRoVpdCache() = 0; |
| virtual bool FlushOutRwVpdCache() = 0; |
| |
| protected: |
| // Set multiple (key, value) pairs to RO VPD. Return true if successfully set |
| // all values, false if any value fails to be set. |
| virtual bool SetRoVpd( |
| const std::map<std::string, std::string>& key_value_map) = 0; |
| |
| // Get the value associated with key `key` in RO VPD, and store it to `value`. |
| // Return true if successfully get the value, false if fail to get the value. |
| virtual bool GetRoVpd(const std::string& key, std::string* value) const = 0; |
| |
| // Set multiple (key, value) pairs to RW VPD. Return true if successfully set |
| // all values, false if any value fails to be set. |
| virtual bool SetRwVpd( |
| const std::map<std::string, std::string>& key_value_map) = 0; |
| |
| // Get the value associated with key `key` in RW VPD, and store it to `value`. |
| // Return true if successfully get the value, false if fail to get the value. |
| virtual bool GetRwVpd(const std::string& key, std::string* value) const = 0; |
| }; |
| |
| } // namespace rmad |
| |
| #endif // RMAD_UTILS_VPD_UTILS_H_ |