Skip to content
This repository has been archived by the owner on Oct 3, 2021. It is now read-only.

Commit

Permalink
Add benchmark tasks combined from seq-mthreaded/pals_lcr and eca-rers…
Browse files Browse the repository at this point in the history
…2012/Problem12_label0*

Used in 'Dirk Beyer, Marie-Christine Jakobs, Thomas Lemberger: Difference Verification with Conditions, SEFM20'
  • Loading branch information
lembergerth committed Nov 3, 2020
1 parent feb194d commit cbc1944
Show file tree
Hide file tree
Showing 425 changed files with 1,127,506 additions and 0 deletions.
3 changes: 3 additions & 0 deletions c/ReachSafety-Combinations.cfg
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
Description: Contains programs that are combinations of other programs. These programs contain program parts independent of each other and may require different techniques to be successfully verified.
Architecture: 32 bit

1 change: 1 addition & 0 deletions c/ReachSafety-Combinations.set
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
combinations/*.yml
10 changes: 10 additions & 0 deletions c/combinations/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
LEVEL := ../

CLANG_WARNINGS := \
-Wno-sometimes-uninitialized \
-Wno-uninitialized \

include $(LEVEL)/Makefile.config

tasks:
./generate-tasks.py --benchmark-dir ../../ --output-dir ./
34 changes: 34 additions & 0 deletions c/combinations/README.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
This directory contains programs combined from other
benchmark tasks that are available in sv-benchmarks.

The benchmarks were created for evaluation of the work
"Dirk Beyer, Marie-Christine Jakobs, Thomas Lemberger: Difference Verification with Conditions, SEFM 2020."

Tasks were contributed by Marie-Christine Jakobs and Thomas Lemberger.

## Structure of benchmark tasks

Each benchmark task in this directory is created from two other tasks
of other categories, according to the following pattern:

```
/* definitions of Task 1 ... */
int main1() { /* main-method of Task 1 ... */ }
/* definitions of Task 2 ... */
int main2() { /* main-method of Task 2 ... */ }

int main() {
if (__VERIFIER_nondet_int()) {
main1();
} else {
main2();
}
```

Definitions are renamed to avoid conflicts, if necessary.

This construction leads to programs with independent program parts.

The name of each benchmark task reveals its origin:
All task names are created by the pattern ${TASK_1}+${TASK_2}.

218 changes: 218 additions & 0 deletions c/combinations/generate-tasks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,218 @@
#!/usr/bin/env python3

# This file is part of the replication artifact for
# difference verification with conditions:
# https://gitlab.com/sosy-lab/research/data/difference-data
#
# SPDX-FileCopyrightText: 2020 Dirk Beyer <https://sosy-lab.org>
#
# SPDX-License-Identifier: Apache-2.0

import argparse
from pathlib import Path
import yaml
import sys


class TaskError(Exception):
pass


def get_tasks(benchmark_dir: Path, glob_pattern):
for file1 in benchmark_dir.glob(glob_pattern):
input_file = _get_input_file(file1)
try:
verdict = _get_verdict(file1)
except TaskError:
print(
"INFO: Ignoring %s because of missing verdict" % str(file1),
file=sys.stderr,
)
continue
else:
yield input_file, verdict


def _get_input_file(yml_task_def):
with yml_task_def.open() as inp:
yml_content = yaml.safe_load(inp)
return yml_task_def.parent / Path(yml_content["input_files"])


def _get_verdict(yml_task_def):
with yml_task_def.open() as inp:
yml_content = yaml.safe_load(inp)
try:
return next(
p["expected_verdict"]
for p in yml_content["properties"]
if p["property_file"].endswith("unreach-call.prp")
)
except StopIteration:
raise TaskError()


def _create_combo(
file1: Path, file2: Path, replacement1=None, replacement2=None
) -> str:
if replacement1:
repl1 = replacement1
else:
repl1 = lambda x: x
if replacement2:
repl2 = replacement2
else:
repl2 = lambda x: x
with file1.open() as inp:
content1 = "".join(
repl1(line.replace("main(", "main1(")) for line in inp.readlines()
)
with file2.open() as inp:
content2 = "".join(
repl2(line.replace("main(", "main2("))
for line in inp.readlines()
if not line.startswith("extern ")
and not line.startswith("void reach_error")
)

additional_defs = """extern unsigned int __VERIFIER_nondet_uint();
extern char __VERIFIER_nondet_char();
extern int __VERIFIER_nondet_int();
extern long __VERIFIER_nondet_long();
extern unsigned long __VERIFIER_nondet_ulong();
extern float __VERIFIER_nondet_float();
extern void exit(int);
"""

return (
additional_defs
+ content1
+ content2
+ """int main()
{
if(__VERIFIER_nondet_int())
main1();
else
main2();
}"""
)


def _get_yml_content(verdict1, verdict2, input_file: str):
verdict = verdict1 == verdict2 == True
return """format_version: '1.0'
input_files: '%s'
properties:
- property_file: ../properties/unreach-call.prp
expected_verdict: %s""" % (
input_file,
verdict,
)


def create_combos(
pattern1, pattern2, replacement1=None, replacement2=None, output_dir=None
):
tasks1 = list(get_tasks(args.benchmark_dir, pattern1))
tasks2 = list(get_tasks(args.benchmark_dir, pattern2))

output_dir.mkdir(parents=True, exist_ok=True)

for file1, verdict1 in tasks1:
for file2, verdict2 in tasks2:
assert isinstance(verdict1, bool)
assert isinstance(verdict2, bool)
if verdict1 == verdict2 == False:
continue
basename = file1.name[:-2] + "+" + file2.name
c_file = output_dir / Path(basename)
c_content = _create_combo(file1, file2, replacement1, replacement2)
yml_content = _get_yml_content(verdict1, verdict2, c_file.name)
yml_file = output_dir / Path(basename[:-2] + ".yml")

with c_file.open("w") as outp:
outp.write(c_content)
with yml_file.open("w") as outp:
outp.write(yml_content)


def _systemc_replacements1(line) -> str:
return (
line.replace("error(", "error1(")
.replace("init_threads(", "init_threads1(")
.replace("exists_runnable_thread(", "exists_runnable_thread1(")
.replace("eval(", "eval1(")
.replace("init_model(", "init_model1(")
.replace("stop_simulation(", "stop_simulation1(")
.replace("start_simulation(", "start_simulation1(")
.replace("reach_error1(", "reach_error(")
.replace("update_channels(", "update_channels1(")
.replace("fire_delta_events(", "fire_delta_events1(")
.replace("reset_delta_events(", "reset_delta_events1(")
.replace("activate_threads(", "activate_threads1(")
.replace("fire_time_events(", "fire_time_events1(")
.replace("reset_time_events(", "reset_time_events1(")
)


def _systemc_replacements2(line) -> str:
return (
line.replace("error(", "error2(")
.replace("init_threads(", "init_threads2(")
.replace("exists_runnable_thread(", "exists_runnable_thread2(")
.replace("eval(", "eval2(")
.replace("init_model(", "init_model2(")
.replace("stop_simulation(", "stop_simulation2(")
.replace("start_simulation(", "start_simulation2(")
.replace("reach_error2(", "reach_error(")
.replace("update_channels(", "update_channels2(")
.replace("fire_delta_events(", "fire_delta_events2(")
.replace("reset_delta_events(", "reset_delta_events2(")
.replace("activate_threads(", "activate_threads2(")
.replace("fire_time_events(", "fire_time_events2(")
.replace("reset_time_events(", "reset_time_events2(")
)


if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument(
"--benchmark-dir", required=True, help="sv-benchmarks directory"
)
parser.add_argument(
"--output-dir", required=True, help="output directory for created files"
)

args = parser.parse_args()
args.benchmark_dir = Path(args.benchmark_dir)
args.output_dir = Path(args.output_dir)

create_combos(
"c/eca-rers2012/Problem05_label4*.yml",
"c/systemc/token_ring*.yml",
output_dir=args.output_dir,
)
create_combos(
"c/bitvector/gcd_*.yml",
"c/floats-cdfpl/newton_*.yml",
output_dir=args.output_dir,
)
create_combos(
"c/seq-mthreaded/pals_lcr.*.yml",
"c/eca-rers2012/Problem12_label0*.yml",
output_dir=args.output_dir,
)
create_combos(
"c/floats-cdfpl/square*.yml",
"c/bitvector/soft_float_*.yml",
output_dir=args.output_dir,
)
create_combos(
"c/systemc/pc_sfifo*.yml",
"c/systemc/token_ring*.yml",
replacement1=_systemc_replacements1,
replacement2=_systemc_replacements2,
output_dir=args.output_dir,
)
Loading

0 comments on commit cbc1944

Please sign in to comment.