| 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 |  | 
|---|