#ifndef _LINUX_UTIL_H_
#define _LINUX_UTIL_H_
#include <sys/malloc.h>
#include <sys/uio.h>
extern int linux_debug;
MALLOC_DECLARE(M_LINUX);
MALLOC_DECLARE(M_EPOLL);
int linux_pwd_onexec(struct thread *);
void linux_pwd_onexec_native(struct thread *);
#define DUMMY(s) \
LIN_SDT_PROBE_DEFINE0(dummy, s, not_implemented); \
int \
linux_ ## s(struct thread *td, struct linux_ ## s ## _args *args) \
{ \
static pid_t pid; \
\
if (pid != td->td_proc->p_pid) { \
linux_msg(td, "syscall %s not implemented", #s); \
LIN_SDT_PROBE0(dummy, s, not_implemented); \
pid = td->td_proc->p_pid; \
}; \
\
return (ENOSYS); \
} \
struct __hack
#define UNIMPLEMENTED(s)
void linux_msg(const struct thread *td, const char *fmt, ...)
__printflike(2, 3);
struct linux_device_handler {
char *bsd_driver_name;
char *linux_driver_name;
char *bsd_device_name;
char *linux_device_name;
int linux_major;
int linux_minor;
int linux_char_device;
};
struct stat;
int linux_device_register_handler(struct linux_device_handler *h);
int linux_device_unregister_handler(struct linux_device_handler *h);
char *linux_driver_get_name_dev(device_t dev);
int linux_driver_get_major_minor(const char *node, int *major, int *minor);
int linux_vn_get_major_minor(const struct vnode *vn, int *major, int *minor);
char *linux_get_char_devices(void);
void linux_free_get_char_devices(char *string);
void translate_vnhook_major_minor(struct vnode *vp, struct stat *sb);
#if defined(KTR)
#define KTR_LINUX KTR_SUBSYS
#define LINUX_CTRFMT(nm, fmt) #nm"("fmt")"
#define LINUX_CTR6(f, m, p1, p2, p3, p4, p5, p6) do { \
CTR6(KTR_LINUX, LINUX_CTRFMT(f, m), \
p1, p2, p3, p4, p5, p6); \
} while (0)
#define LINUX_CTR(f) LINUX_CTR6(f, "", 0, 0, 0, 0, 0, 0)
#define LINUX_CTR0(f, m) LINUX_CTR6(f, m, 0, 0, 0, 0, 0, 0)
#define LINUX_CTR1(f, m, p1) LINUX_CTR6(f, m, p1, 0, 0, 0, 0, 0)
#define LINUX_CTR2(f, m, p1, p2) LINUX_CTR6(f, m, p1, p2, 0, 0, 0, 0)
#define LINUX_CTR3(f, m, p1, p2, p3) LINUX_CTR6(f, m, p1, p2, p3, 0, 0, 0)
#define LINUX_CTR4(f, m, p1, p2, p3, p4) LINUX_CTR6(f, m, p1, p2, p3, p4, 0, 0)
#define LINUX_CTR5(f, m, p1, p2, p3, p4, p5) LINUX_CTR6(f, m, p1, p2, p3, p4, p5, 0)
#else
#define LINUX_CTR(f)
#define LINUX_CTR0(f, m)
#define LINUX_CTR1(f, m, p1)
#define LINUX_CTR2(f, m, p1, p2)
#define LINUX_CTR3(f, m, p1, p2, p3)
#define LINUX_CTR4(f, m, p1, p2, p3, p4)
#define LINUX_CTR5(f, m, p1, p2, p3, p4, p5)
#define LINUX_CTR6(f, m, p1, p2, p3, p4, p5, p6)
#endif
#define LINUX_RATELIMIT_MSG_NOTTESTED(_what) \
do { \
static int seen = 0; \
\
if (seen == 0 && linux_debug >= 2) { \
linux_msg(curthread, "%s is not tested, please report on emulation@FreeBSD.org how it works", _what); \
\
if (linux_debug < 3) \
seen = 1; \
} \
} while (0)
#define LINUX_RATELIMIT_MSG(_message) \
do { \
static int seen = 0; \
\
if (seen == 0) { \
linux_msg(curthread, _message); \
\
if (linux_debug < 3) \
seen = 1; \
} \
} while (0)
#define LINUX_RATELIMIT_MSG_OPT1(_message, _opt1) \
do { \
static int seen = 0; \
\
if (seen == 0) { \
linux_msg(curthread, _message, _opt1); \
\
if (linux_debug < 3) \
seen = 1; \
} \
} while (0)
#define LINUX_RATELIMIT_MSG_OPT2(_message, _opt1, _opt2) \
do { \
static int seen = 0; \
\
if (seen == 0) { \
linux_msg(curthread, _message, _opt1, _opt2); \
\
if (linux_debug < 3) \
seen = 1; \
} \
} while (0)
#endif