Loading...
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 ncpu = sysconf(_SC_NPROCESSORS_CONF);
19 for (cpu = 0; cpu < ncpu; cpu++) {
20 unsigned long long siblings;
21 char *str;
22 size_t strlen;
23 char fn[256];
24
25 snprintf(fn, sizeof fn,
26 "devices/system/cpu/cpu%d/topology/core_cpus", cpu);
27 if (access(fn, F_OK) == -1) {
28 snprintf(fn, sizeof fn,
29 "devices/system/cpu/cpu%d/topology/thread_siblings",
30 cpu);
31 }
32 if (sysfs__read_str(fn, &str, &strlen) < 0)
33 continue;
34 /* Entry is hex, but does not have 0x, so need custom parser */
35 siblings = strtoull(str, NULL, 16);
36 free(str);
37 if (hweight64(siblings) > 1) {
38 cached_result = 1;
39 cached = true;
40 break;
41 }
42 }
43 if (!cached) {
44 cached_result = 0;
45 cached = true;
46 }
47 return cached_result;
48}
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(void)
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(online_topology());
20
21 cached = true;
22 return cached_result;
23}
24
25bool core_wide(bool system_wide, const char *user_requested_cpu_list)
26{
27 /* If not everything running on a core is being recorded then we can't use core_wide. */
28 if (!system_wide)
29 return false;
30
31 /* Cheap case that SMT is disabled and therefore we're inherently core_wide. */
32 if (!smt_on())
33 return true;
34
35 return cpu_topology__core_wide(online_topology(), user_requested_cpu_list);
36}