Skip to content

Commit

Permalink
Merge pull request #30 from criteo/issue25
Browse files Browse the repository at this point in the history
tuning: Avoid crash in PerformancePowerProfile
  • Loading branch information
ErwanAliasr1 authored Aug 19, 2024
2 parents 1669f9f + 5101fa4 commit bf69cb7
Showing 1 changed file with 12 additions and 7 deletions.
19 changes: 12 additions & 7 deletions hwbench/tuning/power_profile.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,13 @@ def __init__(self, out_dir):
self.out_dir = out_dir
self.skip_tuning = False

available_governors = (
pathlib.Path("/sys/devices/system/cpu/cpuidle/available_governors")
current_governor = (
pathlib.Path("/sys/devices/system/cpu/cpuidle/current_governor")
.read_text("ascii")
.strip()
.split()
)
self.skip_tuning |= (
len(available_governors) == 1 and available_governors[0] == "menu"
)
self.skip_tuning |= current_governor == "menu"

def run(self) -> None:
log = tunninglog()
Expand All @@ -29,8 +27,15 @@ def run(self) -> None:
for rootpath, dirnames, filenames in os.walk("/sys/devices/system/cpu"):
for dirname in dirnames:
if pattern.match(dirname):
cpudir = pathlib.Path(rootpath) / dirname
file = cpudir / "cpufreq/scaling_governor"
file = pathlib.Path(rootpath).joinpath(
dirname, "cpufreq", "scaling_governor"
)
# Ignore this tuning if no scaling_governor available
if not file.exists():
log.info(
f"skip PerformancePowerProfile for {dirname} as no scaling governor detected"
)
continue
previous = file.read_text(encoding="utf-8").rstrip()
# please read https://www.kernel.org/doc/html/latest/admin-guide/pm/cpufreq.html
# for more explanation
Expand Down

0 comments on commit bf69cb7

Please sign in to comment.