-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_command.py
executable file
·136 lines (123 loc) · 5.48 KB
/
run_command.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
import os
import json
import argparse
import subprocess
import time
class Run():
'''The engine of starting our framework'''
'''get the json file from the command line'''
def __init__(self):
parser = argparse.ArgumentParser()
parser.add_argument('-c', '--config_file',
required=True, help='JSON config file')
args = parser.parse_args()
self.myjson=args.config_file
with open(self.myjson, 'r') as myconfig:
self.config_data = json.load(myconfig)
root_directory = os.path.dirname(os.path.abspath(__file__))
output_file=self.config_data["subfile"]
self.out_folder=root_directory+"/"+self.config_data["paths"]["outpath"]
self.output_path=root_directory+"/"+self.config_data["paths"]["outpath"] +"/"+output_file
'''create the output folder'''
def mkdir_outputs(self):
if (os.path.exists(self.out_folder))==False:
os.system("mkdir "+self.out_folder)
if (os.path.exists(self.output_path))==False:
os.system("mkdir "+self.output_path)
print("Output path:"+self.output_path)
'''collect the profiling information'''
def run_perf(self,print_it):
print("Getting performance data ......")
run_perf_command="python3 ./Profile/run_benchmarks.py -c "+ self.myjson
if print_it:
print("Run command: "+run_perf_command)
os.system(run_perf_command)
'''get the identified hotspots'''
def identified_hotspot(self,print_it):
print("Identifying hotspots ......")
output_hotspot_command="python3 ./Profile/output_identified_hotspots.py -c "+ self.myjson
if print_it:
print("Run command: "+output_hotspot_command)
os.system(output_hotspot_command)
''' instrumentation based on the function name'''
def instrument_hotspot(self,print_it):
print("Instrumenting multiple hotspots ......")
instrument_command="python3 ./Instrumentation/instrument_multi_hotspot.py -c "+ self.myjson
if print_it:
print("Run command: "+instrument_command)
os.system(instrument_command)
''' instrumentation based on the range of logical address'''
def instrument_logical_address(self,print_it):
print("Instrumenting logical address......")
instrument_command="python3 ./Instrumentation/instrument_logical_address.py -c "+ self.myjson
if print_it==True:
print("Run command: "+instrument_command)
os.system(instrument_command)
''' load the list of identified hotspots'''
def load_hotspot_list(self,app_name):
app_output=self.output_path+"/"+app_name+"_identified_hotspots.json"
f = open(app_output)
data = json.load(f)
f.close()
return [i for i in data]
'''get the list of screen's label that we define'''
def obtain_screen_label_list(self):
screen_label_list=[]
for app in ["application1","application2"]:
app_name=self.config_data["application"][app]
hotspot_lists=self.load_hotspot_list(app_name)
for hotspot in hotspot_lists:
screen_label_list.append(app_name+"_"+hotspot)
return screen_label_list
'''get the process list of screen's label '''
def obtain_screen_proc_dict(self):
proc_dict=dict()
screen_label_list=self.obtain_screen_label_list()
return_code, output = subprocess.getstatusoutput('screen -ls')
text_list=[text for text in output.split("\n") if "." in text and "\t" in text]
for text in text_list:
a=text.split("\t")[1]
label=a.split(".")
number=label[0]
name=".".join(label[1:])
if name in screen_label_list:
proc_dict[number]=name
return proc_dict
''' monitor the progress of instrumentation program'''
def output_instrument_proc(self):
dicts=self.obtain_screen_proc_dict()
total_counter=len(dicts)
counter=0
second=int(self.config_data["sleep_second"])
while True:
pid_list=[i for i in dicts]
for pid in pid_list:
process_dir = os.path.join('/proc', pid)
if os.path.exists(process_dir)==False:
counter+=1
print(dicts[pid]+" instrumentation tool is finished("+str(counter)+"/"+str(total_counter)+")")
dicts.pop(pid)
if counter==total_counter:
break
time.sleep(second)
'''output the instrumentation result'''
def report(self,print_it):
print("Printing results......")
report_command="python3 ./Instrumentation/output_result.py -c "+ self.myjson
if print_it:
print("Run command: "+report_command)
os.system(report_command)
'''the startup engine of program'''
def main(self,print_command):
self.mkdir_outputs()
if self.config_data["runmode"]["logical_address"]=="true":
self.instrument_logical_address(print_command)
if self.config_data["runmode"]["function_name"]=="true":
self.run_perf(print_command)
self.identified_hotspot(print_command)
self.instrument_hotspot(print_command)
self.output_instrument_proc()
self.report(print_command)
if __name__=="__main__":
demo=Run()
demo.main(print_command=False)