#endif
-#define OVERRIDE_TABLE_32_arm_fadvise64_64
-#define OVERRIDE_TABLE_32_sync_file_range2
-
#ifndef CREATE_SYSCALL_TABLE
+#if (__BYTE_ORDER == __LITTLE_ENDIAN)
+
+#define OVERRIDE_32_arm_fadvise64_64
SC_LTTNG_TRACEPOINT_EVENT(arm_fadvise64_64,
- TP_PROTO(int fd, int advice, loff_t offset, loff_t len),
- TP_ARGS(fd, advice, offset, len),
- TP_FIELDS(
- ctf_integer_hex(int, fd, fd)
- ctf_integer_hex(int, advice, advice)
- ctf_integer_hex(loff_t, offset, offset)
- ctf_integer_hex(loff_t, len, len)
+ TP_PROTO(sc_exit(long ret,) int fd, int advice,
+ int32_t offset_low, int32_t offset_high,
+ int32_t len_low, int32_t len_high),
+ TP_ARGS(sc_exit(ret,) fd, advice, offset_low, offset_high,
+ len_low, len_high),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(int, advice, advice))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, len,
+ ((loff_t) len_high << 32) | len_low))
)
)
+#define OVERRIDE_32_sync_file_range2
SC_LTTNG_TRACEPOINT_EVENT(sync_file_range2,
- TP_PROTO(int fd, loff_t offset, loff_t nbytes, unsigned int flags),
- TP_ARGS(fd, offset, nbytes, flags),
- TP_FIELDS(
- ctf_integer_hex(int, fd, fd)
- ctf_integer_hex(loff_t, offset, offset)
- ctf_integer_hex(loff_t, nbytes, nbytes)
- ctf_integer_hex(unsigned int, flags, flags)
+ TP_PROTO(sc_exit(long ret,) int fd,
+ unsigned int flags,
+ int32_t offset_low, int32_t offset_high,
+ int32_t nbytes_low, int32_t nbytes_high),
+ TP_ARGS(sc_exit(ret,) fd, flags, offset_low, offset_high,
+ nbytes_low, nbytes_high),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(unsigned int, flags, flags))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, nbytes,
+ ((loff_t) nbytes_high << 32) | nbytes_low))
+ )
+)
+
+#else /* __BIG_ENDIAN */
+
+#define OVERRIDE_32_arm_fadvise64_64
+SC_LTTNG_TRACEPOINT_EVENT(arm_fadvise64_64,
+ TP_PROTO(sc_exit(long ret,) int fd, int advice,
+ int32_t offset_high, int32_t offset_low,
+ int32_t len_high, int32_t len_low),
+ TP_ARGS(sc_exit(ret,) fd, advice, offset_high, offset_low,
+ len_high, len_low),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(int, advice, advice))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, len,
+ ((loff_t) len_high << 32) | len_low))
+ )
+)
+
+#define OVERRIDE_32_sync_file_range2
+SC_LTTNG_TRACEPOINT_EVENT(sync_file_range2,
+ TP_PROTO(sc_exit(long ret,) int fd,
+ unsigned int flags,
+ int32_t offset_high, int32_t offset_low,
+ int32_t nbytes_high, int32_t nbytes_low),
+ TP_ARGS(sc_exit(ret,) fd, flags, offset_high, offset_low,
+ nbytes_high, nbytes_low),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(unsigned int, flags, flags))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, nbytes,
+ ((loff_t) nbytes_high << 32) | nbytes_low))
+ )
+)
+
+#endif
+
+#define OVERRIDE_32_mmap2
+SC_LTTNG_TRACEPOINT_EVENT(mmap2,
+ TP_PROTO(sc_exit(unsigned long ret,)
+ unsigned long addr, unsigned long len,
+ unsigned long prot, unsigned long flags,
+ unsigned long fd, unsigned long pgoff),
+ TP_ARGS(sc_exit(ret,) addr, len, prot, flags, fd, pgoff),
+ TP_FIELDS(sc_exit(ctf_integer_hex(unsigned long, ret, ret))
+ sc_in(ctf_integer_hex(unsigned long, addr, addr))
+ sc_in(ctf_integer(size_t, len, len))
+ sc_in(ctf_integer(int, prot, prot))
+ sc_in(ctf_integer(int, flags, flags))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(off_t, pgoff, pgoff))
)
)
#define OVERRIDE_TABLE_32_mmap
TRACE_SYSCALL_TABLE(mmap, mmap, 90, 6)
-
+#define OVERRIDE_TABLE_32_mmap2
+TRACE_SYSCALL_TABLE(mmap2, mmap2, 192, 6)
#define OVERRIDE_TABLE_32_arm_fadvise64_64
-TRACE_SYSCALL_TABLE(arm_fadvise64_64, arm_fadvise64_64, 270, 4)
+TRACE_SYSCALL_TABLE(arm_fadvise64_64, arm_fadvise64_64, 270, 6)
#define OVERRIDE_TABLE_32_sync_file_range2
-TRACE_SYSCALL_TABLE(sync_file_range2, sync_file_range2, 341, 4)
+TRACE_SYSCALL_TABLE(sync_file_range2, sync_file_range2, 341, 6)
#endif /* CREATE_SYSCALL_TABLE */
#ifndef CREATE_SYSCALL_TABLE
-SC_LTTNG_TRACEPOINT_EVENT(mmap2,
- TP_PROTO(void *addr, size_t len, int prot,
- int flags, int fd, off_t pgoff),
- TP_ARGS(addr, len, prot, flags, fd, pgoff),
- TP_FIELDS(
- ctf_integer_hex(void *, addr, addr)
- ctf_integer(size_t, len, len)
- ctf_integer(int, prot, prot)
- ctf_integer(int, flags, flags)
- ctf_integer(int, fd, fd)
- ctf_integer(off_t, pgoff, pgoff)
- )
-)
-
#define OVERRIDE_32_pipe
SC_LTTNG_TRACEPOINT_EVENT(pipe,
TP_PROTO(sc_exit(long ret,) int * fildes),
TRACE_SYSCALL_TABLE(execve, execve, 11, 3)
#define OVERRIDE_TABLE_32_clone
TRACE_SYSCALL_TABLE(clone, clone, 120, 5)
-#define OVERRIDE_TABLE_32_mmap2
-TRACE_SYSCALL_TABLE(mmap2, mmap2, 192, 6)
#endif /* CREATE_SYSCALL_TABLE */
#ifdef CONFIG_ARM64
#include "arm-32-syscalls-3.4.25_integers.h"
#endif
+
+#ifdef CONFIG_PPC64
+#include "powerpc-32-syscalls-3.0.34_integers.h"
+#endif
#ifdef CONFIG_ARM64
#include "arm-32-syscalls-3.4.25_pointers.h"
#endif
+
+#ifdef CONFIG_PPC64
+#include "powerpc-32-syscalls-3.0.34_pointers.h"
+#endif
#ifndef CREATE_SYSCALL_TABLE
+#define OVERRIDE_32_mmap2
+SC_LTTNG_TRACEPOINT_EVENT(mmap2,
+ TP_PROTO(sc_exit(unsigned long ret,)
+ unsigned long addr, unsigned long len,
+ unsigned long prot, unsigned long flags,
+ unsigned long fd, unsigned long pgoff),
+ TP_ARGS(sc_exit(ret,) addr, len, prot, flags, fd, pgoff),
+ TP_FIELDS(sc_exit(ctf_integer_hex(unsigned long, ret, ret))
+ sc_in(ctf_integer_hex(unsigned long, addr, addr))
+ sc_in(ctf_integer(size_t, len, len))
+ sc_in(ctf_integer(int, prot, prot))
+ sc_in(ctf_integer(int, flags, flags))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(off_t, pgoff, pgoff))
+ )
+)
+
+#if (__BYTE_ORDER == __LITTLE_ENDIAN)
+
+#define OVERRIDE_32_sync_file_range2
+SC_LTTNG_TRACEPOINT_EVENT(sync_file_range2,
+ TP_PROTO(sc_exit(long ret,) int fd,
+ unsigned int flags,
+ int32_t offset_low, int32_t offset_high,
+ int32_t nbytes_low, int32_t nbytes_high),
+ TP_ARGS(sc_exit(ret,) fd, flags, offset_low, offset_high,
+ nbytes_low, nbytes_high),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(unsigned int, flags, flags))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, nbytes,
+ ((loff_t) nbytes_high << 32) | nbytes_low))
+ )
+)
+
+#else /* __BIG_ENDIAN */
+
+#define OVERRIDE_32_sync_file_range2
+SC_LTTNG_TRACEPOINT_EVENT(sync_file_range2,
+ TP_PROTO(sc_exit(long ret,) int fd,
+ unsigned int flags,
+ int32_t offset_high, int32_t offset_low,
+ int32_t nbytes_high, int32_t nbytes_low),
+ TP_ARGS(sc_exit(ret,) fd, flags, offset_high, offset_low,
+ nbytes_high, nbytes_low),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(unsigned int, flags, flags))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, nbytes,
+ ((loff_t) nbytes_high << 32) | nbytes_low))
+ )
+)
+
+#endif
+
#else /* CREATE_SYSCALL_TABLE */
#define OVERRIDE_TABLE_32_mmap
TRACE_SYSCALL_TABLE(mmap, mmap, 90, 6)
+#define OVERRIDE_TABLE_32_mmap2
+TRACE_SYSCALL_TABLE(mmap2, mmap2, 192, 6)
+#define OVERRIDE_TABLE_32_sync_file_range2
+TRACE_SYSCALL_TABLE(sync_file_range2, sync_file_range2, 308, 6)
#endif /* CREATE_SYSCALL_TABLE */
#ifndef CREATE_SYSCALL_TABLE
-SC_LTTNG_TRACEPOINT_EVENT(mmap2,
- TP_PROTO(void *addr, size_t len, int prot,
- int flags, int fd, off_t pgoff),
- TP_ARGS(addr, len, prot, flags, fd, pgoff),
- TP_FIELDS(
- ctf_integer_hex(void *, addr, addr)
- ctf_integer(size_t, len, len)
- ctf_integer(int, prot, prot)
- ctf_integer(int, flags, flags)
- ctf_integer(int, fd, fd)
- ctf_integer(off_t, pgoff, pgoff)
- )
-)
-
#define OVERRIDE_32_pipe
SC_LTTNG_TRACEPOINT_EVENT(pipe,
TP_PROTO(sc_exit(long ret,) int * fildes),
TRACE_SYSCALL_TABLE(execve, execve, 11, 3)
#define OVERRIDE_TABLE_32_clone
TRACE_SYSCALL_TABLE(clone, clone, 120, 5)
-#define OVERRIDE_TABLE_32_mmap2
-TRACE_SYSCALL_TABLE(mmap2, mmap2, 192, 6)
#endif /* CREATE_SYSCALL_TABLE */
-#define OVERRIDE_32_mmap
-#define OVERRIDE_64_mmap
-
#ifndef CREATE_SYSCALL_TABLE
+#define OVERRIDE_32_mmap
+#define OVERRIDE_64_mmap
SC_LTTNG_TRACEPOINT_EVENT(mmap,
- TP_PROTO(sc_exit(long ret,) unsigned long addr, unsigned long len, unsigned long prot, unsigned long flags, unsigned long fd, unsigned long off),
+ TP_PROTO(sc_exit(unsigned long ret,)
+ unsigned long addr, unsigned long len,
+ unsigned long prot, unsigned long flags,
+ unsigned long fd, unsigned long off),
TP_ARGS(sc_exit(ret,) addr, len, prot, flags, fd, off),
- TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ TP_FIELDS(sc_exit(ctf_integer_hex(unsigned long, ret, ret))
sc_in(ctf_integer_hex(unsigned long, addr, addr))
sc_in(ctf_integer(size_t, len, len))
sc_in(ctf_integer(int, prot, prot))
-#define OVERRIDE_32_execve
-#define OVERRIDE_64_execve
-
#ifndef CREATE_SYSCALL_TABLE
+#define OVERRIDE_32_execve
+#define OVERRIDE_64_execve
SC_LTTNG_TRACEPOINT_EVENT(execve,
TP_PROTO(sc_exit(long ret,) const char *filename, char *const *argv, char *const *envp),
TP_ARGS(sc_exit(ret,) filename, argv, envp),
)
)
+#define OVERRIDE_32_clone
+#define OVERRIDE_64_clone
SC_LTTNG_TRACEPOINT_EVENT(clone,
TP_PROTO(sc_exit(long ret,) unsigned long clone_flags, unsigned long newsp,
void __user *parent_tid,
#endif
-#ifdef CREATE_SYSCALL_TABLE
+#ifndef CREATE_SYSCALL_TABLE
+
+/* mmap_pgoff is kernel internal. mmap2 is exposed in unistd.h. */
+#define OVERRIDE_32_mmap_pgoff
+#define OVERRIDE_32_mmap2
+SC_LTTNG_TRACEPOINT_EVENT(mmap2,
+ TP_PROTO(sc_exit(unsigned long ret,)
+ unsigned long addr, unsigned long len,
+ unsigned long prot, unsigned long flags,
+ unsigned long fd, unsigned long pgoff),
+ TP_ARGS(sc_exit(ret,) addr, len, prot, flags, fd, pgoff),
+ TP_FIELDS(sc_exit(ctf_integer_hex(unsigned long, ret, ret))
+ sc_in(ctf_integer_hex(unsigned long, addr, addr))
+ sc_in(ctf_integer(size_t, len, len))
+ sc_in(ctf_integer(int, prot, prot))
+ sc_in(ctf_integer(int, flags, flags))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(off_t, pgoff, pgoff))
+ )
+)
+
+#define OVERRIDE_32_sync_file_range
+SC_LTTNG_TRACEPOINT_EVENT(sync_file_range,
+ TP_PROTO(sc_exit(long ret,) int fd,
+ int32_t offset_low, int32_t offset_high,
+ int32_t nbytes_low, int32_t nbytes_high,
+ unsigned int flags),
+ TP_ARGS(sc_exit(ret,) fd, offset_low, offset_high,
+ nbytes_low, nbytes_high, flags),
+ TP_FIELDS(sc_exit(ctf_integer(long, ret, ret))
+ sc_in(ctf_integer(int, fd, fd))
+ sc_in(ctf_integer(loff_t, offset,
+ ((loff_t) offset_high << 32) | offset_low))
+ sc_in(ctf_integer(loff_t, nbytes,
+ ((loff_t) nbytes_high << 32) | nbytes_low))
+ sc_in(ctf_integer(unsigned int, flags, flags))
+ )
+)
+
+#else /* #ifndef CREATE_SYSCALL_TABLE */
#define OVERRIDE_TABLE_32_mmap
TRACE_SYSCALL_TABLE(mmap, mmap, 90, 6)
-#endif
+/* mmap_pgoff is kernel internal. mmap2 is exposed in unistd.h. */
+#define OVERRIDE_TABLE_32_mmap_pgoff
+#define OVERRIDE_TABLE_32_mmap2
+TRACE_SYSCALL_TABLE(mmap2, mmap2, 192, 6)
+
+#define OVERRIDE_TABLE_32_sync_file_range
+TRACE_SYSCALL_TABLE(sync_file_range, sync_file_range, 314, 6)
+
+#endif /* #else #ifndef CREATE_SYSCALL_TABLE */