Comments (6)
@dbeyer This issue shouldn't be closed as WARNINGS_AS_ERRORS
is still set to 0
in the current build system due to problematic benchmarks. Enabling WARNINGS_AS_ERRORS
is going to be very difficult because many benchmarks trigger warnings.
from sv-benchmarks.
Sorry, I must have closed this issue incidentally by closing another one (#118).
from sv-benchmarks.
I think it would be helpful to turn on WARNINGS_AS_ERRORS
by default and turn it off for now only in those directories where it is necessary. This would serve as documentation about the current state, ensure that newly added tasks get added without warnings, and maybe motivate some people to remove the warnings from the tasks they submitted. At least we can then identify and ping the people more easily.
from sv-benchmarks.
@delcypher I think if we want to get process on this we need to have strict checks as default and only loosen them specifically for some directories where this is (still) needed. This way we can always look at the exceptions and see where work is still necessary. I hope that this would improve working on fixing the benchmarks.
Currently nobody knows what kind of warnings need to be taken care of on which parts of the benchmark set, so nobody does anything.
Could you do this in the build system? Would be great.
from sv-benchmarks.
The build system already supports enabling/disabling warnings on a per directory basis. Here is what you need to do.
- Merge #149 to make debugging easier for yourself
- Change
WARNINGS_AS_ERRORS ?= 0
inMakefile.config
toWARNINGS_AS_ERRORS ?= 1
. - For directories where you need to disable
WARNINGS_AS_ERRORS
you can add this line
WARNINGS_AS_ERRORS ?= 0
to the Makefile
for that directory before the include $(LEVEL)/Makefile.config
line.
For example
LEVEL := ../
WARNINGS_AS_ERRORS ?= 0
include $(LEVEL)/Makefile.config
To check the change is having effect run make debug_vars
in the directory where you changed the Makefile
and check you see that WARNINGS_AS_ERRORS
is set appropriately.
Note you can also specify WARNINGS_AS_ERRORS
on the command line when building to override the behaviour
make WARNINGS_AS_ERRORS=1
There are a few things you need to be aware of
SUPPRESS_WARNINGS
andWARNINGS_AS_ERRORS
cannot both be enabled at the same time.- The TravisCI build has
SUPPRESS_WARNINGS
enabled because so many warnings fire that we hit TravisCI's log limit and the build fails. So if you makeWARNINGS_AS_ERRORS
default you will break the build.
As for doing the work of working out which warnings to have (and which compiler supports them) this is not my responsibility.
from sv-benchmarks.
Can we disable individual warnings/errors per directory?
How can I do what you suggest without breaking the Travis build? Is it possible to make SUPPRESS_WARNINGS
and WARNINGS_AS_ERRORS
compatible? Should we simply redirect warnings to a file or /dev/null
on Travis? Or pipe them through head
to see at least some of them?
from sv-benchmarks.
Related Issues (20)
- Tasks in seq-mthreaded wrongly marked as non-terminating HOT 2
- Task ntdrivers/floppy2 is not memory safe
- Task ntdrivers/diskperf.i.cil-1.c is not memory safe HOT 2
- ntdrivers/parport.i.cil-2 is not memory safe
- LDV tasks with undefined behaviour and/or wrong verdicts HOT 3
- cut-2 and od-1 from busy-box are not memory safe HOT 1
- Undefined behavior in two AWS benchmarks
- MemSafety - unset subproperty for false verdict
- Incorrect Verification Task
- geo1-ll.c can overflow HOT 3
- Implementation-defined behaviour HOT 3
- SV-COMP concurrency benchmarks with data races HOT 3
- "Repeated" benchmarks in pthread-wmm
- why can echo-2.i overflow? HOT 2
- __builtin_unreachable() in LDV benchmarks HOT 3
- Benchmarks for weak memory models HOT 3
- Reachable error in pthread-ext/41_FreeBSD_abd_kbd_sliced
- Use of `__VERIFIER_nondet_*` functions that aren't specified in SV-COMP rules HOT 1
- Info on SV-COMP 2022? HOT 2
- Repository moved to GitLab HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from sv-benchmarks.