#ifndef __BPF_UTIL__ #define __BPF_UTIL__ #include #include #include #include #include #if __BYTE_ORDER == __LITTLE_ENDIAN # define __bpf_ntohs(x) __builtin_bswap16(x) # define __bpf_htons(x) __builtin_bswap16(x) #elif __BYTE_ORDER == __BIG_ENDIAN # define __bpf_ntohs(x) (x) # define __bpf_htons(x) (x) #else # error "Fix your __BYTE_ORDER?!" #endif #define bpf_htons(x) \ (__builtin_constant_p(x) ? \ __constant_htons(x) : __bpf_htons(x)) #define bpf_ntohs(x) \ (__builtin_constant_p(x) ? \ __constant_ntohs(x) : __bpf_ntohs(x)) 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; fp = fopen(fcpu, "r"); if (!fp) { printf("Failed to open %s: '%s'!\n", fcpu, strerror(errno)); exit(1); } while (fgets(buff, sizeof(buff), fp)) { if (sscanf(buff, "%u-%u", &start, &end) == 2) { possible_cpus = start == 0 ? end + 1 : 0; break; } } fclose(fp); if (!possible_cpus) { printf("Failed to retrieve # possible CPUs!\n"); exit(1); } return possible_cpus; } #endif /* __BPF_UTIL__ */