Skip to content

Releases: trabucayre/openFPGALoader

nightly

30 Dec 10:03
c35d174
Compare
Choose a tag to compare
nightly Pre-release
Pre-release
Merge pull request #503 from chenrui333/add-ubuntu-24

ci: add ubuntu 24

v0.13.1 release

31 Dec 21:03
Compare
Choose a tag to compare

Evolution summary:

Core

Fix

  • CMakeLists.txt: fix release number

Contributors

v0.13.0 release

31 Dec 17:50
Compare
Choose a tag to compare

Evolution summary:

core

new

  • main: In help output, show how to detect flash
  • main: add 'user-flash' CLI argument

update

  • main: added default value for user_flash in struct arguments args
  • CMakeLists.txt: switch prio between hidapi-libusb and hidapi-hidraw: fix issue on WSL2 with cmsisdap (#413)

fix

  • main,spiFlash,xilinx: fix warnings

board

new

  • KNJN Dragon-L PCI Express & HDMI FPGA board (Spartan6 xc6slx25tcsg324)
  • Numato Systems Mimas A7 board.
  • Zetta ZD25WQ16CSIGT
  • Add support for VCU108 board and Virtex UltraScale
  • AMD Virtex 7 FPGA VC709 Connectivity Kit Board
  • CERN SPEC45 support
  • lilygo-t-fpga board (based on gwu2x #434)
  • Trenz cyc5000

cable

new

  • configBitstreamParser: added static method to switch bits for 32bits value
  • libusb_ll: rework. Splitted scan method -> help futur dev with a common code to detect/select usb devices
  • Gowin GWU2X USB (JTAG mode) (#434)

update

  • libgpiodJtagBitbang: simplify code by using less structures

part

new

  • Altera Max II EPM240T100C5N Board
  • Altera Update Max II and Cyclone II documentation (#493)
  • Altera Cyclone II
  • Altera MAX10M40SCE144C8G
  • Altera Max10 10M16SAU169C8G support (Used by LimeSDR Mini V1).
  • Altera EP4CE6E22 and EP4CE10F17
  • Altera EP4CGX150
  • Altera Stratix V GS D5
  • Efinix Titanium Ti180
  • Gowin: GW1N9 detection
  • Gowin GW2A-55
  • Xilinx spartan6 LX25T (xc6slx25T)
  • Xilinx xc7vx690t
  • Xilinx XC2C64A-xVQ44 with ID 0x06e5e093 (#458)
  • Xilinx xc2c64a QFN48
  • Xilinx adding support for the xc7z030
  • Xilinx xc6slx45t
  • Xilinx Spartan7 xc7s6 variant
  • Xilinx xcau15p.

part driver

  • Altera: first draft to have a native support for max10 family (only internal flash with POF file)
  • Efinix: add support for flash detect and flash dump in SoJ mode
  • Efinix: do not allow untested detect_flash() non-SoJ path until someone tries it out for sure
  • Gowin: Implement user flash programming for GW1N9
  • Gowin: added detect_flash/erase_flash for gw2a FPGAs
  • Gowin: Use std::unique_ptr instead of manual RAII
  • Lattice: added support for reset method (only tested with ECP5
  • Xilinx: added WBSTAR & BOOTSTS register read/decode. Fixed dec/hex format and padding
  • Xilinx: added readback access to registers (stat, conf, ...)
  • Xilinx: Add XADC reads of VCC registers

update

  • programSPI return type void -> bool
  • programJTAG return type void -> bool
  • program: thow exception when something fails
  • Xilinx: replaced reverseWord by configBitstreamParser::reverse_32

fix

  • Xilinx: fix read_dna and read_xadc typo
  • fixed warning in read_registers

spiFlash

new

  • added M25P32 chip
  • added IS25LP256D chip support
  • added TI M25P80 (0x202014)
  • added some flash's datasheet link
  • added quad bit mask and corresponding register
  • added configuration/nonvolatile configuration register for spansion and micron SPI Flash
  • added quad support for S125FL
  • added method to enable/disable Quad mode support
  • added MX25L enable/disable quad + display status register
  • added S25FL128S display register
  • core,xilinx,device: added option/methods to enable/disable quad mode on SPI Flash
  • all devices / spiInterface / main: added method / infra to detect flash chip with --detect -f

update

  • added ask before writting TB when OTP, added missing write_enable and fixed mask
  • enable_protection/disable_protection: uses mask to only deal by bp
  • read_id: display jedec ID. display_status_reg small fixes
  • display_status_reg simplify again
  • added get_bp_mask to return default bp mask (unknown device) or compute mask based on bp_offset. Replace all manual mask compute. (#468)
  • reorder entries, reformat

fix

  • removed unused variable (#468)
  • 0x0000 is not a valid jedec id

spiOverJtag

new

  • added basic efinix build script (WIP)
  • Xilinx spartan7 xc7s6ftgb196 bitstream
  • Xilinx Spartan6 xc6slx25csg324
  • Xilinx Spartan6 model: 25T package: CSG324 (xc6slx25tcsg324)
  • Xilinx Spartan6 xc6slx45tfgg48 support
  • Xilinx Artix xc7a200tfbg676 support (tested on hardware).
  • Xilinx support and bitstreams for xcku040 and xcku060
  • Efinix Titanium Ti180J484
  • Efinix Trion t13f256 SPI flash support

doc

new

  • Efinix Titanium Ti180
  • add flash compatibility for Xilinx Kintex UltraScale. Tested on KCU105 primary qspi.
  • install.rst: instructions to install under Guix
  • Gowin GW2A-55
  • Xilinx xc6slx45t
  • Xilinx xcau25p

update

  • help output
  • install.rst

Contributors

v0.12.1 release

23 Mar 17:31
Compare
Choose a tag to compare

Evolution summary:

part

fix

  • lattice,xilinx: fix uint64_t print format: lld -> PRIx64
  • gatemate: fix unintended gpio access with dirtyJtag cables
  • gatemate: remove flash reset, power_up and read_id duplicates
  • gatemate: fix CFG_MD typos
  • gatemate: fix passive spi segfaults and improve verbosity
  • gatemate: fix jtag-spi-bypass with dirtyJtag

spiFlash

new

  • MX25R6435F

fix

  • spiFlashdb: MX25R6435F: added missing bp bit 4
  • SPIFlash::bp_to_len

Contributors

v0.12.0 release

09 Mar 09:28
Compare
Choose a tag to compare

Evolution summary:

core

new

  • CMake: bump the minimal required version to 3.5
  • Add WebAssembly support.
  • ftdiJtagMPSSE,jtag,jtagInterface: allows to force read/write edge configuration (useful to mimic SPI through JTAG)
  • ftdiJtagMPSSE,jtagInterface: {set|get}{Read|Write}Edge signature
  • Add user device list for non-fpga JTAG devices

update

  • jtag: rework detectChain: try unmasked idcode first
  • jtag: update JTAG chain detect
  • jtag: move JTAG chain bit init to device_select()

fix

  • jtag: shiftDR: (fix daisy chain) when more than one FPGA, a sequence of '0' before and/or after must be sent instead of '1' (fix #189 and #133
  • jtag: fix state machine (issue introduce by commit 9e91c3)
  • make IDCODE unsigned
  • macos workflow
  • drop mingw w32

board

new

  • Gaisler gr740-mini
  • QMTECH cyclone10 LP starter kit (10CL016YU484C8G)
  • @lambdaconcept ecpix5_r03 (ft4232)
  • SiPEED tang Primer 25K
  • SiPEED tang Mega 138K
  • Digilent cmoda7_15t
  • ALINX AX7102 board.
  • ALINX AX7101 board.
  • Avnet Mini-ITX
  • pynq-z1 board
  • Cern VEC_V6 Board
  • Cern VMM3 board
  • Antmicro DDR4 Tester board
  • Antmicro DDR5 Tester board
  • Antmicro LPDDR4 Tester board
  • trion_t20_bga256_jtag support
  • Xilinx KCU105 (Kintex Ultrascale xcku040)
  • AMD Virtex UltraScale+ FPGA VCU1525 Acceleration Development Kit
  • Add GD32VF103 to misc devices
  • Trenz TE0712-8 Board (XC7A200TFBG484)
  • Trenz TEC0330 board
  • Olimex GateMate A1 EVB

update

  • Lattice: nexus boards: change from CABLE_DEFAULT (i.e. 6MHz) to CABLE_MHZ(1) (i.e. 1MHz) as at 6MHz the download of bitstreams is not stable.

files

new

  • fsParser: adding GW5A-25 IDCODE
  • latticeBitParser: add support for loading Lattice (Nexus) encrypted bitstreams, by adding key and preamble of encrypted bitstreams to if statements.
  • latticeBitParser: add ECP3 VERIFY ID support (avoid to fail with bitstream)

cable

new

  • FTDI FT4232HP mapping
  • efinix jtag ft2232 variant
  • Add faulty MPSEE cmd 8E workaround

update

  • drop div_by_5 to allow 2.5MHz clock
  • Make CH347 driver faster Speed up toggleClk
  • update CH347 (#424)
  • xvc client: ensure send() entire buffer
  • xvc client: handle failed ll_write()
  • all jtag cable: no more hardcoding tdi bit with writeTMS

fix

  • DFU: fix code to accept tinyDFU implementation (where not altsettings have an DFU descriptor)
  • svf_jtag: fix -Wmismatched-new-delete delete -> delete[]

part

new

  • main: allows mcufw only mode for gowin
  • Lattice: Add all MachXO[23] part IDs
  • Lattice: improve info about "BSE Error Code" from Device Status Register
  • Lattice: machXO3: re-add partially revision
  • Gowin: add known ID codes for GW5 series
  • Gowin: add preliminary support for GW5AST-138
  • Gowin: GW5A SPI flash support
  • Gowin: Fix status register parse for GW5AST
  • Gowin: avoid multiple status register access
  • Gowin: Fix clk cycle after sending a command, don't read status register programSRAM sequence
  • Gowin: mcufw may be written without fs (but this erase all memory)
  • Gowin: detectFamily new function
  • Xilinx: add jtag->flush before sleep
  • Xilinx: Add Kintex Ultrascale+ KU3P ID-Code.
  • Xilinx: xczu17eg. It's tested on xczu17eg board with Digilent HS3 at 30Mbps.
  • Xilinx: XADC and DNA for Xilinx FPGA (#407)
  • Xilinx: xcku115 to parts list (#394)
  • Xilinx: Add remaining ZynqMP IDs
  • Xilinx: Add xc7k70t and small fixes for xc7k160t
  • Xilinx: Virtex 7 xc7vx330t

update

  • part: Add separator for each chip family.
  • part: Reorder families (older first, smaller first) and minor alignment cleanups.
  • part: Add separator for each vendor.
  • Altera/Intel: update idcode (same idcode for III/IV/10 LP)
  • Lattice: 0x012bc043 is for LCMXO2-4000HC
  • Lattice: restore bypass instruction in clearSRAM()
  • Lattice: spi_put: avoid loop when tx == NULL
  • Lattice: programming and add nexus boards
  • Gowin: GW5A/SPI flash: adding delay after erase flash and after SPI mode instruction. Seems fixed write error.
  • Gowin: displayReadReg update. Now GW5A field are correctly displayed
  • Gowin: Rewrite algorithms
  • Xilinx: Fix XC2 ident.

fix

  • Altera,Efinix,Gowin,Xilinx: Fix 'Flash SRAM' -> 'Load SRAM'
  • Gowin: fix flash erase for GW1NSR-4C: during shiftDR sequence TDI MUST be 0x0000
  • Gowin: writeFLASH: increase delay before CRC check (required for 9K device)
  • Gowin: try second eraseSRAM before writeSRAM. Not always working but better...
  • Gowin: GW5AST work around
  • Gowin: programFlash/writeFlash: disable previous rewrite (fix write with tangnano4k)
  • Gowin: fix gw1n external flash access
  • CologneChip: gatemate: do not call ftdi-related routines when using alternative cables
  • CologneChip: gatemate: fix configuration in jtag chains
  • CologneChip: gatemate: use more suitable change to RUN_TEST_IDLE state
  • Lattice: nexus family: REFRESH (plus config logic reset) in case of fpga in error state and add capabilities to handle the whole 64-bits status register
  • Lattice: fix bscan width and other minor things for NEXUS family
  • Lattice: fix the warning "left shift count >= width of type" shown in win32/64 builds
  • Lattice: fix bscan register initialization inside clearSRAM()
  • Lattice: correct mask for sram erase for NEXUS_FAMILY, as it is 0x00
  • Fix SRAM loading on invalid flash

spiFlash

new

  • Macronix MX25L51245G (CertusPro Versa board and gr740-mini)
  • Micron MT25/N25Q128_1_8V (Lattice Certus Versa and CertusPro eval boards) and distinguish between N25Q128 1.8V and 3V memories
  • S25FL128L flash
  • Macronix MX25L3233F used on Cmod A7-35T
  • N25Q256A

fix

  • ftdispi: add missing status_pin
  • ftdipp_mpsse: fix format-zero-length snprintf -> memset

spiOverJtag

new

  • Xilinx : xcku3p_ffva676 support.
  • Xilinx : xc7a35tfgg484 support.
  • Xilinx: xc7a15tcpg236 support
  • Xilinx: xc7k70tfbg484 support
  • Xilinx: add constr_xc7k_fbg676.xdc
  • Xilinx: Virtex6: Add spiOverJtag for Virtex6, detect xc6vlx130 and provide bitfile for xc6vlx130tff784
  • Xilinx: Virtex 7 xc7vx330tffg1157
  • Intel/Altera: cyclone10 LP 10CL016YU484C8G

update

  • compress spiOverJtag for Darwin too
  • remove obsolete xc6 directory
  • Xilinx: Update code since Virtex Ultrascale has apparently been replaced with Xilinx Ultrascale.
  • Xilinx: Rearrange for better extensibility - Use ifdef ... elsif ... `endif for better seperation
  • Xilinx: XC6SLX...L may need other pin constraints as XC6SLX... - Checked and handled for XC6Sxxx(T)fgg484

fix

  • Xilinx: fix errors on xc6slx150tfgg484
  • Xilinx: add missing xc6s_tqg144 constraint

doc

new

  • board: Avnet Mini-ITX Base Kit
  • part: Gowin GW5A serie
  • part/board: certus boards/parts entries
  • cable: FT4232HP cable/interface.

update

  • data: adding an (unused for now) SPIFlash entry

fix

  • board: fix wrong constraints link
  • board: fix efinix naming / mode

Contributors

v0.11.0 release

02 Aug 09:23
Compare
Choose a tag to compare

Evolution summary:

core

new

  • CMakeLists: add an option to enable/disable -O3 optim (enabled by default)
  • option to use an extra GPIO as the status indicator

update

  • CMakeLists: when gzip is available spiOverJtag .bit and .rbf are compressed before installing
  • ftdipp_mpsse: adding bus_addr, device_addr getters
  • args: better --offset description (#319)
  • main: parse_opt: busdev-num: explicitly set hex base
  • jtag: adding getter to lowlevel transport driver
  • DATA_DIR override with environment variable (#333)
  • README,main: add remote bitbang for ip and port
  • Replace the string arguments usage with a bitfield
  • cleanup/lint/cppcheck
  • verbose: small rework

fix

  • scripts/msys2/PKGBUILD: try to fix previous commit (gzip)
  • workflows: removing ubuntu 18.04 (obsolete) adding 22.04
  • workflows: fix again ubuntu version
  • libusb_ll: fix typo in scan method
  • main: deduplicate messages about board's default cable/user's selection, display warn always instead of when verbose mode is set.
  • Tell USB bus and address when ftdi open fails.
  • Parse USB bus:dev as decimal integers, to be consistent with --scan-usb.

board

new

  • sipeed tang nano 20k
  • Added Lone Dynamics Schoko and Konfekt SBCs
  • colorlight-i9+ board
  • Trenz TEI0010 - AnalogMax
  • adding Opal Kelly XEM8320 board
  • Add Support for Xilinx KCU116 (#322)
  • added support for 14bits 125MHz redpitaya board (7010)
  • add Sitlinv STLV7325
  • add support for Trenz C10LP-RefKit
  • hseda-xc6slx16

files

update

  • bitparser: check bitstream length in the file
  • bitparser: replace _raw_data.size() with _file_size
  • fsParser: fix usercode/checksum size
  • latticeBitParser: add SPI_MODE missing instruction (issue #324)

cable

new

  • remoteBitbang_client: adding new protocol (client side)
  • WCH CH347T(mode #3) JTAG cable

update

  • usbBlaster: add option to fix firmware path at build time
  • Allow VID:PID override for JLink probe
  • jlink: suport writeTDI() with tx=NULL
  • jlink: report skipped devices with verbose
  • jlink: support J-Link BASE and J-Trace PRO
  • libgpiod: v2 api support

fix

  • fix: fix cmsisdap support for macOS
  • usbBlaster: change tx_len size (16 -> 32) to fix a potential overflow when log2(xfer_len) > 16 in toggleClk method
  • xvc_server: don't stop when connection close, rework read to return code for error and for disconnect
  • xvc_server: fix comm when Vivado acts as client
  • usbBlaster,ftdiJtagMPSSE: fix alignment for 1 bit len read transaction
  • dirtyJtag: throw exception when getVersion fails, use a #define for TIMEOUT value
  • cable: bus_addr, device_addr: int -> uint8_t
  • xvc_server: catch exception

part

new

  • Add Support for Xilinx Artix-7 a25t (xc7a25t)
  • Add support for XCVU9P IR length and codes
  • Add target-flash and secondary-bitstream CLI options for VCU118
  • Add ID code for part xa2c64a (Coolrunner-II).
  • Add initial support for VCU128
  • part: Add all cyclone V variant board: Add the Terasic C5G
  • Intel MAX10 (10M08)
  • add LCMXO2-256HC, update doc/FPGAs
  • Artix+ AU25P support for Opal Kelly Board
  • gowin: merge CRC check into one method, check usercode/checksum as fallback when usercode register doesn't match computed file's checksum (issue #279)
  • efinix: in JTAG mode keep bus_addr, device_addr between jtag and spi interfaces
  • efinix: in jtag mode fix access to the ll driver
  • parts: fix Efinix titanium irlen
  • Add initial support for VCU128
  • gowin: fix typo

update

  • Add support for flashing UFM on MachXO2 using JEDEC file. (#339)
  • efinix: support using JTAG interfaces
  • lattice: bypass refresh instruction for machXO2
  • xilinx: rework error message for zynqXX in SPI_MODE
  • lattice: when loadConfiguration fails -> check if external flash is blank
  • skip_load_bridge and skip_reset arguments also for Xilinx devices

fix

  • Fix off-by-one errors in calculating UFM start page.
  • Only delete bitstream objects if non-null
  • Fix VCU118 board part name and IR length
  • efinix: fix JTAG: detect family, fix irlen for titanium, add support for bit file, hex file can't be used with titanium
  • lattice: fix cast int vs uint8_t
  • lattice: UFM printf -> printInfo

spiFlash

new

  • MT25QU01 flash support
  • ST M25P16 flash support
  • ST M25P16 flash support
  • Macronix MX25L12833 flash support
  • Windbond w25q80bv flash support

update

  • Add support for 4-byte QSPI flash addressing (#295)
  • spiInterface: add read method

fix

  • temporary disable read extended

spiOverJtag

new

  • spiOverJtag_xc7a50tfgg484
  • spiOverJtag_xc7a200tfbg484
  • package xc7a (fbg484)
  • Spartan-6 lx9 CSG324 package.
  • Add XCVU9P spiOverJtag bitfile with SPIx8 support
  • Bitfile and constraints for xc6slx150tcsg484. (#312)
  • Add flash support for VCU128
  • efinix: - jtag mode: added spiOverJtag support; - spiOverJtag: added efinix support: verilog file and t8f81 bitstream - xyloni: part code for spiOverJtag flash access/load bridge
  • added efinix Titanium Ti60 support

update

  • spiOverJtag: ignore .bit and .rbf files

fix

  • fix missing spiOverJTAG for C10LP-RefKit

doc

new

  • Add documentation for Xilinx SPIx8 mode
  • xilinx: zynq limitation/requirement note
  • boards.yml: Add C5G

update

Contributors

v0.10.0 release

21 Dec 20:46
Compare
Choose a tag to compare

Evolution summary:

core

new

  • main: add busdev-num option to select a probe by his bus number / device address
  • libusb_ll: libusb wrapper (currently limited to scan device), src/main: add scan-usb option
  • libusb_ll: adding a libusb_open() return code check: when fails skip rest of the loop

update

  • src/main: simplify svf type search
  • svf: now is device independent and parsing is improved
  • pathHelper: Only compile on win builds

fix

  • removing test_sfl.svf
  • libusb_ll: typo (ft2232RL -> ft232RL). Fix #276
  • ftdispi: typo: replace holdn by wpn for spi_config.wpn_pi (fix issue #277).
  • ftdipp_mpsse: bus/addr: change type to uint8_t, default value to 0 and use cable_t bus_addr/device_addr$
  • msys2: Fix absolute windows paths
  • typo

board

new

  • LiteX-Acorn-Baseboards support
  • ALINX AX516 board.
  • Digilent CmodA7-35T fpga board
  • USRP X300 and X310
  • VCU118 board
  • Digilent nexys A7 (50/100) aka nexys 4 DDR
  • Alchitry Au+
  • Digilent CMOD S7 board.

cable

new

  • add cable jetson-nano-gpio

update

  • src/cable: rename bus/device to bus_addr/device_addr
  • cable implementation: rework to use cable_t directly
  • xvc_client: allows to select port
  • src/cable: rework cable list. move vid/pid from mpsse_bit_config to cable_t

part

new

  • Add support for Xc6slx9tqg144 FPGA

update

  • lattice: allows to use bit file for machxo2
  • altera,intel/Xilinx: adding an option to bypass spiOverJtag automatic bitstream selection by providing the bitstream file path

fix

  • xilinx: zynqXX: load only (#268)

files

new

  • pofParser: introducing intel/altera POF file parser

update

  • latticeBitParser: support machxo2 (check compress & fill vector)

spiFlash

new

  • microchip SST26VF064B flash

update

  • limit automatic read burst length to 64K
  • add --bulk-erase command line option

fix

  • Fix return value checking polarity and error reporting in protect_flash() and unprotect_flash()

spiOverJtag

new

  • spiOverJtag_xc7a50tcsg324
  • spiOverJtag_xc7s25csga225
  • spiOverJtag_xc7s_csga225

doc

update

  • Updated Troubleshooting

fix

  • Simplified troubleshooting .rst and removed media

Contributors

v0.9.1 release

19 Sep 19:03
Compare
Choose a tag to compare

Evolution summary:

core

update

  • add specific -D to enable/disable --device arg

cable

new

  • lpc-link2
  • Steppenprobe

update

  • cmsisDAP: allows to select interface number

fix

  • main,board,ftdiJtagBitbang: use pin ID instead of shift (issue #249)
  • libgpiodJtagBitbang: fix warning
  • ftdiJtagBitbang: fix int vs uint32_t

part

new

  • Xilinx: Kintex UltraScale KCU035
  • Gowin: add MSPI support when GW2A (issue #250)

fix

  • Xilinx: flow_program/xc95: increase delay and use getClkFreq (issue #104)
  • Xilinx: flow_program/xc95: verify write: replace hardcoded number of sections by nb_section
  • Gowin: better error message when mismatch between fs idcode and target's idcode (issue #252)

doc

update

  • doc/guide/install: add a note about Linux group right (issue #245)

fix

  • doc/guide/advanced: fix sphinx warning

Contributors

Maciej Nowak (@Novakov)
Diego Herranz (@diegoherranz)

v0.9.0 release

26 Jul 19:17
Compare
Choose a tag to compare

Evolution summary:

core:

new

  • main: always check if board is not null before access
  • add skip_load_bridge cmd-line parameter
  • ftdiJtagMPSSE: add writeTMSTDI method with full tms & tdi buffer. Always return TDO buffer
  • add means to set cable index from command line

update

  • ftdipp_mpsse: robustness: check all function return code / improve a bit error message
  • ftdipp_mpsse: change verbose level
  • ftdipp_mpsse: don't throw exception when iProduct is empty: display warn and use empty string
  • ftdiJtagxx: check lowlevel init return value
  • jtag: when verbose > 1: display unfiltered/raw IDCODE
  • add option to bypass reset in SPI write mode. Adapt altera accordingly
  • stop using get_state and promote the use of get_status

fix

  • Use uint32_t for misc_dev_list (fixes #196)
  • CMakeLists: fix general code styling, use dynamic linking on macOS
  • ftdipp_mpsse: don't display error when attach kernel driver, when the device hasn't been detach before or when driver isn't loaded.
  • spiInterface: unprotect_flash: fix return. Improve messages
  • ftdispi: add missing index param
  • fix(part.hpp): use uint32_t instead of int for fpga_list index

cable

new

  • xvc_client/xvc_server: Xilinx Virtual Cable
  • libgpiod JTAG driver

update

  • cmsisDAP: better error message if support is not enabled
  • anlogicCable: remove unused verbose, tdi, tms
  • jlink: write_data -> writeTMSTDI. Fix behaviour
  • DFU: check iProduct and iInterface -> set to a default string when empty
  • DFU: display error code

fix

  • cmsisDAP: fix crash in case hid device cannot be opened
  • DFU: fix detect -> bypass bitstream
  • DFU: fix potential leak
  • add missing mpsse_bit_config index
  • jlink: check usb_claim error

board

new

  • ORBTrace Mini support (DFU mode)
  • Add initial support for ZCU106 development board
  • Support for the Papilio One board
  • Sipeed Tang Primer 20K (GW2A)

fix

  • gatemate: fix failed signal polarity and update documentation

part

new

  • intel: cycloneV 5CEBA9 entry (issue #213)
  • intel: cycloneIV EP4CE115
  • Xilinx: Kintex XC7K410T
  • Xilinx: Kintex XC7K420T
  • Xilinx: ZynqMP Ultrascale Plus XCZU11EG
  • Xilinx: Kintex Ultrascale XCKU040
  • Xilinx: explictly add spartan3e and xc3s250e
  • Gowin: GW2A (GW2A(R)-18(C))

update

  • Gowin: GW1NSR-4C: Add MCU Firmware flashing support
  • xc3s500e IDCODE: revision set to zero.

fix

  • Correct part number for ZCU106 board

update

  • efinix: support loading a bitstream to memory using only JTAG pins (no GPIO).
  • --flash-sector CFG0 for MachXO3D and more information for its Breakout Board
  • colognechip: explicitly set spi or ftdi_jtag to null, drop useless else if -> if not spi it must be jtag
  • xilinx: adapts flow_disable/flow_enable for xc3s, adding custom method to load bitstream for xc3s

fix

  • colognechip: fix dumpFlash: add override, remove filename param and use filename from constructor
  • efinix: fix dumpFlash: add override, remove filename param and use filename from constructor
  • part: re-adding version nibble to remove ambiguities between U, UM and UM5G
  • xilinx: fix wait until done for spartan3e
  • lattice MACHXO3D: no exception when flash-sector is not provided in SRAM mode

files

fix

  • efinixHexParser: remove unused reverseOrder
  • configBitstreamParser: string::find return size_t not uint32_t
  • latticeBitParser: when .bit is encrypted use Part: from header to retrieve idcode
  • latticeBitParser: fix end header position with MACHOX3D .bit file
  • ihexParser: check buffer size, increase if required

spiFlash

new

  • N25Q64 part
  • S25FL512S part
  • Support for the Microchip SST25VF040B flash.

update

  • handle case where TB is not configurable
  • Removed TOP/BOTTOM settings from SST25VF040B
  • Removed must_relock part for the "SST25VF040B"

fix

  • bulk_erase: check bp before erase
  • stop if jedec_id == 0xffffff
  • fix display: when bp_len==0 -> set bp/tb = 0, otherwise parse reg

spiOverJtag

new

  • cycloneV 5CEBA9F27
  • cycloneV enable init done pin
  • cyclone IV EP4CE115F23
  • artix fgg676 constraints file
  • artix xc7a100tfgg676
  • kintex support xc7k420tffg901
  • kintex support xc7k160tffg676
  • Spartan3E (xc3s500evq100)

update

  • update spiOverJtag_5ce927.rbf.gz created with Lite 20.1.1

doc

  • FPGA: add 5CEBA9
  • README: add skip-load-bridge / skip-reset
  • guide: Add instructions for manual installation on macOS
  • Documentation for the xc3s500e part

update

  • FPGA: update/fix ECP5 list

fix

  • intel: fix svf generation command (issue #212)

Contributors

v0.8.0 release

19 Mar 09:38
Compare
Choose a tag to compare

Evolution summary:

core:

new

  • part: add map manufacturer id <-> name
  • jtag: adding method to inject device into active device list
  • ftdi MPSSE / jtag: add option to use neg edge for TDO's sampling
  • xilinx: adding zynqmp support and a method to init this family of devices

update

  • jtag: better display for unknown IDCODE
  • jtag: improving jtag chain detection: now searching for masked and unmasked idcode
  • display: use a less dark blue
  • Nicer layout for the boards/fpga/cables table
  • main: bitstream default target depends on mode spi/jtag

fix

  • ftdiJtagMPSSE: fix read/write polarity: always write on neg, read is by default on pos but may on neg with arty
  • Darwin cmake config is missing Security framework
  • ftdiJtagMPSSE,ftdipp_mpsse: fix verbose level -> must be an int8_t not uint8_t
  • jtag: fix shiftIR: bypass_after must be computed in all case

cable

new

  • digilent jtag-smt2-nc
  • Olimex ARM-USB-OCD-H
  • SEGGER J-Link

board

new

  • alinx AXU2CGA
  • Xilinx AC701 development kit
  • Xilinx/TUL PYNQ-Z2
  • Xilinx Zynq-7000 SoC ZC702 Evaluation Kit
  • Xilinx Zynq-7000 SoC ZC706 Evaluation Kit
  • Xilinx ZynqMPSoC ZCU102 Evaluation Kit
  • CERN SPEC150
  • colorlight-i9
  • digilent genesys2
  • digilent zybo_z7 10/20
  • QMTech qmtechCycloneV_5cefa5f23 board
  • QMTech Kintex7 Core Board
  • sipeed tangnano1k
  • sipeed tangnano9k
  • Terasic DE1-SoC board

part

new

  • Xilinx Spartan6 xc6slx150T
  • Xilinx Kintex 160T
  • Xilinx Zynq XC7Z045
  • Xilinx ZynqMPSoC XCZU2CG
  • Xilinx ZynqMPSoC XCZU9EG
  • Gowin GW1NZ-1
  • Gowin GW1NR-9C
  • Altera CycloneV 5CEFA5
  • Altera CycloneV SoC 5CSEMA5

update

  • ice40: add CRAM support

fix

  • ice40: Add override specifier to resolve compiler warnings

spiFlash

new

  • Spansion S25FL256S
  • Spansion S25FL256L
  • Microchip SST26VF032B

update

  • spiFlash: add no block protect use case

fix

  • spiFlash: when no subsector_erase compute end_addr with correct block size
  • spiFlashdb: fix bp_offset list
  • spiFlash: force subsector only for SST26VF032B
  • spiFlash: fix overflow test (#172)

spiOverJtag

new

  • Xilinx spartan6 FTG 256 ucf
  • Xilinx spartan6 LX16 FTG256
  • Xilinx spartan6 LX16 CSG324
  • Xilinx Spartan6 LX150T
  • add spiOverJtag build process for Kintex7 ffg900-2 packages, amend and extend build process for ff676-1 package
  • Add spiOverJtag support for Xilinx xc7k325tffg676 part.
  • spiOverJtag/spiOverJtag_5cefa5f23.rbf.gz bitstream to write flash

update

  • compress the kintex7 bitstreams

CI

new

  • add CI for macOS
  • use reusable composite action and reusable workflow from msys2/setup-msys2

fix

  • fix msys2 build failure
  • fix step 'Show package content'

doc

new

  • FPGAs: ice40 memory support
  • cable: move to yml
  • declare board compatibility through a YAML file
  • declare FPGA compatibility list through YAML file
  • conf: add intersphinx mapping 'constraints'
  • cross-reference FPGA compatibility table and vendor notes
  • boards: iCE40UP5K-B-EVN
  • cable: RV-Debugger-BL702

update

  • board: add field 'Constraints'
  • install.rst
  • boards: iCE40-HX8K: memory ok

fix

  • debian command

Contributors