System call inout/output arg processing
[lttng-modules.git] / instrumentation / syscalls / headers / syscalls_pointers_override.h
index a24c4d315db2c2c6bfa4c11b938865ae64a90c2b..6dba8d5af53849693a225b043ca0456259293f79 100644 (file)
@@ -4,32 +4,36 @@
 #ifndef CREATE_SYSCALL_TABLE
 
 SC_TRACE_EVENT(sys_execve,
-       TP_PROTO(const char *filename, char *const *argv, char *const *envp),
-       TP_ARGS(filename, argv, envp),
-       TP_STRUCT__entry(__string_from_user(filename, filename)
-               __field_hex(char *const *, argv)
-               __field_hex(char *const *, envp)),
-       TP_fast_assign(tp_copy_string_from_user(filename, filename)
-               tp_assign(argv, argv)
-               tp_assign(envp, envp)),
+       TP_PROTO(sc_exit(long ret,) const char *filename, char *const *argv, char *const *envp),
+       TP_ARGS(sc_exit(ret,) filename, argv, envp),
+       TP_STRUCT__entry(sc_exit(__field(long, ret))
+               sc_in(__string_from_user(filename, filename))
+               sc_in(__field_hex(char *const *, argv))
+               sc_in(__field_hex(char *const *, envp))),
+       TP_fast_assign(sc_exit(tp_assign(ret, ret))
+               sc_in(tp_copy_string_from_user(filename, filename))
+               sc_in(tp_assign(argv, argv))
+               sc_in(tp_assign(envp, envp))),
        TP_printk()
 )
 
 SC_TRACE_EVENT(sys_clone,
-       TP_PROTO(unsigned long clone_flags, unsigned long newsp,
+       TP_PROTO(sc_exit(long ret,) unsigned long clone_flags, unsigned long newsp,
                void __user *parent_tid,
                void __user *child_tid),
-       TP_ARGS(clone_flags, newsp, parent_tid, child_tid),
+       TP_ARGS(sc_exit(ret,) clone_flags, newsp, parent_tid, child_tid),
        TP_STRUCT__entry(
-               __field_hex(unsigned long, clone_flags)
-               __field_hex(unsigned long, newsp)
-               __field_hex(void *, parent_tid)
-               __field_hex(void *, child_tid)),
+               sc_exit(__field(long, ret))
+               sc_in(__field_hex(unsigned long, clone_flags))
+               sc_in(__field_hex(unsigned long, newsp))
+               sc_in(__field_hex(void *, parent_tid))
+               sc_in(__field_hex(void *, child_tid))),
        TP_fast_assign(
-               tp_assign(clone_flags, clone_flags)
-               tp_assign(newsp, newsp)
-               tp_assign(parent_tid, parent_tid)
-               tp_assign(child_tid, child_tid)),
+               sc_exit(tp_assign(ret, ret))
+               sc_in(tp_assign(clone_flags, clone_flags))
+               sc_in(tp_assign(newsp, newsp))
+               sc_in(tp_assign(parent_tid, parent_tid))
+               sc_in(tp_assign(child_tid, child_tid))),
        TP_printk()
 )
 
@@ -37,16 +41,18 @@ SC_TRACE_EVENT(sys_clone,
 #define OVERRIDE_32_sys_getcpu
 #define OVERRIDE_64_sys_getcpu
 SC_TRACE_EVENT(sys_getcpu,
-       TP_PROTO(unsigned __user *cpup, unsigned __user *nodep, void *tcache),
-       TP_ARGS(cpup, nodep, tcache),
+       TP_PROTO(sc_exit(long ret,) unsigned __user *cpup, unsigned __user *nodep, void *tcache),
+       TP_ARGS(sc_exit(ret,) cpup, nodep, tcache),
        TP_STRUCT__entry(
-               __field_hex(unsigned *, cpup)
-               __field_hex(unsigned *, nodep)
-               __field_hex(void *, tcache)),
+               sc_exit(__field(long, ret))
+               sc_out(__field_hex(unsigned *, cpup))
+               sc_out(__field_hex(unsigned *, nodep))
+               sc_inout(__field_hex(void *, tcache))),
        TP_fast_assign(
-               tp_assign(cpup, cpup)
-               tp_assign(nodep, nodep)
-               tp_assign(tcache, tcache)),
+               sc_exit(tp_assign(ret, ret))
+               sc_out(tp_assign(cpup, cpup))
+               sc_out(tp_assign(nodep, nodep))
+               sc_inout(tp_assign(tcache, tcache))),
        TP_printk()
 )
 
This page took 0.024229 seconds and 4 git commands to generate.