mirror of
https://passt.top/passt
synced 2024-12-22 05:35:23 +00:00
linux_dep: Move close_range() conditional handling to linux_dep.h
util.h has some #ifdefs and weak definitions to handle compatibility with various kernel versions. Move this to linux_dep.h which handles several other similar cases. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
parent
b84cd05098
commit
d64f257243
20
linux_dep.h
20
linux_dep.h
@ -125,4 +125,24 @@ struct tcp_info_linux {
|
|||||||
#define FALLOC_FL_COLLAPSE_RANGE 0x08
|
#define FALLOC_FL_COLLAPSE_RANGE 0x08
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <linux/close_range.h>
|
||||||
|
|
||||||
|
#ifdef CLOSE_RANGE_UNSHARE /* Linux kernel >= 5.9 */
|
||||||
|
/* glibc < 2.34 and musl as of 1.2.5 need these */
|
||||||
|
#ifndef SYS_close_range
|
||||||
|
#define SYS_close_range 436
|
||||||
|
#endif
|
||||||
|
__attribute__ ((weak))
|
||||||
|
/* cppcheck-suppress funcArgNamesDifferent */
|
||||||
|
int close_range(unsigned int first, unsigned int last, int flags) {
|
||||||
|
return syscall(SYS_close_range, first, last, flags);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
/* No reasonable fallback option */
|
||||||
|
/* cppcheck-suppress funcArgNamesDifferent */
|
||||||
|
int close_range(unsigned int first, unsigned int last, int flags) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* LINUX_DEP_H */
|
#endif /* LINUX_DEP_H */
|
||||||
|
1
util.c
1
util.c
@ -28,6 +28,7 @@
|
|||||||
#include <linux/errqueue.h>
|
#include <linux/errqueue.h>
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
|
|
||||||
|
#include "linux_dep.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "iov.h"
|
#include "iov.h"
|
||||||
#include "passt.h"
|
#include "passt.h"
|
||||||
|
19
util.h
19
util.h
@ -17,7 +17,6 @@
|
|||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/syscall.h>
|
#include <sys/syscall.h>
|
||||||
#include <linux/close_range.h>
|
|
||||||
|
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
@ -171,24 +170,6 @@ int do_clone(int (*fn)(void *), char *stack_area, size_t stack_size, int flags,
|
|||||||
|
|
||||||
struct ctx;
|
struct ctx;
|
||||||
|
|
||||||
#ifdef CLOSE_RANGE_UNSHARE /* Linux kernel >= 5.9 */
|
|
||||||
/* glibc < 2.34 and musl as of 1.2.5 need these */
|
|
||||||
#ifndef SYS_close_range
|
|
||||||
#define SYS_close_range 436
|
|
||||||
#endif
|
|
||||||
__attribute__ ((weak))
|
|
||||||
/* cppcheck-suppress funcArgNamesDifferent */
|
|
||||||
int close_range(unsigned int first, unsigned int last, int flags) {
|
|
||||||
return syscall(SYS_close_range, first, last, flags);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
/* No reasonable fallback option */
|
|
||||||
/* cppcheck-suppress funcArgNamesDifferent */
|
|
||||||
int close_range(unsigned int first, unsigned int last, int flags) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int sock_l4_sa(const struct ctx *c, enum epoll_type type,
|
int sock_l4_sa(const struct ctx *c, enum epoll_type type,
|
||||||
const void *sa, socklen_t sl,
|
const void *sa, socklen_t sl,
|
||||||
const char *ifname, bool v6only, uint32_t data);
|
const char *ifname, bool v6only, uint32_t data);
|
||||||
|
Loading…
Reference in New Issue
Block a user