X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/97e2219ed6c0e511f6165460cec79afadf42f589..cb3dd47fc3ee91fbf921e02078184253ef3f775d:/teshsuite/smpi/MBI/RMARemoteRemoteConcurrencyGenerator.py diff --git a/teshsuite/smpi/MBI/RMARemoteRemoteConcurrencyGenerator.py b/teshsuite/smpi/MBI/RMARemoteRemoteConcurrencyGenerator.py index 10e421ca99..9361187b41 100755 --- a/teshsuite/smpi/MBI/RMARemoteRemoteConcurrencyGenerator.py +++ b/teshsuite/smpi/MBI/RMARemoteRemoteConcurrencyGenerator.py @@ -1,7 +1,7 @@ #! /usr/bin/python3 import os import sys -from generator_utils import * +import generator_utils as gen template = """// @{generatedby}@ /* ///////////////////////// The MPI Bugs Initiative //////////////////////// @@ -25,7 +25,7 @@ BEGIN_MPI_FEATURES END_MPI_FEATURES BEGIN_MBI_TESTS - $ mpirun -np 2 ${EXE} + $ mpirun -np 3 ${EXE} | @{outcome}@ | @{errormsg}@ END_MBI_TESTS @@ -57,12 +57,16 @@ int main(int argc, char **argv) { MPI_Win_create(&winbuf, 100 * sizeof(int), sizeof(int), MPI_INFO_NULL, MPI_COMM_WORLD, &win); @{init1}@ + @{init2}@ @{epoch}@ - if (rank == 0 || rank == 2) { + if (rank == 0) { @{operation1}@ /* MBIERROR1 */ } + else if (rank == 2) { + @{operation2}@ /* MBIERROR2 */ + } @{finEpoch}@ @@ -74,24 +78,27 @@ int main(int argc, char **argv) { """ -for e in epoch: - for p1 in get + put: - patterns = {} - patterns = {'e': e, 'p1': p1} - patterns['generatedby'] = f'DO NOT EDIT: this file was generated by {os.path.basename(sys.argv[0])}. DO NOT EDIT.' - patterns['rmafeature'] = 'Yes' - patterns['p1'] = p1 - patterns['e'] = e - patterns['epoch'] = epoch[e]("1") - patterns['finEpoch'] = finEpoch[e]("1") - patterns['init1'] = init[p1]("1") - patterns['operation1'] = operation[p1]("1") - - # Generate a data race (Get + Get/load/store/Put) - replace = patterns - replace['shortdesc'] = 'Global Concurrency error.' - replace['longdesc'] = 'Global Concurrency error. Both processes 0 and 2 access the window in process 1 with @{p1}@' - replace['outcome'] = 'ERROR: GlobalConcurrency' - replace['errormsg'] = 'Global Concurrency error. @{p1}@ at @{filename}@:@{line:MBIERROR1}@ conflicts in process 1' - make_file(template, f'GlobalConcurrency_rr_{e}_{p1}_nok.c', replace) - +for e in gen.epoch: + for p1 in gen.get + gen.put: + for p2 in gen.put: + patterns = {} + patterns = {'e': e, 'p1': p1, 'p2': p2} + patterns['generatedby'] = f'DO NOT EDIT: this file was generated by {os.path.basename(sys.argv[0])}. DO NOT EDIT.' + patterns['rmafeature'] = 'Yes' + patterns['p1'] = p1 + patterns['p2'] = p2 + patterns['e'] = e + patterns['epoch'] = gen.epoch[e]("1") + patterns['finEpoch'] = gen.finEpoch[e]("1") + patterns['init1'] = gen.init[p1]("1") + patterns['operation1'] = gen.operation[p1]("1") + patterns['init2'] = gen.init[p2]("2") + patterns['operation2'] = gen.operation[p2]("2") + + # Generate a data race + replace = patterns.copy() + replace['shortdesc'] = 'Global Concurrency error.' + replace['longdesc'] = 'Global Concurrency error. Both processes 0 and 2 access the window in process 1 with @{p1}@' + replace['outcome'] = 'ERROR: GlobalConcurrency' + replace['errormsg'] = 'Global Concurrency error. @{p1}@ at @{filename}@:@{line:MBIERROR1}@ and @{p2}@ at @{filename}@:@{line:MBIERROR2}@ conflicts in process 1' + gen.make_file(template, f'GlobalConcurrency_rr_{e}_{p1}_{p2}_nok.c', replace)