3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 22:14:08 +00:00
Commit graph

616 commits

Author SHA1 Message Date
Jannis Harder edbc0548af Fix deadlock with parallel SBY procs each with parallel tasks
When multiple SBY processes run in parallel (from a Makefile or other
job-server aware tool) and each SBY process runs tasks in parallel, each
with enough tasks to be limited by the total job count, it is possible
for the processes to race in such a way that every SBY process's helper
process is in a blocking read from the job-server but a job-token would
only become available as soon as any SBY process exits.

In that situation SBY doesn't actually need the job-token anymore and
only previously requested it as there was opportunity for parallelism.
It would immediatly return the token as soon as it is acquired. That's
usually sufficient to deal with no-longer-needed-but-requested tokens,
but when SBY is done, it needs to return the job-token held by the
parent process ASAP which it can only do by actually exiting, so we need
to interrupt the blocking read of SBY's helper process.

This could be done by sending a signal to the helper process, except
that Python made the decision in 3.5 to have automatic EINTR retry loops
around most system calls with no opt-out. That was part of the reason to
go with this specifc helper process design that avoids interrupting a
blocking read in the first place.

Using an exception raised from the signal handler instead might lose a
token when the signal arrives after the read returns, but before the
token is stored in a variable. You cannot recover from a lost token in
the context of the job-server protocol, so that's not an option. (This
can't happen with recent Python versions but that would depend on
undocumented behavior that could plausibly change again.)

Thankfully the only case where we need to interrupt the read is when SBY
is about to exit and will not request any further tokens. This allows us
to use a signal handler that uses dup2 to close and replace the
read-from fd with one that already is at EOF, making the next retry
return immediatly. (If we'd need to interrupt a read and continue
running we could also do this but the fd shuffling would be more
involved.)
2023-07-17 15:29:17 +02:00
Claire Xen fbbbab235f
Merge pull request #240 from YosysHQ/claire/aigfolds
Add "pdr -d" engine support (and aigfolds config option)
2023-06-28 11:11:36 +02:00
Jannis Harder 4d1ac0115c
Merge pull request #244 from jix/smtbmc-cover-keepgoing 2023-06-26 16:35:56 +02:00
Jannis Harder 28c053bd94 smtbmc: Allow using --keep-going in cover mode
See YosysHQ/yosys#3816 for the smtbmc change that made --keep-going do
something in cover mode
2023-06-23 10:34:03 +02:00
Jannis Harder c52acf2a1f docs: Make sphinx-argparse work independently of sphinx's cwd 2023-06-19 11:39:37 +02:00
Krystine Sherwin 1a4c2a57ad
Add sbysrc to path during docs build 2023-06-19 21:39:07 +12:00
Jannis Harder 0d6a70e137 autotune: Fix crash on no-engine error path 2023-06-19 11:21:49 +02:00
Krystine Sherwin 27e20fd5c3
Add sphinx-argparse to generate usage
Move parser generation into a seperate file to avoid import issues with bad python modules during docs gen.
With the requirements.txt provided to readthedocs, there shouldn't need to be any other changes?
Also I've never been able to run `make test` so I'm not actually sure if the changes break sby, but they shouldn't.
2023-06-13 11:40:28 +12:00
Claire Xenia Wolf f692eff845 Add support for "abc pdr -d" engine
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2023-06-07 22:21:06 +02:00
Claire Xenia Wolf 8b3ba68845 Add aigfolds option
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2023-06-07 22:05:17 +02:00
Claire Xen c027aea3db
Merge pull request #237 from jix/sphinx-theme
Change Sphinx theme to "furo"
2023-06-04 21:33:52 +02:00
Claire Xen c562d65e75
Merge pull request #239 from YosysHQ/claire/aigvmap
Add aigvmap and aigsyms options
2023-06-04 18:53:16 +02:00
Claire Xenia Wolf 7d60a3ba34 Add aigvmap and aigsyms options
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2023-06-03 22:16:35 +02:00
Claire Xen 81b9de988b
Merge pull request #238 from YosysHQ/claire/nowitrename
Make call to "witness -rename" optional (default=on)
2023-06-02 13:11:41 +02:00
Claire Xenia Wolf f49c9ebb29 Make call to "witness -rename" optional (default=on)
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2023-06-02 13:04:45 +02:00
Krystine Sherwin 36e7a72586
Adding prep mode and skip_prep option
Allows for generating a design_prep model which can then be used by multiple distinct sby runs.
2023-05-16 17:42:53 +12:00
Jannis Harder cb968ea2bb Update .readthedocs.yaml 2023-05-08 11:33:14 +02:00
Jannis Harder 513d0d4288 Change Sphinx theme to "furo" 2023-05-03 16:56:09 +02:00
Jannis Harder 74f33880bd
Merge pull request #232 from dlmiles/win-qol-cleanopt
-f clean: QoL improvement on Windows concerning file/dir removal locking
2023-02-20 19:48:36 +01:00
Darryl L. Miles fa5bc957c1 -f clean: QoL improvement on Windows concerning file/dir removal locking
When using the -f argument be more forgiving with the expectation of a clean
workspace and the expectation of the new sby run being responsible for
directory creation.

This is a usability and quality of life improvement for Windows users where
the OS can implement file and directory locking implicitly.  In the EDA world
it is common to have multiple tools in use at any one time and it can become
tortious to have to close files / exit 3rd party applications to release
locking so sby is happy to rerun.

This change will prevent sby claiming a terminal error has occurred when it
fails to create a directory that already exists.  It also now considers the
environment to be 'clean' (as per -f) if all the non-directory elements of
the file tree have been deleted, leaving potentially an empty a skeleton of
directories.
2023-02-18 09:36:18 +00:00
Miodrag Milanović 2cd0f6f71c
Try fixing GH action 2023-02-13 10:33:46 +01:00
Miodrag Milanović 8eaeca9aa4
Update GH action 2023-02-13 10:24:24 +01:00
N. Engelhardt 81ee5fdd5a
update prerequisites 2023-02-08 17:59:26 +01:00
Jannis Harder 466ab84745
Merge pull request #230 from jix/append_assume_default
append_assume: Make `append_assume on` the default for now
2023-02-08 14:42:20 +01:00
Jannis Harder c5dce57067 append_assume: Make append_assume on the default for now
Having `append_assume off` needs `vcd_sim on` to not be ignored with a
warning and `vcd_sim off` is still the default.
2023-02-08 14:18:52 +01:00
Jannis Harder 37d1234e38
Merge pull request #228 from jix/docs-updates
Docs updates
2023-02-06 22:10:38 +01:00
Jannis Harder 7a3b88ca67 docs: Document new sim related options 2023-02-06 16:55:19 +01:00
Jannis Harder 6d1ef8b5a0 docs: Yices is still recommended 2023-02-06 16:54:37 +01:00
Jannis Harder 7d3f0d50a5
Merge pull request #227 from jix/sim_traces
Unified trace generation using Yosys's sim command across all engines
2023-01-25 10:53:21 +01:00
Jannis Harder f14aaa57c4 avy: Fold aiger model using abc to support assumptions 2023-01-11 18:36:06 +01:00
Jannis Harder 6398938e6a Enable yosys sim support for clock signals in hierarchical designs 2023-01-11 18:02:45 +01:00
Jannis Harder 06c36d5bb0 Support "fifo:" make jobserver auth 2023-01-10 18:42:26 +01:00
Jannis Harder 6d3b5aa960 Unified trace generation using yosys's sim across all engines
Currently opt-in using the `fst` or `vcd_sim` options.
2023-01-10 18:42:26 +01:00
Jannis Harder 4c44a10f72
Merge pull request #226 from jix/python36-fstrings
Do not use fstring syntax that requires Python 3.8
2022-12-19 17:28:04 +01:00
Jannis Harder beb8b3c6e3 Do not use fstring syntax that requires Python 3.8
While we most likely will require Python 3.8 going forward, this might
restore Python 3.6 compatibility until we update the installation guide.
2022-12-19 16:49:37 +01:00
Jannis Harder 544a1cb369
Merge pull request #224 from jix/jobserver-poll-fix
jobserver: Only poll non-helper-process jobserver fd when ready to read
2022-12-09 16:54:24 +01:00
Jannis Harder 19109fd9f2 jobserver: Only poll non-helper-process jobserver fd when ready to read
This avoids SBY going into a busy wait loop in that case.
2022-12-09 16:24:22 +01:00
Claire Xen 9c75e49418
Merge pull request #221 from YosysHQ/claire/click
Add color handling via click.style and click.echo
2022-11-24 18:19:43 +01:00
Claire Xenia Wolf c29a5bbe8a Add colors to engine header message
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2022-11-24 18:12:22 +01:00
Claire Xenia Wolf e8d713cc27 Add colors to early and late log messages
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2022-11-02 12:35:11 +01:00
Claire Xenia Wolf 003ccf7197 Add color handling via click.style and click.echo
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
2022-10-31 20:29:32 +01:00
Jannis Harder 54cb030738
Merge pull request #220 from jix/aigbmc-use-yw
aigbmc: Convert aiw trace to yw trace and load that into smtbmc
2022-10-24 16:29:23 +02:00
Miodrag Milanović 50bdc76fe3
Update CI script 2022-10-24 08:31:45 +02:00
Jannis Harder 966bdae1f6 aigbmc: Convert aiw trace to yw trace and load that into smtbmc
This handles more edge cases concerning FF initialization, memories and
hierarchy.
2022-10-20 14:36:07 +02:00
Jannis Harder 6995aaef78
Merge pull request #219 from jix/fix-parallel-tests
tests: Do not run the same SBY task multiple times in parallel
2022-10-20 14:35:17 +02:00
Jannis Harder 90616c280b tests: Do not run the same SBY task multiple times in parallel 2022-10-20 14:18:51 +02:00
Jannis Harder 83a1aa23c8
Merge pull request #218 from jix/fix_engine_list
Fix engine_list's return value
2022-09-15 17:59:25 +02:00
Jannis Harder a0e3dd3d9a Fix engine_list's return value
This fixes #216
2022-09-15 15:47:27 +02:00
Jannis Harder e97dd01523
Merge pull request #215 from KrystalDelusion/master
Fixing golden/fifo.sv
2022-09-08 12:37:30 +02:00
KrystalDelusion 37140e7e81 Fixing golden/fifo.sv
Had missed a change from (non golden) fifo.sv.
2022-09-07 09:52:52 +12:00