diff options
author | Daniel Friesel <derf@finalrewind.org> | 2019-03-04 15:15:54 +0100 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2019-03-04 15:16:10 +0100 |
commit | 4e37798145fa03bd90880f4ac315529190472eaf (patch) | |
tree | d6051e435941d9a4a9ea21f81624d87be1d818b9 /bin/generate-dfa-benchmark.py | |
parent | 9abd39d11da2db4d5804d4e8199578bfa3aa9164 (diff) |
generate PTA from YAML model, support several types of test harness
Diffstat (limited to 'bin/generate-dfa-benchmark.py')
-rwxr-xr-x | bin/generate-dfa-benchmark.py | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/bin/generate-dfa-benchmark.py b/bin/generate-dfa-benchmark.py index 1eb5073..87cb662 100755 --- a/bin/generate-dfa-benchmark.py +++ b/bin/generate-dfa-benchmark.py @@ -4,7 +4,9 @@ import getopt import json import re import sys +import yaml from automata import PTA +from harness import TransitionHarness opt = {} @@ -37,30 +39,37 @@ if __name__ == '__main__': modelfile = args[0] with open(modelfile, 'r') as f: - pta = PTA.from_json(json.load(f)) + if '.json' in modelfile: + pta = PTA.from_json(json.load(f)) + else: + pta = PTA.from_yaml(yaml.safe_load(f)) + + harness = TransitionHarness('GPIO::p1_0') + + print('#include "arch.h"') + print(harness.global_code()) - print('ptalog.startBenchmark(0);') + print(harness.start_benchmark()) for run in pta.dfs(opt['depth'], with_arguments = True): - print('ptalog.reset();') + print(harness.start_run()) for transition, arguments in run: print('// {} -> {}'.format(transition.origin.name, transition.destination.name)) - print('ptalog.passTransition({:d});'.format(pta.get_transition_id(transition))) if transition.is_interrupt: print('// wait for {} interrupt'.format(transition.name)) - print('// TODO add startTransition / stopTransition calls to interrupt routine') + transition_code = '// TODO add startTransition / stopTransition calls to interrupt routine' else: - print('ptalog.startTransition();') if 'instance' in opt: - print('{}.{}({});'.format(opt['instance'], transition.name, ', '.join(arguments))) + transition_code = '{}.{}({});'.format(opt['instance'], transition.name, ', '.join(map(str, arguments))) else: - print('{}({});'.format(transition.name, ', '.join(arguments))) - print('ptalog.stopTransition();') + transition_code = '{}({});'.format(transition.name, ', '.join(arguments)) + print(harness.pass_transition(pta.get_transition_id(transition), transition_code)) if 'sleep' in opt: print('arch.delay_ms({:d});'.format(opt['sleep'])) - print('ptalog.dump();') + print(harness.stop_run()) print() + print(harness.stop_benchmark()) sys.exit(0) |