885e631959
Alexei Starovoitov says: ==================== pull-request: bpf-next 2019-02-16 The following pull-request contains BPF updates for your *net-next* tree. The main changes are: 1) numerous libbpf API improvements, from Andrii, Andrey, Yonghong. 2) test all bpf progs in alu32 mode, from Jiong. 3) skb->sk access and bpf_sk_fullsock(), bpf_tcp_sock() helpers, from Martin. 4) support for IP encap in lwt bpf progs, from Peter. 5) remove XDP_QUERY_XSK_UMEM dead code, from Jan. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
71 lines
1.5 KiB
C
71 lines
1.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __BPF_UTIL__
|
|
#define __BPF_UTIL__
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <errno.h>
|
|
|
|
static inline unsigned int bpf_num_possible_cpus(void)
|
|
{
|
|
static const char *fcpu = "/sys/devices/system/cpu/possible";
|
|
unsigned int start, end, possible_cpus = 0;
|
|
char buff[128];
|
|
FILE *fp;
|
|
int len, n, i, j = 0;
|
|
|
|
fp = fopen(fcpu, "r");
|
|
if (!fp) {
|
|
printf("Failed to open %s: '%s'!\n", fcpu, strerror(errno));
|
|
exit(1);
|
|
}
|
|
|
|
if (!fgets(buff, sizeof(buff), fp)) {
|
|
printf("Failed to read %s!\n", fcpu);
|
|
exit(1);
|
|
}
|
|
|
|
len = strlen(buff);
|
|
for (i = 0; i <= len; i++) {
|
|
if (buff[i] == ',' || buff[i] == '\0') {
|
|
buff[i] = '\0';
|
|
n = sscanf(&buff[j], "%u-%u", &start, &end);
|
|
if (n <= 0) {
|
|
printf("Failed to retrieve # possible CPUs!\n");
|
|
exit(1);
|
|
} else if (n == 1) {
|
|
end = start;
|
|
}
|
|
possible_cpus += end - start + 1;
|
|
j = i + 1;
|
|
}
|
|
}
|
|
|
|
fclose(fp);
|
|
|
|
return possible_cpus;
|
|
}
|
|
|
|
#define __bpf_percpu_val_align __attribute__((__aligned__(8)))
|
|
|
|
#define BPF_DECLARE_PERCPU(type, name) \
|
|
struct { type v; /* padding */ } __bpf_percpu_val_align \
|
|
name[bpf_num_possible_cpus()]
|
|
#define bpf_percpu(name, cpu) name[(cpu)].v
|
|
|
|
#ifndef ARRAY_SIZE
|
|
# define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
|
|
#endif
|
|
|
|
#ifndef sizeof_field
|
|
#define sizeof_field(TYPE, MEMBER) sizeof((((TYPE *)0)->MEMBER))
|
|
#endif
|
|
|
|
#ifndef offsetofend
|
|
#define offsetofend(TYPE, MEMBER) \
|
|
(offsetof(TYPE, MEMBER) + sizeof_field(TYPE, MEMBER))
|
|
#endif
|
|
|
|
#endif /* __BPF_UTIL__ */
|