mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-16 10:17:32 +00:00
perf hwmon_pmu: Use openat rather than dup to refresh directory
The hwmon PMU test will make a temp directory, open the directory with O_DIRECTORY then fill it with contents. As the open is before the filling the contents the later fdopendir may reflect the initial empty state, meaning no events are seen. Change to re-open the directory, rather than dup the fd, so the latest contents are seen. Minor tweaks/additions to debug messages. Signed-off-by: Ian Rogers <irogers@google.com> Tested-by: Arnaldo Carvalho de Melo <acme@kernel.org> Link: https://lore.kernel.org/r/20241206042306.1055913-1-irogers@google.com Signed-off-by: Namhyung Kim <namhyung@kernel.org>
This commit is contained in:
parent
246dfe3dc1
commit
3f61a12b08
@ -258,8 +258,12 @@ static int hwmon_pmu__read_events(struct hwmon_pmu *pmu)
|
|||||||
if (pmu->pmu.sysfs_aliases_loaded)
|
if (pmu->pmu.sysfs_aliases_loaded)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* Use a dup-ed fd as closedir will close it. */
|
/*
|
||||||
dup_fd = dup(pmu->hwmon_dir_fd);
|
* Use a dup-ed fd as closedir will close it. Use openat so that the
|
||||||
|
* directory contents are refreshed.
|
||||||
|
*/
|
||||||
|
dup_fd = openat(pmu->hwmon_dir_fd, ".", O_DIRECTORY);
|
||||||
|
|
||||||
if (dup_fd == -1)
|
if (dup_fd == -1)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
@ -336,6 +340,9 @@ static int hwmon_pmu__read_events(struct hwmon_pmu *pmu)
|
|||||||
close(fd);
|
close(fd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (hashmap__size(&pmu->events) == 0)
|
||||||
|
pr_debug2("hwmon_pmu: %s has no events\n", pmu->pmu.name);
|
||||||
|
|
||||||
hashmap__for_each_entry_safe((&pmu->events), cur, tmp, bkt) {
|
hashmap__for_each_entry_safe((&pmu->events), cur, tmp, bkt) {
|
||||||
union hwmon_pmu_event_key key = {
|
union hwmon_pmu_event_key key = {
|
||||||
.type_and_num = cur->key,
|
.type_and_num = cur->key,
|
||||||
@ -343,8 +350,8 @@ static int hwmon_pmu__read_events(struct hwmon_pmu *pmu)
|
|||||||
struct hwmon_pmu_event_value *value = cur->pvalue;
|
struct hwmon_pmu_event_value *value = cur->pvalue;
|
||||||
|
|
||||||
if (!test_bit(HWMON_ITEM_INPUT, value->items)) {
|
if (!test_bit(HWMON_ITEM_INPUT, value->items)) {
|
||||||
pr_debug("hwmon_pmu: removing event '%s%d' that has no input file\n",
|
pr_debug("hwmon_pmu: %s removing event '%s%d' that has no input file\n",
|
||||||
hwmon_type_strs[key.type], key.num);
|
pmu->pmu.name, hwmon_type_strs[key.type], key.num);
|
||||||
hashmap__delete(&pmu->events, key.type_and_num, &key, &value);
|
hashmap__delete(&pmu->events, key.type_and_num, &key, &value);
|
||||||
zfree(&value->label);
|
zfree(&value->label);
|
||||||
zfree(&value->name);
|
zfree(&value->name);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user