code refactor

This commit is contained in:
Adnan Hodzic 2020-02-08 21:04:34 +01:00
parent 16bc315da2
commit 29b85b8095
3 changed files with 29 additions and 18 deletions

View File

@ -96,9 +96,12 @@ def main(monitor, live, daemon, install, log):
root_check() root_check()
s.run("snapctl set daemon=disabled", shell=True) s.run("snapctl set daemon=disabled", shell=True)
s.run("snapctl stop --disable auto-cpufreq", shell=True) s.run("snapctl stop --disable auto-cpufreq", shell=True)
delete_file(auto_cpufreq_log_file)
remove_complete_msg()
else: else:
root_check() root_check()
remove() remove()
remove_complete_msg()
if __name__ == '__main__': if __name__ == '__main__':
# while True: # while True:

View File

@ -24,6 +24,4 @@ echo -e "\n* Reloading systemd manager configuration"
systemctl daemon-reload systemctl daemon-reload
echo -e "reset failed" echo -e "reset failed"
systemctl reset-failed systemctl reset-failed
echo -e "\n-------------------------------------------------------------------------------\n"

View File

@ -24,7 +24,12 @@ s = subprocess
cpus = os.cpu_count() cpus = os.cpu_count()
# get turbo boost state # get turbo boost state
cur_turbo = s.getoutput("cat /sys/devices/system/cpu/intel_pstate/no_turbo") turbo_loc = "/sys/devices/system/cpu/intel_pstate/no_turbo"
cur_turbo = s.getoutput("cat " + turbo_loc)
# govs/script loc
avail_gov_loc = "/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors"
scripts_dir = "/usr/local/share/auto-cpufreq/scripts/"
# get current scaling governor # get current scaling governor
get_cur_gov = s.getoutput("cpufreqctl --governor") get_cur_gov = s.getoutput("cpufreqctl --governor")
@ -37,7 +42,7 @@ bat_state = power.PowerManagement().get_providing_power_source_type()
auto_cpufreq_log_file = "/var/log/auto-cpufreq.log" auto_cpufreq_log_file = "/var/log/auto-cpufreq.log"
# daemon check # daemon check
dcheck = subprocess.getoutput("snapctl get daemon") dcheck = s.getoutput("snapctl get daemon")
# deploy cpufreqctl script # deploy cpufreqctl script
def cpufreqctl(): def cpufreqctl():
@ -49,7 +54,7 @@ def cpufreqctl():
if os.path.isfile("/usr/bin/cpufreqctl"): if os.path.isfile("/usr/bin/cpufreqctl"):
pass pass
else: else:
os.system("cp /usr/local/share/auto-cpufreq/scripts/cpufreqctl.sh /usr/bin/cpufreqctl") os.system("cp " + scripts_dir + "cpufreqctl.sh /usr/bin/cpufreqctl")
# print footer func # print footer func
def footer(l): def footer(l):
@ -61,6 +66,11 @@ def deploy_complete_msg():
print("\nTo disable and remove auto-cpufreq daemon, run:\nsudo auto-cpufreq --remove") print("\nTo disable and remove auto-cpufreq daemon, run:\nsudo auto-cpufreq --remove")
footer(79) footer(79)
def remove_complete_msg():
print("\n" + "-" * 25 + " auto-cpufreq daemon removed " + "-" * 25 + "\n")
print("auto-cpufreq successfully removed.")
footer(79)
# deploy auto-cpufreq daemon # deploy auto-cpufreq daemon
def deploy(): def deploy():
@ -86,10 +96,10 @@ def deploy():
create_file(auto_cpufreq_log_file) create_file(auto_cpufreq_log_file)
print("\n* Deploy auto-cpufreq install script") print("\n* Deploy auto-cpufreq install script")
os.system("cp /usr/local/share/auto-cpufreq/scripts/auto-cpufreq-install.sh /usr/bin/auto-cpufreq-install") os.system("cp " + scripts_dir + "/auto-cpufreq-install.sh /usr/bin/auto-cpufreq-install")
print("\n* Deploy auto-cpufreq remove script") print("\n* Deploy auto-cpufreq remove script")
os.system("cp /usr/local/share/auto-cpufreq/scripts/auto-cpufreq-remove.sh /usr/bin/auto-cpufreq-remove") os.system("cp " + scripts_dir + "/auto-cpufreq-remove.sh /usr/bin/auto-cpufreq-remove")
# run auto-cpufreq daemon deploy script # run auto-cpufreq daemon deploy script
s.call("/usr/bin/auto-cpufreq-install", shell=True) s.call("/usr/bin/auto-cpufreq-install", shell=True)
@ -123,7 +133,7 @@ def remove():
# check for necessary scaling governors # check for necessary scaling governors
def gov_check(): def gov_check():
avail_gov = "/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors" avail_gov = avail_gov_loc
governors=["performance","powersave"] governors=["performance","powersave"]
@ -170,15 +180,15 @@ def set_powersave():
# conditions for setting turbo in powersave # conditions for setting turbo in powersave
if load1m > cpus: if load1m > cpus:
print("High load, setting turbo boost: on") print("High load, setting turbo boost: on")
s.run("echo 0 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 0 > " + turbo_loc, shell=True)
footer(79) footer(79)
elif cpuload > 50: elif cpuload > 50:
print("High CPU load, setting turbo boost: on") print("High CPU load, setting turbo boost: on")
s.run("echo 0 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 0 > " + turbo_loc, shell=True)
footer(79) footer(79)
else: else:
print("Load optimal, setting turbo boost: off") print("Load optimal, setting turbo boost: off")
s.run("echo 1 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 1 > " + turbo_loc, shell=True)
footer(79) footer(79)
# make turbo suggestions in powersave # make turbo suggestions in powersave
@ -231,15 +241,15 @@ def set_performance():
# conditions for setting turbo in performance # conditions for setting turbo in performance
if load1m > 1: if load1m > 1:
print("High load, setting turbo boost: on") print("High load, setting turbo boost: on")
s.run("echo 0 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 0 > " + turbo_loc, shell=True)
footer(79) footer(79)
elif cpuload > 20: elif cpuload > 20:
print("High CPU load, setting turbo boost: on") print("High CPU load, setting turbo boost: on")
s.run("echo 0 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 0 > " + turbo_loc, shell=True)
footer(79) footer(79)
else: else:
print("Load optimal, setting turbo boost: off") print("Load optimal, setting turbo boost: off")
s.run("echo 1 > /sys/devices/system/cpu/intel_pstate/no_turbo", shell=True) s.run("echo 1 > " + turbo_loc, shell=True)
footer(79) footer(79)
# make turbo suggestions in performance # make turbo suggestions in performance
@ -391,12 +401,12 @@ def read_log():
# check if program (argument) is running # check if program (argument) is running
def is_running(program, argument): def is_running(program, argument):
# iterate over all process id's found by psutil # iterate over all process id's found by psutil
for pid in psutil.pids(): for pid in psutil.pids():
try: try:
# requests the process information corresponding to each process id # requests the process information corresponding to each process id
p = psutil.Process(pid) p = psutil.Process(pid)
# check if value of program-variable that was used to call the function matches the name field of the plutil.Process(pid) output # check if value of program-variable that was used to call the function matches the name field of the plutil.Process(pid) output
if program in p.name(): if program in p.name():
# check output of p.name(), output name of program # check output of p.name(), output name of program
# p.cmdline() - echo the exact command line via which p was called. # p.cmdline() - echo the exact command line via which p was called.
for arg in p.cmdline(): for arg in p.cmdline():