2024-04-19 16:46:38 -05:00
|
|
|
#ifndef QL_MEMORY_BANK_CONFIG_SETTING_H
|
|
|
|
#define QL_MEMORY_BANK_CONFIG_SETTING_H
|
|
|
|
|
2024-05-05 23:21:36 -05:00
|
|
|
#include <cstdint>
|
2024-04-19 16:46:38 -05:00
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
struct QLMemoryBankPBSetting {
|
|
|
|
QLMemoryBankPBSetting(uint32_t n = 0) : num_wl(n) {}
|
|
|
|
uint32_t num_wl = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* A data structure to store QL Memory Bank configuration setting
|
|
|
|
*******************************************************************/
|
|
|
|
class QLMemoryBankConfigSetting {
|
|
|
|
public: /* Constructors */
|
|
|
|
QLMemoryBankConfigSetting();
|
|
|
|
|
|
|
|
public: /* Public Accessors */
|
|
|
|
QLMemoryBankPBSetting pb_setting(const std::string& name) const;
|
|
|
|
|
|
|
|
public: /* Public Mutators */
|
|
|
|
void add_pb_setting(const std::string& name, uint32_t num_wl);
|
|
|
|
|
|
|
|
private: /* Internal data */
|
|
|
|
std::map<std::string, QLMemoryBankPBSetting> settings_;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|