summary | 
shortlog | log | 
commit | 
commitdiff | 
tree
first ⋅ prev ⋅ next
 
Luke Kenneth Casson Leighton [Sat, 17 Apr 2021 07:46:26 +0000 (08:46 +0100)]
 
Document why FFSynchronizer is not used.
Custom synchronization can be used with less latency than more generic
solutions.
Staf Verhaegen [Thu, 22 Apr 2021 08:55:33 +0000 (10:55 +0200)]
 
Double empty lines between top level definitions.
Luke Kenneth Casson Leighton [Sat, 17 Apr 2021 08:03:44 +0000 (09:03 +0100)]
 
whitespace (pep8)
Luke Kenneth Casson Leighton [Fri, 9 Oct 2020 13:12:02 +0000 (14:12 +0100)]
 
comments on JTAG IO
Staf Verhaegen [Wed, 21 Apr 2021 17:35:34 +0000 (19:35 +0200)]
 
Remove generated test file.
Staf Verhaegen [Wed, 21 Apr 2021 17:30:54 +0000 (19:30 +0200)]
 
Fix path for env
Luke Kenneth Casson Leighton [Sat, 17 Apr 2021 08:03:09 +0000 (09:03 +0100)]
 
comment on why clocks are in FSM
Staf Verhaegen [Thu, 1 Apr 2021 12:38:46 +0000 (14:38 +0200)]
 
modgrammar dependency
Staf Verhaegen [Thu, 1 Apr 2021 11:48:37 +0000 (13:48 +0200)]
 
Typo (is -> ==)
Staf Verhaegen [Thu, 1 Apr 2021 11:48:17 +0000 (13:48 +0200)]
 
svfcocotb: Fix results access for SDR and SIR.
Staf Verhaegen [Thu, 1 Apr 2021 11:47:18 +0000 (13:47 +0200)]
 
svfgrammar: Forgotten SVF statements.
Staf Verhaegen [Thu, 1 Apr 2021 11:46:34 +0000 (13:46 +0200)]
 
Support lower case hex letters.
Staf Verhaegen [Wed, 21 Apr 2021 17:19:32 +0000 (19:19 +0200)]
 
Connect tdi to tdo for boundary scan without IOs.
Luke Kenneth Casson Leighton [Thu, 22 Oct 2020 17:13:57 +0000 (18:13 +0100)]
 
Handle case with zero IO cells for boundary scan.
Luke Kenneth Casson Leighton [Fri, 9 Oct 2020 12:36:47 +0000 (13:36 +0100)]
 
Comment sections in TAP.elaborate()
Staf Verhaegen [Thu, 8 Apr 2021 11:43:48 +0000 (13:43 +0200)]
 
nmigen-soc dependency
Staf Verhaegen [Mon, 6 Jan 2020 16:39:25 +0000 (17:39 +0100)]
 
Fix cocotb path for c4m_jtag_svfgrammar.
Staf Verhaegen [Wed, 25 Dec 2019 14:21:35 +0000 (15:21 +0100)]
 
BinaryValue API change.
Staf Verhaegen [Tue, 17 Dec 2019 19:26:08 +0000 (20:26 +0100)]
 
Update the unit tests.
* Add test for custom shiftreg
* Add Wishbone JTAG port test.
Staf Verhaegen [Tue, 17 Dec 2019 16:53:08 +0000 (17:53 +0100)]
 
cocotb improvements
* Made ir_width configurable.
* Allow to use BinaryValue for load_ir.
Staf Verhaegen [Mon, 6 Jan 2020 17:06:05 +0000 (18:06 +0100)]
 
Made nmigen code independent of VHDL code.
All blocks have been converted to nmigen.
Staf Verhaegen [Mon, 6 Jan 2020 17:05:06 +0000 (18:05 +0100)]
 
Support for different IO types in VHDL code.
IO cells can now be input, output, tri-state output, tri-state
inout. Update tests and added separate test for c4m_jtag_ioblock.
Staf Verhaegen [Tue, 17 Dec 2019 19:26:46 +0000 (20:26 +0100)]
 
Force passing by name for TAP.add_shiftreg().
Staf Verhaegen [Tue, 17 Dec 2019 19:27:08 +0000 (20:27 +0100)]
 
Also clean python cache.
Staf Verhaegen [Mon, 16 Dec 2019 10:00:04 +0000 (11:00 +0100)]
 
Added test bench for nmigen TAP with cocotb.
Based on vhdl controller test bench.
Staf Verhaegen [Mon, 16 Dec 2019 15:36:45 +0000 (16:36 +0100)]
 
Fix order of iocells in ioblock.
Staf Verhaegen [Mon, 16 Dec 2019 09:45:15 +0000 (10:45 +0100)]
 
Specify names for TAP signals.
Staf Verhaegen [Sun, 15 Dec 2019 12:54:18 +0000 (13:54 +0100)]
 
Basic nmigen generator bench for TAP top cell.
Simple generation with nmigen and yosys as only dependency.
Staf Verhaegen [Sun, 15 Dec 2019 14:19:51 +0000 (15:19 +0100)]
 
Fix paths after move.
Staf Verhaegen [Sun, 15 Dec 2019 13:55:36 +0000 (14:55 +0100)]
 
[broken]Moved test benches to test/vhdl
test/vhdl will be for test benches of the vhdl code; test/nmigen for the
nmigen code.
This just moves the files. They will be fixed in next commit.
Staf Verhaegen [Sun, 15 Dec 2019 13:52:36 +0000 (14:52 +0100)]
 
Move idcode.vhdl to test/ghdl/idcode
Staf Verhaegen [Sun, 15 Dec 2019 13:49:46 +0000 (14:49 +0100)]
 
Remove unused bench
Staf Verhaegen [Tue, 10 Dec 2019 20:31:16 +0000 (21:31 +0100)]
 
Made STATE and NEXT_STATE internal to c4m_jtag_tap_fsm.
This also makes the STATE_TYPE type internal to c4m_jtag_tap_fsm.
Staf Verhaegen [Tue, 10 Dec 2019 20:17:18 +0000 (21:17 +0100)]
 
Pass VERSION generic from controller to idblock.
Staf Verhaegen [Tue, 10 Dec 2019 20:16:00 +0000 (21:16 +0100)]
 
Moved function definitions before component definitions in pkg.
Staf Verhaegen [Tue, 10 Dec 2019 20:14:31 +0000 (21:14 +0100)]
 
Added TODO for IOMODEs.
Staf Verhaegen [Sun, 8 Dec 2019 09:48:56 +0000 (10:48 +0100)]
 
Add top controller instance from nmigen code.
Currently ghdlsynth needs instantiated cell with given generic values.
Staf Verhaegen [Fri, 6 Dec 2019 19:06:49 +0000 (20:06 +0100)]
 
Simplify signal generation for TAP wishbone interfaces.
Staf Verhaegen [Fri, 6 Dec 2019 19:06:06 +0000 (20:06 +0100)]
 
Use Elif for third m.next assignment.
This way m.next assignments are done in one If/Elif statements for
the "IDLE" state and not in two different If statements.
Staf Verhaegen [Fri, 6 Dec 2019 10:40:40 +0000 (11:40 +0100)]
 
Use Wishbone code from nmigen-soc.
Staf Verhaegen [Fri, 6 Dec 2019 11:07:27 +0000 (12:07 +0100)]
 
Support JTAG bus with a reset signal.
Staf Verhaegen [Fri, 6 Dec 2019 10:47:43 +0000 (11:47 +0100)]
 
Rework ShiftReg and Wishbone elaboration.
- ShiftReg is now a Record subclass just providing the interface for
  user code.
- JTAGWishbone class is removed.
- elaboration for ShiftReg and Wishbone is now done in
 _elaborate_shiftregs() and _elaborate_whishbones() TAP methods.
Staf Verhaegen [Fri, 6 Dec 2019 10:17:48 +0000 (11:17 +0100)]
 
Use the JTAG Interface class as bus.
Staf Verhaegen [Fri, 6 Dec 2019 09:46:18 +0000 (10:46 +0100)]
 
Get Wishbone from c4m lib.
Staf Verhaegen [Fri, 6 Dec 2019 09:43:10 +0000 (10:43 +0100)]
 
Rename JTAG to TAP.
Staf Verhaegen [Thu, 5 Dec 2019 19:48:18 +0000 (20:48 +0100)]
 
Renamed jtag.py -> tap.py.
Staf Verhaegen [Thu, 5 Dec 2019 19:43:26 +0000 (20:43 +0100)]
 
Added JTAG bus interface.
Staf Verhaegen [Thu, 5 Dec 2019 16:22:20 +0000 (17:22 +0100)]
 
Move pmod resource to own file and convert it in one function.
Staf Verhaegen [Wed, 4 Dec 2019 19:50:13 +0000 (20:50 +0100)]
 
python setuptools files
Staf Verhaegen [Wed, 4 Dec 2019 16:36:22 +0000 (17:36 +0100)]
 
Fix code after move
* tests fixed
* path to vhdl source
Staf Verhaegen [Fri, 6 Dec 2019 18:07:41 +0000 (19:07 +0100)]
 
[broken]Move code
Moved files without any changes to easily track later changes.
Staf Verhaegen [Wed, 4 Dec 2019 15:29:31 +0000 (16:29 +0100)]
 
Setup new structure for code
New structure will be compatible with easy pip/conda installing.
Staf Verhaegen [Thu, 5 Dec 2019 19:39:50 +0000 (20:39 +0100)]
 
Made _add_files static method of JTAG.
Staf Verhaegen [Wed, 4 Dec 2019 16:34:23 +0000 (17:34 +0100)]
 
Update test code for interface change of c4m_jtag_tap_controller.
Staf Verhaegen [Fri, 6 Dec 2019 16:09:26 +0000 (17:09 +0100)]
 
Handle stall signal.
Staf Verhaegen [Wed, 13 Nov 2019 11:32:55 +0000 (12:32 +0100)]
 
Added nmigen wrapper and support code for JTAG interface.
nmigen code has support for adding shift registers and a Wishbone bus
master that is drive by JTAG commands.
Staf Verhaegen [Tue, 29 Oct 2019 12:02:21 +0000 (13:02 +0100)]
 
Only add assert statement if DEBUG generic is true.
Default value is false.
Staf Verhaegen [Thu, 3 Oct 2019 14:47:47 +0000 (16:47 +0200)]
 
cocotb/c4m_jtag: support trst_n to be None.
Staf Verhaegen [Thu, 3 Oct 2019 14:46:27 +0000 (16:46 +0200)]
 
c4m_jtag_tap_controller: Remove TAPSTATE_TYPE signals and TDO_EN from interface
Staf Verhaegen [Mon, 26 Aug 2019 19:02:39 +0000 (21:02 +0200)]
 
clean up unused python import statements
Staf Verhaegen [Sun, 7 Jul 2019 16:29:06 +0000 (18:29 +0200)]
 
IDCODE:
- provide default manufacturer ID that is invalid according to spec
- provide default for all MANUFACTURER, PART_NUMBER and VERSION
Staf Verhaegen [Mon, 25 Jun 2018 16:48:03 +0000 (18:48 +0200)]
 
Don't use tri-state logic for TDO; introduce TDO_EN signal to indicate when TDO is valid.
Add assert for conflicting TDO assignment.
Staf Verhaegen [Mon, 25 Jun 2018 16:46:28 +0000 (18:46 +0200)]
 
Simulation setup improvements:
 * Use cocotb-path to get cocotb install dir
 * Use relative paths to find source code for simulation
 * Remove rm dual_serial test
 * Ignore build directory
Staf Verhaegen [Sat, 14 Apr 2018 09:28:44 +0000 (11:28 +0200)]
 
Added SVF_Executor class that allows to execute a SVF file through a JTAG_Master object
Currently only limited implementation only enough to run demos in simulation
on the Retro_uC.
Staf Verhaegen [Sat, 14 Apr 2018 09:20:36 +0000 (11:20 +0200)]
 
Added SVF grammar parser
Using modgrammar (can be installed with pip)
TODO: PIO, PIOMAP
Staf Verhaegen [Sat, 14 Apr 2018 09:18:56 +0000 (11:18 +0200)]
 
JTAG_master class: fix bug that wrongly changed state to Scan when TMS is 0
Staf Verhaegen [Sat, 14 Apr 2018 09:17:45 +0000 (11:17 +0200)]
 
JTAG_master class: document need for manual setting of state after using change_state method
Staf Verhaegen [Sat, 25 Nov 2017 15:44:05 +0000 (16:44 +0100)]
 
Fix ghdl sim script.
Staf Verhaegen [Sun, 27 Aug 2017 20:05:24 +0000 (22:05 +0200)]
 
Import the JTAG interface code as used for the Chips4Maker pilot Retro-uC
This code has currently been tested in FPGA through a buspirate so should
already be functional.