Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[MBI] Fix string types.
[simgrid.git] / teshsuite / smpi / MBI / RMALocalLocalConcurrencyGenerator.py
index 5e57e17..00777e3 100755 (executable)
@@ -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,89 @@ 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")
+
+            # 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'
             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
+                replace['shortdesc'] = 'Correct code using RMA operations'
+                replace['longdesc'] = 'Correct code using RMA operations'
+                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
+        replace['shortdesc'] = 'Correct code using RMA operations'
+        replace['longdesc'] = 'Correct code using RMA operations'
+        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
+            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
+            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' 
+            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
+            replace['shortdesc'] = 'Correct code using RMA operations'
+            replace['longdesc'] = 'Correct code using RMA operations'
+            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)