blob: f7ff6d740c9d381dbcbc427c9adbd6a12d6f92f1 [file] [log] [blame]
#ifndef CONFIGURATION_PACKETS_H_
#define CONFIGURATION_PACKETS_H_
#include <array>
#include <map>
#include <memory>
#include <unordered_map>
#include "ecc.h"
#include "header.h"
class ConfigurationPackets {
public:
ConfigurationPackets(const std::string& arch);
static const std::unordered_map<std::string, size_t>
words_in_architecture;
static std::shared_ptr<ConfigurationPackets> InitFromFile(
const std::string& file,
const std::string& arch);
void AddAuxData(const std::string& file);
void WriteBits(std::ostream& out);
void SetBits(std::ifstream& ifs);
private:
using ConfigurationFrame = std::pair<uint32_t, std::vector<uint32_t>>;
using ConfigurationFrames = std::map<uint32_t, std::vector<uint32_t>>;
// Refer to UG470 page 109 for address of configuration registers and
// commands
const uint32_t kCmdWrite = 0x30008000;
const uint32_t kFdriWrite = 0x30004000;
const uint32_t kFarWrite = 0x30002000;
const uint32_t kCrcWrite = 0x30000000;
const uint32_t kNop = 0x20000000;
const uint32_t kFarReg = 0x1;
const uint32_t kFdriReg = 0x2;
const uint32_t kCmdReg = 0x4;
const uint32_t kWcfgCmd = 0x1;
// Writing the RCRC(0x7) command in type 1 packet with 1 word to the CMD
// register (0x30008001)
const std::array<uint32_t, 2> kRCrcCmd = {{0x30008001, 0x7}};
size_t words_per_frame_;
std::string architecture_;
ConfigurationFrames configuration_data_packets_;
std::vector<uint32_t> fpga_configuration_head_;
std::vector<uint32_t> fpga_configuration_tail_;
std::unique_ptr<Header> header_;
ECC ecc_;
void InitializeConfigurationData(const std::string& line);
void InitializeFpgaConfigurationHead(const std::string& line);
void InitializeFpgaConfigurationTail(const std::string& line);
void InitializeHeader(const std::string& line);
uint32_t GetCRC(ConfigurationFrames::const_iterator frame_citr,
bool is_new_row = false) const;
uint32_t GetFpgaConfigurationCRC() const;
void UpdateECCs();
void SetBit(const std::string& line);
void WriteConfiguration(std::ostream& out);
void WriteFpgaConfiguration(std::ostream& out,
const std::vector<uint32_t>& vect);
void WritePacket(std::ostream& out,
ConfigurationFrames::const_iterator frame_citr) const;
bool IsDifferentRow(
ConfigurationFrames::const_iterator frame_citr1,
ConfigurationFrames::const_iterator frame_citr2) const;
void Line2Vector(const std::string& line, std::vector<uint32_t>& vect);
};
#endif // CONFIGURATION_PACKETS_H_