tangxifan
9cfb2f52ef
[OpenFPGA code] bug fix for fully equivalent outputs of pb_type
2020-09-16 19:26:46 -06:00
tangxifan
fc6bfdc7a2
[OpenFPGA Code] Patch syntax compatibility for older gcc
2020-09-14 18:55:21 -06:00
tangxifan
5d83abb2cf
bug fix in read architecture bitstream and regression tests
2020-07-27 19:37:05 -06:00
tangxifan
6592db3dfe
bug fix in calling the wrong function of write_fabric_bitstream
2020-07-27 14:32:58 -06:00
tangxifan
d68e77f322
Split the writer of build_fabric_bitstream to a separated command so that users will output multiple files in different formats
2020-07-27 14:16:33 -06:00
tangxifan
5fb7d9fbdb
bug fix in fabric bitstream file format writer
2020-07-26 21:28:45 -06:00
tangxifan
92d2d2d849
add fabric bitstream XML writer
2020-07-26 21:00:57 -06:00
tangxifan
2603836111
split logical tile netlists to keep good Verilog hierarchy
2020-07-24 12:53:21 -06:00
tangxifan
be5966475e
formulate file name, module name and instance name to be consistent
2020-07-24 12:23:27 -06:00
tangxifan
b5fd6aa859
add inverter subckt writer to FPGA-SPICE
2020-07-17 13:01:08 -06:00
tangxifan
824b56f14c
fabric key can now accept instance name only; decoders are no longer part of the key
2020-07-06 16:42:33 -06:00
tangxifan
462fc0d04e
add spice transistor wrapper writer
2020-07-05 14:50:29 -06:00
tangxifan
81171a8f97
start transplanting FPGA-SPICE
2020-07-05 12:10:12 -06:00
tangxifan
1f38e17111
bug fix for naming conflicts in mux local encoder and architecture decoders
2020-07-03 14:12:13 -06:00
tangxifan
adee87569d
enable fast bitstream building by creating a frame view of fabric
2020-07-02 16:25:36 -06:00
tangxifan
0a3c746fb1
now split CB module bus ports into lower/upper parts
2020-07-01 14:37:13 -06:00
tangxifan
e688ca1388
update fabric bitstream writer to support various configuration protocols
2020-07-01 11:54:28 -06:00
tangxifan
2e7684b746
adapt bus ports in connection block module builder
2020-06-30 17:50:53 -06:00
tangxifan
2ef083c49d
adapt SB module builder to use bus ports
2020-06-30 16:02:40 -06:00
tangxifan
ebf5636e7b
add verbose output to edge sorting for GSBs
2020-06-26 17:10:51 -06:00
tangxifan
aded675633
rename files in fpga bitstream library to be consistent with conventions
2020-06-21 13:06:39 -06:00
tangxifan
d526f08782
deploy bitstream reader in openfpga shell
2020-06-20 18:48:19 -06:00
tangxifan
675a59ecb8
Move fpga_bitstream to the libopenfpga library and add XML reader
2020-06-20 18:25:17 -06:00
tangxifan
5d79a3f69f
critical bug fixed when annotating the routing results.
...
Add previous node check. This is due to that some loops between SB/CBs may exist
when routing congestion is high, which leads to same nets appear in the inputs
of a routing multiplexer. Actually one of them is driven by the other as a downstream node
Using previous node check can identify which one to pick
2020-06-17 11:17:57 -06:00
tangxifan
b91c30191a
add input and output net echo in arch bitstream database
2020-06-17 00:04:55 -06:00
tangxifan
a5055e9d26
add support about loading external fabric key
2020-06-12 13:03:11 -06:00
tangxifan
9dbf536306
add shuffled configurable children support for top module
2020-06-12 11:16:53 -06:00
tangxifan
3499b4d3e7
add fabric key writer for top-level module
2020-06-12 10:41:34 -06:00
tangxifan
278acee216
bug fix for 'build_fabric' command
2020-06-11 23:59:24 -06:00
tangxifan
9167b288b6
add options for fabric key
2020-06-11 21:50:46 -06:00
tangxifan
58807bfcb3
remove simulation settings from openfpga arch data structure
2020-06-11 19:31:16 -06:00
tangxifan
96b58dfdbb
use new simulation setting command in openfpga shell
2020-06-11 19:31:15 -06:00
tangxifan
4a2f6dfae2
add read/write simulation setting commands to openfpga shell
2020-06-11 19:31:15 -06:00
tangxifan
0bee70bee6
finish memory bank configuration protocol support.
2020-06-11 19:31:13 -06:00
tangxifan
0e16ee1030
add configuration bus nets for memory bank decoders at top module
2020-06-11 19:31:13 -06:00
tangxifan
fa8dfc1fbd
add configuration protocol ports to top module for memory bank organization
2020-06-11 19:31:13 -06:00
tangxifan
fbe05963e0
add configuration bus builder for flatten memory organization (applicable to memory bank and standalone configuration protocol)
2020-06-11 19:31:12 -06:00
tangxifan
d2d443a988
start developing memory bank and standalone configuration protocol
2020-06-11 19:31:12 -06:00
tangxifan
8b3e79766c
add fast configuration option to fpga_verilog to speed up full testbench simulation
2020-06-11 19:31:12 -06:00
tangxifan
65df309419
bug fixing for frame-based configuration protocol and rename some naming function to be generic
2020-06-11 19:31:10 -06:00
tangxifan
4a0e1cd908
add fabric bitstream data structure and deploy it to Verilog testbench generation
2020-06-11 19:31:10 -06:00
tangxifan
5c5a044c68
add architecture decoder (for frame-based config memory) to Verilog writer
2020-06-11 19:31:09 -06:00
tangxifan
290dd1a8a6
add frame decoder builder to all the module graph builder except the top-level
2020-06-11 19:31:09 -06:00
tangxifan
8864920460
add frame-based memory module builder
2020-06-11 19:31:09 -06:00
tangxifan
3a26bb5eef
add advanced check in configurable memories
2020-06-11 19:31:09 -06:00
tangxifan
bba476fef4
add explicit port mapping support to Verilog testbench generator
2020-06-11 19:31:07 -06:00
tangxifan
e089b0ef22
use constant string for inverted port naming
2020-06-11 19:31:07 -06:00
tangxifan
8915d10d27
add verbose output option to configure port disable timing writer
2020-06-11 19:31:07 -06:00
tangxifan
f52b5d5b4c
use error code in read_arch command
2020-06-11 19:31:07 -06:00
tangxifan
e9ceedb01b
use constant openfpga context in SDC generator
2020-06-11 19:31:07 -06:00
tangxifan
13f591cacf
add new command to disable timing for configure ports of programmable modules
2020-06-11 19:31:06 -06:00
tangxifan
4c0953415b
add configuration chain sdc writer
2020-06-11 19:31:06 -06:00
tangxifan
8d2360a710
simplify include_netlist.v
2020-06-11 19:31:05 -06:00
tangxifan
5a8c05378e
add --depth option to fabric hierarchy writer
2020-06-11 19:31:04 -06:00
tangxifan
d9dc7160a7
minor fix on the hierarchy writer in SDC generator
2020-06-11 19:31:04 -06:00
tangxifan
c651df6421
add hierarchy writer to SDC generator
2020-06-11 19:31:04 -06:00
tangxifan
6aff33dd35
add fabric hierarchy writer
2020-06-11 19:31:04 -06:00
tangxifan
8726c618eb
add time unit support on SDC generator. Now users can define time_unit thru cmd-line options
2020-06-11 19:31:03 -06:00
tangxifan
7e82c23f52
now add SDC generator supports both hierarchical and flatten in writing timing constraints
2020-06-11 19:31:03 -06:00
tangxifan
d0793d9029
now disable_sb_output support wildcard
2020-06-11 19:31:02 -06:00
tangxifan
8695c5ee78
add options to use general-purpose wildcards in SDC generator
2020-06-11 19:31:02 -06:00
tangxifan
e811f8bb21
plug in netlist manager and now the include_netlist appears in one unique file
2020-04-23 20:42:11 -06:00
tangxifan
87b17fc25f
add netlist manager data structure
2020-04-23 18:59:09 -06:00
tangxifan
68b7991a46
bug fixed for sdc on memory blocks
2020-04-21 13:37:56 -06:00
tangxifan
d325bede68
add fabric bitstream writer
2020-04-21 12:02:10 -06:00
tangxifan
e10cafe0a5
Critical patch on repacking about wire LUT support.
...
Previously, the wire LUT identification is too naive and does not consider all the cases
2020-04-19 16:42:31 -06:00
tangxifan
b9dab2baaf
add exit codes to command execution in shell context
2020-04-08 16:18:05 -06:00
tangxifan
1fb37f4c71
improve directory creator to support same functionality as 'mkdir -p'
2020-04-08 12:55:09 -06:00
tangxifan
cbcd1d20d4
fixed memory leakage in pb_pin fixup
2020-04-07 16:24:04 -06:00
tangxifan
5a04da2082
fix memory leakage in openfpga title
2020-04-07 16:14:41 -06:00
tangxifan
bcb86801fa
bug fixed in gpio naming for module manager ports
2020-04-05 17:26:44 -06:00
tangxifan
e601a648cc
relax asseration to allow AIB (non-I/O) blocks on the side of FPGA fabrics
2020-03-27 19:07:34 -06:00
tangxifan
7c9c2451f2
debugging multiple io_types; bug fixed to support I/Os in more flexible location of FPGA fabric
2020-03-27 16:03:42 -06:00
tangxifan
329b0a9cf1
add options to enable SDC constraints on zero-delay paths
2020-03-25 15:55:30 -06:00
tangxifan
c2e5d6b8e2
add options to dsiable SDC for non-clock global ports
2020-03-25 14:38:13 -06:00
tangxifan
787dc8ce83
added ASCII OpenFPGA logo in shell interface
2020-03-25 11:16:04 -06:00
tangxifan
9e4e12aae9
fixed echo message in the compression rate of gsb uniquifying
2020-03-22 16:13:04 -06:00
tangxifan
ff474d87de
fixed critical bug in uniquifying GSBs. Now it can guarantee minimum number of unique GSBs
2020-03-22 16:11:00 -06:00
tangxifan
3958ac2494
fix bugs in flow manager on default compress routing problems
2020-03-22 15:26:15 -06:00
tangxifan
7b9384f3b2
add write_gsb command to shell interface
2020-03-21 19:40:26 -06:00
tangxifan
9a518e8bb6
bug fixed for tileable rr_graph builder for more 4x4 fabrics
2020-03-21 18:07:00 -06:00
tangxifan
c0e8d98c6f
bug fixed in tile direct builder
2020-03-21 12:43:56 -06:00
tangxifan
aff73bdd74
deployed edge sorting and make it as an option to link_arch command
2020-03-08 15:59:53 -06:00
tangxifan
37423729ec
bug fixing for naming the duplicated pins
2020-03-07 15:44:57 -07:00
tangxifan
7fcd27e000
now we give explicit instance name to each interconnect inside grid. Thus resolve the problem in sdc writer
2020-03-03 12:29:58 -07:00
tangxifan
3241d8bd37
put analysis sdc writer online. Minor bug in redudant '/' to be fixed
2020-03-02 19:54:18 -07:00
tangxifan
037c7e5c43
adapt top-level function for analysis SDC writer
2020-03-02 17:58:44 -07:00
tangxifan
a17c14c363
clean-up command addition and add fabric bitstream building to sample script
2020-03-02 10:39:19 -07:00
tangxifan
aa66042dfb
move simulation setting annotation to a separated source file
2020-02-29 15:19:02 -07:00
tangxifan
7b18f7cd09
now the auto select number of clocks in simulation is online
2020-02-29 13:29:16 -07:00
tangxifan
542fadaaae
allow users to use VPR critical path delay in OpenFPGA simulation
2020-02-28 12:10:27 -07:00
tangxifan
de8425874c
use user defined critical path delay in SDC generation
2020-02-28 11:24:39 -07:00
tangxifan
092e10afda
bring pnr sdc generator online and fixed minor bugs in bitstream writing
2020-02-28 11:14:50 -07:00
tangxifan
9b769cd8e4
bug fix for using renamed i/o names
2020-02-27 16:37:20 -07:00
tangxifan
078f72320f
debugging Verilog testbench generator. Bug spotted in using renamed atom_block and clock ports
2020-02-27 13:24:26 -07:00
tangxifan
f558405887
ported verilog testbench generator online. Split from fabric generator. Testing to be done
2020-02-27 12:33:09 -07:00
tangxifan
b3796b0818
build io location map
2020-02-26 19:58:18 -07:00
tangxifan
25e0583636
add io location map data structure and start porting verilog testbench generator
2020-02-26 17:10:57 -07:00
tangxifan
a26d31b87f
make write bitstream online
2020-02-26 11:09:23 -07:00
tangxifan
4024ed63cb
add truth table build up for physical LUTs
2020-02-25 22:39:42 -07:00
tangxifan
8e9660b816
add mapped block fast look-up as placement annotation
2020-02-24 16:09:29 -07:00
tangxifan
2d17395e13
start integrating fpga_bitstream. Bring data structures online
2020-02-22 23:04:42 -07:00
tangxifan
4abaef14b5
bug fixed in pb_pin fix-up. This is due to A CRITICAL BUG IN PHYSICAL_TILE PIN MAPPING!!!
2020-02-20 20:50:59 -07:00
tangxifan
3e07d7d5e0
finish net addition to LbRouter. Found a bug in pb pin fix-up. Need to consider clustered I/O block z offset
2020-02-20 20:26:20 -07:00
tangxifan
fdb27c5a6b
move lb_rr_graph construction to repack command
2020-02-20 13:24:34 -07:00
tangxifan
409b3f6896
add lb_rr_graph builder for the refactored version
2020-02-17 21:11:56 -07:00
tangxifan
8e97443410
start working on repack
2020-02-17 17:57:43 -07:00
tangxifan
62e4f14e30
add lb_rr_graph to device annotation
2020-02-17 17:26:27 -07:00
tangxifan
6c69b52ded
Add missing file
2020-02-17 17:11:29 -07:00
tangxifan
e37ac8a098
add grid module Verilog writer
2020-02-16 16:04:41 -07:00
tangxifan
c6c3ef71f3
adapt all the Verilog submodule writers and bring it onlien
2020-02-16 13:35:18 -07:00
tangxifan
bf54be3d00
add option data structure for FPGA Verilog
2020-02-15 21:39:47 -07:00
tangxifan
da79ef687c
add missing files
2020-02-15 20:54:37 -07:00
tangxifan
8b0df8632c
bring fpga verilog create directory online
2020-02-15 20:38:45 -07:00
tangxifan
539f13720a
tile direct supports inter-column/inter-row direct connections
2020-02-15 13:42:53 -07:00
tangxifan
213c611c0b
add tile direct builder
2020-02-14 22:21:32 -07:00
tangxifan
afe8278670
put routing module builder online
2020-02-13 17:35:29 -07:00
tangxifan
89086ed080
add verbose output to build grid module
2020-02-13 15:38:26 -07:00
tangxifan
072965cd64
make grid module builder online; basic support on physical tiles
2020-02-13 15:27:16 -07:00
tangxifan
895d5b5a0a
add utils for grid module builder
2020-02-12 20:25:05 -07:00
tangxifan
fddd3c9463
add mux module builder
2020-02-12 19:45:14 -07:00
tangxifan
f11832b8cf
start integrating module graph builder
2020-02-12 17:53:23 -07:00
tangxifan
13fadd0f91
move compact routing hierarchy to build_fabric command
2020-02-12 15:49:47 -07:00
tangxifan
c78d3e9af1
add mux library builder
2020-02-12 14:58:23 -07:00
tangxifan
a736e09c29
add rr_switch binding in link openfpga arch command
2020-02-12 10:52:20 -07:00
tangxifan
a31d6c6d1e
rename pb_type annotation to device annotation
2020-02-12 09:52:18 -07:00
tangxifan
175bef014a
add compact_routing hierarchy command
2020-02-11 17:40:37 -07:00
tangxifan
1372f748f1
put GSB builder online
2020-02-11 16:37:14 -07:00
tangxifan
3d7eff64b9
bug fixed for lut truth table fixup. Results look good
2020-02-06 17:47:25 -07:00
tangxifan
ed9e038845
add functionality of LUT truth table fix-up
2020-02-06 17:14:29 -07:00
tangxifan
99f5a86b49
bug fixed for routing annotation and routing net fix-up
2020-02-06 12:54:55 -07:00
tangxifan
dad204674b
done an initial version of clustering net fix-up based on routing results. Debugging on the way
2020-02-05 21:50:52 -07:00
tangxifan
75c3507acf
add verbose output option for openfpga linking architecture
2020-01-31 11:36:58 -07:00
tangxifan
d62c9fe86f
adding pb_graph_node annotation
2020-01-30 16:40:13 -07:00
tangxifan
e48ab8cb44
move annotation source files to a separated folder
2020-01-30 13:37:41 -07:00
tangxifan
f28ca3ffd0
add more echo to log
2020-01-29 18:58:57 -07:00
tangxifan
87f1ca1151
add naming fix-up report generation
2020-01-29 18:56:47 -07:00
tangxifan
2dc4c26257
add naming fix-up
2020-01-29 17:49:33 -07:00
tangxifan
8c86c0af04
add check netlist naming conflict command and functions
2020-01-29 16:23:41 -07:00
tangxifan
d2c47693f6
add check codes for mode bits annotation to pb_types and clean up utils source files
2020-01-29 14:29:00 -07:00
tangxifan
a4381563bc
move check codes to separated source files
2020-01-29 13:47:59 -07:00
tangxifan
b67358d2c5
add check codes for physical pb_type circuit model annotation
2020-01-29 12:56:49 -07:00
tangxifan
a722438fa3
add mode bits binding to pb_type annotation
2020-01-29 12:27:55 -07:00
tangxifan
61b487eb75
show more information in the log file
2020-01-29 11:29:41 -07:00
tangxifan
399ba8d648
add pb type port mapping to circuit model ports
2020-01-29 11:24:14 -07:00
tangxifan
cf3c5b5c42
add circuit model type checking for physical pb_type annotation
2020-01-29 10:41:02 -07:00
tangxifan
8a7a4dc48e
add physical type annotation for interconnects and inference
2020-01-28 21:59:10 -07:00
tangxifan
bb7fa2af77
add pb interconnect binding to circuit model
2020-01-28 17:04:10 -07:00
tangxifan
1651c9ca18
add binding between physical pb_type and circuit models
2020-01-28 16:03:02 -07:00
tangxifan
a4a84ca35b
add check codes for physical pb_type and port annotation
2020-01-28 15:27:00 -07:00
tangxifan
5d9850c2eb
move pb_type annotation to independent source files as they are getting large
2020-01-28 15:13:14 -07:00
tangxifan
fdcc04cca8
add physical pb_type inference
2020-01-28 14:55:47 -07:00
tangxifan
caeb0bfff8
add physical pb_type binding for explicit annotations
2020-01-28 14:27:35 -07:00
tangxifan
82f71e82e8
add check codes for physical mode annotation for pb_types
2020-01-27 21:15:32 -07:00
tangxifan
f99dd4c261
debugged pb_type physical mode annotation
2020-01-27 20:40:18 -07:00
tangxifan
b8c504f574
Do not allow vpr to free everything when it is done. So that we can have access to their device data
2020-01-27 19:49:05 -07:00
tangxifan
df056f5d70
openfpga shell will stay in interactive mode after executing a script
2020-01-27 17:56:24 -07:00
tangxifan
5ecb771673
debugging the annotation to physical mode of pb_types
2020-01-27 17:43:22 -07:00
tangxifan
a6fbbce33e
start developing the openfpga arch binding to vpr
2020-01-27 15:31:12 -07:00
tangxifan
5039af2c2f
update title page
2020-01-24 17:00:53 -07:00
tangxifan
a7a1fe8a74
simplify openfpga title page and add command dependency on read_arch and write_arch
2020-01-24 16:57:14 -07:00
tangxifan
655f84b00e
add write_openfpga_arch command to openfpga shell
2020-01-23 20:58:15 -07:00
tangxifan
a03f8aa346
add profiling for read arch
2020-01-23 20:12:30 -07:00
tangxifan
cdb3b6de46
add read_openfpga_arch to OpenFPGA shell
2020-01-23 19:10:53 -07:00
tangxifan
3cb16a2279
move basic commands to separated CXX files
2020-01-23 14:42:49 -07:00
tangxifan
ba207ee5a5
start split workload from the main.cpp in openfpga
2020-01-23 13:24:35 -07:00