| 1 | #!/usr/bin/python | 
|---|
| 2 |  | 
|---|
| 3 | import subprocess | 
|---|
| 4 | import os | 
|---|
| 5 | import random | 
|---|
| 6 |  | 
|---|
| 7 | data_dir = 'data' | 
|---|
| 8 | gen_dir = 'generated' | 
|---|
| 9 | test_gen_tool_dir = 'LLSCTestGenerator' | 
|---|
| 10 |  | 
|---|
| 11 | test_gen_binary = 'generate_test' | 
|---|
| 12 |  | 
|---|
| 13 | log_init_name = 'log_init_' | 
|---|
| 14 | log_term_name = 'log_term_' | 
|---|
| 15 |  | 
|---|
| 16 | generated_test = 'test_llsc.c' | 
|---|
| 17 | main_task = 'test_llsc_main.c' | 
|---|
| 18 | task_no_tty = 'test_llsc_no_tty.c' | 
|---|
| 19 |  | 
|---|
| 20 | res_natif = 'res_natif.txt' | 
|---|
| 21 |  | 
|---|
| 22 | # Parametres des tests | 
|---|
| 23 | nb_locks = 20 | 
|---|
| 24 | nb_max_incr = 2000 | 
|---|
| 25 | nb_procs = 4 | 
|---|
| 26 |  | 
|---|
| 27 |  | 
|---|
| 28 | os.chdir(os.path.dirname(__file__)) | 
|---|
| 29 |  | 
|---|
| 30 | scripts_path = os.path.abspath(".") | 
|---|
| 31 | top_path = os.path.abspath("../") | 
|---|
| 32 |  | 
|---|
| 33 | topcell_name = "top.cpp" | 
|---|
| 34 |  | 
|---|
| 35 |  | 
|---|
| 36 | random.seed() | 
|---|
| 37 |  | 
|---|
| 38 |  | 
|---|
| 39 | def get_x_y(nb_procs): | 
|---|
| 40 | x = 1 | 
|---|
| 41 | y = 1 | 
|---|
| 42 | to_x = True | 
|---|
| 43 | while (x * y * 4 < nb_procs): | 
|---|
| 44 | if to_x: | 
|---|
| 45 | x = x * 2 | 
|---|
| 46 | else: | 
|---|
| 47 | y = y * 2 | 
|---|
| 48 | to_x = not to_x | 
|---|
| 49 | return x, y | 
|---|
| 50 |  | 
|---|
| 51 |  | 
|---|
| 52 | print "make -C", test_gen_tool_dir | 
|---|
| 53 | subprocess.call([ 'make', '-C', test_gen_tool_dir ]) | 
|---|
| 54 |  | 
|---|
| 55 | print "cp", os.path.join(test_gen_tool_dir, test_gen_binary), os.path.join(scripts_path, test_gen_binary) | 
|---|
| 56 | subprocess.call([ 'cp', os.path.join(test_gen_tool_dir, test_gen_binary), os.path.join(scripts_path, test_gen_binary)]) | 
|---|
| 57 |  | 
|---|
| 58 | print "mkdir -p", os.path.join(scripts_path, data_dir) | 
|---|
| 59 | subprocess.call([ 'mkdir', '-p', os.path.join(scripts_path, data_dir) ]) | 
|---|
| 60 |  | 
|---|
| 61 | while True: | 
|---|
| 62 | x, y = get_x_y(nb_procs) | 
|---|
| 63 |  | 
|---|
| 64 | b0 = random.randint(0, 1) | 
|---|
| 65 | b1 = random.randint(0, 1) | 
|---|
| 66 |  | 
|---|
| 67 | print test_gen_binary, nb_procs, nb_max_incr, nb_locks, b0, b1, generated_test, main_task, task_no_tty | 
|---|
| 68 | tab_size = subprocess.Popen([ os.path.join(scripts_path, test_gen_binary), str(nb_procs), str(nb_max_incr), str(nb_locks), str(b0), str(b1), generated_test, main_task, task_no_tty ], stdout = subprocess.PIPE).communicate()[0] | 
|---|
| 69 |  | 
|---|
| 70 | print "make -f Makefile.nat" | 
|---|
| 71 | subprocess.call([ 'make', '-f', 'Makefile.nat' ]) | 
|---|
| 72 |  | 
|---|
| 73 | print "./test_natif >", os.path.join(data_dir, res_natif) | 
|---|
| 74 | output = subprocess.Popen([ './test_natif' ], stdout = subprocess.PIPE).communicate()[0] | 
|---|
| 75 | file = open(os.path.join(data_dir, res_natif), 'w') | 
|---|
| 76 | file.write(output) | 
|---|
| 77 | file.close() | 
|---|
| 78 |  | 
|---|
| 79 | print "./test_llsc.py", str(x), str(y), tab_size | 
|---|
| 80 | subprocess.call([ './test_llsc.py', str(x), str(y), tab_size ]) | 
|---|
| 81 |  | 
|---|
| 82 | print "cd", top_path | 
|---|
| 83 | os.chdir(top_path) | 
|---|
| 84 | print "touch", topcell_name | 
|---|
| 85 | subprocess.call([ 'touch', topcell_name ]) | 
|---|
| 86 | print "make" | 
|---|
| 87 | subprocess.call([ 'make' ]) | 
|---|
| 88 |  | 
|---|
| 89 | # Launch simulation | 
|---|
| 90 | print "./simul.x >", os.path.join(scripts_path, data_dir, log_init_name + str(nb_procs)) | 
|---|
| 91 | output = subprocess.Popen([ './simul.x' ], stdout = subprocess.PIPE).communicate()[0] | 
|---|
| 92 |  | 
|---|
| 93 | # Write simulation results to data directory | 
|---|
| 94 | print "cd", scripts_path | 
|---|
| 95 | os.chdir(scripts_path) | 
|---|
| 96 | filename = os.path.join(data_dir, log_init_name + str(nb_procs)) | 
|---|
| 97 | file = open(filename, 'w') | 
|---|
| 98 | file.write(output) | 
|---|
| 99 | file.close() | 
|---|
| 100 |  | 
|---|
| 101 | term_filename = os.path.join(scripts_path, data_dir, log_term_name + str(nb_procs)) | 
|---|
| 102 | print "mv", os.path.join(top_path, 'term1'), term_filename | 
|---|
| 103 | subprocess.call([ 'mv', os.path.join(top_path, 'term1'), term_filename ]) | 
|---|
| 104 |  | 
|---|
| 105 | # Quit if results obtained by simulation are incorrect | 
|---|
| 106 | print "diff", term_filename, os.path.join(data_dir, res_natif) | 
|---|
| 107 | output = subprocess.Popen([ 'diff', term_filename, os.path.join(data_dir, res_natif) ]).communicate()[0] | 
|---|
| 108 | if output != None: | 
|---|
| 109 | break; | 
|---|
| 110 |  | 
|---|
| 111 |  | 
|---|
| 112 | ## Enf of simulations | 
|---|
| 113 |  | 
|---|
| 114 |  | 
|---|
| 115 |  | 
|---|
| 116 |  | 
|---|
| 117 |  | 
|---|
| 118 |  | 
|---|
| 119 |  | 
|---|
| 120 |  | 
|---|
| 121 |  | 
|---|