Loading...
1// SPDX-License-Identifier: GPL-2.0-only
2#include <string.h>
3#include "api/fs/fs.h"
4#include "cputopo.h"
5#include "smt.h"
6
7bool smt_on(const struct cpu_topology *topology)
8{
9 static bool cached;
10 static bool cached_result;
11 int fs_value;
12
13 if (cached)
14 return cached_result;
15
16 if (sysfs__read_int("devices/system/cpu/smt/active", &fs_value) >= 0)
17 cached_result = (fs_value == 1);
18 else
19 cached_result = cpu_topology__smt_on(topology);
20
21 cached = true;
22 return cached_result;
23}
24
25bool core_wide(bool system_wide, const char *user_requested_cpu_list,
26 const struct cpu_topology *topology)
27{
28 /* If not everything running on a core is being recorded then we can't use core_wide. */
29 if (!system_wide)
30 return false;
31
32 /* Cheap case that SMT is disabled and therefore we're inherently core_wide. */
33 if (!smt_on(topology))
34 return true;
35
36 return cpu_topology__core_wide(topology, user_requested_cpu_list);
37}
1#include <stdio.h>
2#include <stdlib.h>
3#include <unistd.h>
4#include <linux/bitops.h>
5#include "api/fs/fs.h"
6#include "smt.h"
7
8int smt_on(void)
9{
10 static bool cached;
11 static int cached_result;
12 int cpu;
13 int ncpu;
14
15 if (cached)
16 return cached_result;
17
18 if (sysfs__read_int("devices/system/cpu/smt/active", &cached_result) > 0)
19 goto done;
20
21 ncpu = sysconf(_SC_NPROCESSORS_CONF);
22 for (cpu = 0; cpu < ncpu; cpu++) {
23 unsigned long long siblings;
24 char *str;
25 size_t strlen;
26 char fn[256];
27
28 snprintf(fn, sizeof fn,
29 "devices/system/cpu/cpu%d/topology/core_cpus", cpu);
30 if (sysfs__read_str(fn, &str, &strlen) < 0) {
31 snprintf(fn, sizeof fn,
32 "devices/system/cpu/cpu%d/topology/thread_siblings",
33 cpu);
34 if (sysfs__read_str(fn, &str, &strlen) < 0)
35 continue;
36 }
37 /* Entry is hex, but does not have 0x, so need custom parser */
38 siblings = strtoull(str, NULL, 16);
39 free(str);
40 if (hweight64(siblings) > 1) {
41 cached_result = 1;
42 cached = true;
43 break;
44 }
45 }
46 if (!cached) {
47 cached_result = 0;
48done:
49 cached = true;
50 }
51 return cached_result;
52}