haproxy/include/haproxy/cpuset-t.h
Willy Tarreau 5b09341c02 MEDIUM: cpu-map: replace the process number with the thread group number
The principle remains the same, but instead of having a single process
and ignoring extra ones, now we set the affinity masks for the respective
threads of all groups.

The doc was updated with a few extra examples.
2022-07-15 19:43:10 +02:00

57 lines
1.3 KiB
C

#ifndef _HAPROXY_CPUSET_T_H
#define _HAPROXY_CPUSET_T_H
#define _GNU_SOURCE
#include <sched.h>
#if defined(__FreeBSD__) || defined(__DragonFly__) || defined(__NetBSD__)
#include <sys/param.h>
#ifdef __FreeBSD__
#include <sys/_cpuset.h>
#include <sys/cpuset.h>
#include <sys/sysctl.h>
#include <strings.h>
#endif
#endif
#include <haproxy/api-t.h>
#if defined(__linux__) || defined(__DragonFly__) || \
(defined(__FreeBSD_kernel__) && defined(__GLIBC__))
# define CPUSET_REPR cpu_set_t
# define CPUSET_USE_CPUSET
#elif defined(__FreeBSD__) || defined(__NetBSD__)
# define CPUSET_REPR cpuset_t
# if defined(__FreeBSD__) && __FreeBSD_version >= 1301000
# define CPUSET_USE_CPUSET
# else
# define CPUSET_USE_FREEBSD_CPUSET
# endif
#elif defined(__APPLE__)
# define CPUSET_REPR unsigned long
# define CPUSET_USE_ULONG
#else
# error "No cpuset support implemented on this platform"
#endif
struct hap_cpuset {
CPUSET_REPR cpuset;
};
struct cpu_map {
struct hap_cpuset proc; /* list of CPU masks for the whole thread group */
struct hap_cpuset proc_t1 ; /* list of CPU masks for the 1st thread of the group */
struct hap_cpuset thread[MAX_THREADS_PER_GROUP]; /* list of CPU masks for the 32/64 threads of this group */
};
#endif /* _HAPROXY_CPUSET_T_H */