xilinx: rework program_spi method to uses new mcsParser features when extension == mcs
This commit is contained in:
parent
f349377f5f
commit
3706236b43
|
|
@ -656,11 +656,11 @@ void Xilinx::program(unsigned int offset, bool unprotect_flash)
|
|||
if (_mode == Device::SPI_MODE) {
|
||||
if (_flash_chips & PRIMARY_FLASH) {
|
||||
select_flash_chip(PRIMARY_FLASH);
|
||||
program_spi(bit, offset, unprotect_flash);
|
||||
program_spi(bit, _file_extension, offset, unprotect_flash);
|
||||
}
|
||||
if (_flash_chips & SECONDARY_FLASH) {
|
||||
select_flash_chip(SECONDARY_FLASH);
|
||||
program_spi(secondary_bit, offset, unprotect_flash);
|
||||
program_spi(secondary_bit, _secondary_file_extension, offset, unprotect_flash);
|
||||
}
|
||||
|
||||
reset();
|
||||
|
|
@ -766,15 +766,20 @@ float Xilinx::get_spiOverJtag_version()
|
|||
return version;
|
||||
}
|
||||
|
||||
void Xilinx::program_spi(ConfigBitstreamParser * bit, unsigned int offset,
|
||||
bool unprotect_flash)
|
||||
void Xilinx::program_spi(ConfigBitstreamParser * bit, std::string extention,
|
||||
unsigned int offset, bool unprotect_flash)
|
||||
{
|
||||
if (!bit)
|
||||
throw std::runtime_error("called with null bitstream");
|
||||
if (extention == "mcs") {
|
||||
McsParser *parser = (McsParser *)bit;
|
||||
SPIInterface::write(parser->getRecords(), unprotect_flash, true);
|
||||
} else {
|
||||
const uint8_t *data = bit->getData();
|
||||
int length = bit->getLength() / 8;
|
||||
SPIInterface::write(offset, data, length, unprotect_flash);
|
||||
}
|
||||
}
|
||||
|
||||
void Xilinx::program_mem(ConfigBitstreamParser *bitfile)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -31,8 +31,8 @@ class Xilinx: public Device, SPIInterface {
|
|||
~Xilinx();
|
||||
|
||||
void program(unsigned int offset, bool unprotect_flash) override;
|
||||
void program_spi(ConfigBitstreamParser * bit, unsigned int offset,
|
||||
bool unprotect_flash);
|
||||
void program_spi(ConfigBitstreamParser * bit, std::string extention,
|
||||
unsigned int offset, bool unprotect_flash);
|
||||
void program_mem(ConfigBitstreamParser *bitfile);
|
||||
bool dumpFlash(uint32_t base_addr, uint32_t len) override;
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue