X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/4e03f78d2ffac18f4e8ffa7016a3cec61bbad03a..35a644bdf9d0c5603c9483f03f913e4a649638d6:/teshsuite/smpi/MBI/RMALocalLocalConcurrencyGenerator.py diff --git a/teshsuite/smpi/MBI/RMALocalLocalConcurrencyGenerator.py b/teshsuite/smpi/MBI/RMALocalLocalConcurrencyGenerator.py index 5e57e17e2c..a34c0ea41e 100755 --- a/teshsuite/smpi/MBI/RMALocalLocalConcurrencyGenerator.py +++ b/teshsuite/smpi/MBI/RMALocalLocalConcurrencyGenerator.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 //////////////////////// @@ -11,17 +11,17 @@ template = """// @{generatedby}@ Description: @{shortdesc}@ @{longdesc}@ - Version of MPI: Conforms to MPI 2, requires MPI 3 implementation (for lock_all/unlock_all epochs) + Version of MPI: Conforms to MPI 2, requires MPI 3 implementation (for lock_all/unlock_all epochs) BEGIN_MPI_FEATURES - P2P!basic: Lacking - P2P!nonblocking: Lacking - P2P!persistent: Lacking - COLL!basic: Lacking - COLL!nonblocking: Lacking - COLL!persistent: Lacking - COLL!tools: Lacking - RMA: @{rmafeature}@ + P2P!basic: Lacking + P2P!nonblocking: Lacking + P2P!persistent: Lacking + COLL!basic: Lacking + COLL!nonblocking: Lacking + COLL!persistent: Lacking + COLL!tools: Lacking + RMA: @{rmafeature}@ END_MPI_FEATURES BEGIN_MBI_TESTS @@ -40,7 +40,7 @@ END_MBI_TESTS int main(int argc, char **argv) { int nprocs = -1; int rank = -1; - MPI_Win win; + MPI_Win win; int winbuf[100] = {0}; MPI_Init(&argc, &argv); @@ -51,20 +51,20 @@ int main(int argc, char **argv) { if (nprocs < 2) printf("MBI ERROR: This test needs at least 2 processes to produce a bug!\\n"); - MPI_Datatype type = MPI_INT; - int target = 1; + MPI_Datatype type = MPI_INT; + int target = 1; MPI_Win_create(&winbuf, 100 * sizeof(int), sizeof(int), MPI_INFO_NULL, MPI_COMM_WORLD, &win); - winbuf[0] = 12345; - @{init1}@ + winbuf[0] = 12345; + @{init1}@ @{epoch}@ - if (rank == 0) { - @{operation1}@ /* MBIERROR1 */ - @{operation2}@ /* MBIERROR2 */ - } + if (rank == 0) { + @{operation1}@ /* MBIERROR1 */ + @{operation2}@ /* MBIERROR2 */ + } @{finEpoch}@ @@ -76,89 +76,90 @@ int main(int argc, char **argv) { """ -for e in epoch: - for p1 in get: - for p2 in put + store + load + get + loadstore: +for e in gen.epoch: + for p1 in gen.get: + for p2 in gen.put + gen.store + gen.load + gen.get + gen.loadstore: 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['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'] = epoch[e]("1") - patterns['finEpoch'] = finEpoch[e]("1") - patterns['init1'] = init[p1]("1") - patterns['operation1'] = operation[p1]("1") - patterns['operation2'] = operation[p2]("1") - - # Generate a data race (Get + Get/load/store/Put) - replace = patterns - replace['shortdesc'] = 'Local Concurrency error.' - replace['longdesc'] = 'Local Concurrency error. @{p2}@ conflicts with @{p1}@' - replace['outcome'] = 'ERROR: LocalConcurrency' + 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['operation2'] = gen.operation[p2]("1") + shortdesc_rma = 'Correct code using RMA operations' + + # Generate a data race (Get + Get/load/store/Put) + replace = patterns.copy() + replace['shortdesc'] = 'Local Concurrency error.' + replace['longdesc'] = 'Local Concurrency error. @{p2}@ conflicts with @{p1}@' + replace['outcome'] = 'ERROR: LocalConcurrency' replace['errormsg'] = 'Local Concurrency error. @{p2}@ at @{filename}@:@{line:MBIERROR2}@ conflicts with @{p1}@ line @{line:MBIERROR1}@' - make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p1}_{p2}_nok.c', replace) - # Generate a correct code by switching operation1 and operation2 - if p2 in store + load + loadstore: - replace = patterns - replace['shortdesc'] = 'Correct code using RMA operations' - replace['longdesc'] = 'Correct code using RMA operations' - replace['outcome'] = 'OK' - replace['errormsg'] = 'OK' - replace['operation1'] = operation[p2]("1") - replace['operation2'] = operation[p1]("1") - make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p2}_{p1}_ok.c', replace) - # Generate a correct code by removing operation2 - replace = patterns - replace['shortdesc'] = 'Correct code using RMA operations' - replace['longdesc'] = 'Correct code using RMA operations' - replace['outcome'] = 'OK' + gen.make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p1}_{p2}_nok.c', replace) + # Generate a correct code by switching operation1 and operation2 + if p2 in gen.store + gen.load + gen.loadstore: + replace = patterns.copy() + replace['shortdesc'] = shortdesc_rma + replace['longdesc'] = shortdesc_rma + replace['outcome'] = 'OK' + replace['errormsg'] = 'OK' + replace['operation1'] = gen.operation[p2]("1") + replace['operation2'] = gen.operation[p1]("1") + gen.make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p2}_{p1}_ok.c', replace) + # Generate a correct code by removing operation2 + replace = patterns.copy() + replace['shortdesc'] = shortdesc_rma + replace['longdesc'] = shortdesc_rma + replace['outcome'] = 'OK' replace['errormsg'] = 'OK' - replace['operation1'] = operation[p1]("1") + replace['operation1'] = gen.operation[p1]("1") replace['operation2'] = '' - make_file(template, f'LocalConcurrency_{e}_{p1}_ok.c', replace) + gen.make_file(template, f'LocalConcurrency_{e}_{p1}_ok.c', replace) -for e in epoch: - for p1 in put: - for p2 in store: +for e in gen.epoch: + for p1 in gen.put: + for p2 in gen.store: 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['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'] = epoch[e]("1") - patterns['finEpoch'] = finEpoch[e]("1") - patterns['init1'] = init[p1]("1") - patterns['operation1'] = operation[p1]("1") - patterns['operation2'] = operation[p2]("1") - - # Generate a data race (Put + store) - replace = patterns - replace['shortdesc'] = 'Local Concurrency error.' - replace['longdesc'] = 'Local Concurrency error. @{p2}@ conflicts with @{p1}@' - replace['outcome'] = 'ERROR: LocalConcurrency' + 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['operation2'] = gen.operation[p2]("1") + + # Generate a data race (Put + store) + replace = patterns.copy() + replace['shortdesc'] = 'Local Concurrency error.' + replace['longdesc'] = 'Local Concurrency error. @{p2}@ conflicts with @{p1}@' + replace['outcome'] = 'ERROR: LocalConcurrency' replace['errormsg'] = 'Local Concurrency error. @{p2}@ at @{filename}@:@{line:MBIERROR2}@ conflicts with @{p1}@ line @{line:MBIERROR1}@' - make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p1}_{p2}_nok.c', replace) - # Generate a correct code by switching operation1 and operation2 - replace = patterns - replace['shortdesc'] = 'Correct code using RMA operations' - replace['longdesc'] = 'Correct code using RMA operations' - replace['outcome'] = 'OK' + gen.make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p1}_{p2}_nok.c', replace) + # Generate a correct code by switching operation1 and operation2 + replace = patterns.copy() + replace['shortdesc'] = shortdesc_rma + replace['longdesc'] = shortdesc_rma + replace['outcome'] = 'OK' replace['errormsg'] = 'OK' - replace['operation1'] = operation[p2]("1") - replace['operation2'] = operation[p1]("1") - make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p2}_{p1}_ok.c', replace) - - # Generate a correct code by removing operation2 - replace = patterns - replace['shortdesc'] = 'Correct code using RMA operations' - replace['longdesc'] = 'Correct code using RMA operations' - replace['outcome'] = 'OK' + replace['operation1'] = gen.operation[p2]("1") + replace['operation2'] = gen.operation[p1]("1") + gen.make_file(template, f'LocalConcurrency_lloutwindow_{e}_{p2}_{p1}_ok.c', replace) + + # Generate a correct code by removing operation2 + replace = patterns.copy() + replace['shortdesc'] = shortdesc_rma + replace['longdesc'] = shortdesc_rma + replace['outcome'] = 'OK' replace['errormsg'] = 'OK' - replace['operation1'] = operation[p1]("1") + replace['operation1'] = gen.operation[p1]("1") replace['operation2'] = '' - make_file(template, f'LocalConcurrency_{e}_{p1}_ok.c', replace) + gen.make_file(template, f'LocalConcurrency_{e}_{p1}_ok.c', replace)