[lttng-dev] [PATCH lttng-modules 2/2] Cleanup: reuse code in accept() and accept4() instrumentation
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Mon Aug 29 20:28:38 UTC 2016
Merged patch 1 and 2 into master. Fixup added: using LTTNG_SYSCALL_ACCEPT_locvar
in the accept4 code too.
Thanks,
Mathieu
----- On Aug 29, 2016, at 4:02 PM, Jeremie Galarneau jeremie.galarneau at efficios.com wrote:
> Signed-off-by: Jérémie Galarneau <jeremie.galarneau at efficios.com>
> ---
> .../x86-64-syscalls-3.10.0-rc7_pointers_override.h | 106 ++++++++-------------
> 1 file changed, 42 insertions(+), 64 deletions(-)
>
> diff --git
> a/instrumentation/syscalls/headers/x86-64-syscalls-3.10.0-rc7_pointers_override.h
> b/instrumentation/syscalls/headers/x86-64-syscalls-3.10.0-rc7_pointers_override.h
> index 6c59790..9d94aee 100644
> ---
> a/instrumentation/syscalls/headers/x86-64-syscalls-3.10.0-rc7_pointers_override.h
> +++
> b/instrumentation/syscalls/headers/x86-64-syscalls-3.10.0-rc7_pointers_override.h
> @@ -52,48 +52,54 @@ SC_LTTNG_TRACEPOINT_EVENT_CODE(connect,
> TP_code_post()
> )
>
> +#define LTTNG_SYSCALL_ACCEPT_locvar \
> + __typeof__(upeer_sockaddr->sa_family) sa_family;\
> + uint16_t sport; \
> + uint32_t v4addr; \
> + uint16_t v6addr[8]; \
> + int v4addr_len, v6addr_len; \
> + int uaddr_len;
> +
> +#define LTTNG_SYSCALL_ACCEPT_code_pre \
> + sc_inout( \
> + memset(tp_locvar, 0, sizeof(*tp_locvar)); \
> + (void) get_user(tp_locvar->uaddr_len, upeer_addrlen); \
> + ) \
> + sc_out( \
> + if (tp_locvar->uaddr_len < sizeof(struct sockaddr)) \
> + goto skip_code; \
> + (void) get_user(tp_locvar->sa_family, &upeer_sockaddr->sa_family); \
> + switch (tp_locvar->sa_family) { \
> + case AF_INET: \
> + if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in)) \
> + goto skip_code; \
> + (void) get_user(tp_locvar->sport, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_port); \
> + (void) get_user(tp_locvar->v4addr, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_addr.s_addr); \
> + tp_locvar->v4addr_len = 4; \
> + break; \
> + case AF_INET6: \
> + if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in6)) \
> + goto skip_code; \
> + (void) get_user(tp_locvar->sport, &((struct sockaddr_in6 *)
> upeer_sockaddr)->sin6_port); \
> + if (copy_from_user(tp_locvar->v6addr, \
> + &((struct sockaddr_in6 *) upeer_sockaddr)->sin6_addr.in6_u.u6_addr8, \
> + sizeof(tp_locvar->v6addr))) \
> + memset(tp_locvar->v6addr, 0, sizeof(tp_locvar->v6addr)); \
> + tp_locvar->v6addr_len = 8; \
> + break; \
> + } \
> + skip_code: \
> + )
> +
> #define OVERRIDE_64_accept
> SC_LTTNG_TRACEPOINT_EVENT_CODE(accept,
> TP_PROTO(sc_exit(long ret,) int fd, struct sockaddr * upeer_sockaddr, int *
> upeer_addrlen),
> TP_ARGS(sc_exit(ret,) fd, upeer_sockaddr, upeer_addrlen),
> TP_locvar(
> - __typeof__(upeer_sockaddr->sa_family) sa_family;
> - uint16_t sport;
> - uint32_t v4addr;
> - uint16_t v6addr[8];
> - int v4addr_len, v6addr_len;
> - int uaddr_len;
> + LTTNG_SYSCALL_ACCEPT_locvar
> ),
> TP_code_pre(
> - sc_inout(
> - memset(tp_locvar, 0, sizeof(*tp_locvar));
> - (void) get_user(tp_locvar->uaddr_len, upeer_addrlen);
> - )
> - sc_out(
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr))
> - goto skip_code;
> - (void) get_user(tp_locvar->sa_family, &upeer_sockaddr->sa_family);
> - switch (tp_locvar->sa_family) {
> - case AF_INET:
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in))
> - goto skip_code;
> - (void) get_user(tp_locvar->sport, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_port);
> - (void) get_user(tp_locvar->v4addr, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_addr.s_addr);
> - tp_locvar->v4addr_len = 4;
> - break;
> - case AF_INET6:
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in6))
> - goto skip_code;
> - (void) get_user(tp_locvar->sport, &((struct sockaddr_in6 *)
> upeer_sockaddr)->sin6_port);
> - if (copy_from_user(tp_locvar->v6addr,
> - &((struct sockaddr_in6 *) upeer_sockaddr)->sin6_addr.in6_u.u6_addr8,
> - sizeof(tp_locvar->v6addr)))
> - memset(tp_locvar->v6addr, 0, sizeof(tp_locvar->v6addr));
> - tp_locvar->v6addr_len = 8;
> - break;
> - }
> - skip_code:
> - )
> + LTTNG_SYSCALL_ACCEPT_code_pre
> ),
> TP_FIELDS(
> sc_exit(ctf_integer(long, ret, ret))
> @@ -121,35 +127,7 @@ SC_LTTNG_TRACEPOINT_EVENT_CODE(accept4,
> int uaddr_len;
> ),
> TP_code_pre(
> - sc_inout(
> - memset(tp_locvar, 0, sizeof(*tp_locvar));
> - (void) get_user(tp_locvar->uaddr_len, upeer_addrlen);
> - )
> - sc_out(
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr))
> - goto skip_code;
> - (void) get_user(tp_locvar->sa_family, &upeer_sockaddr->sa_family);
> - switch (tp_locvar->sa_family) {
> - case AF_INET:
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in))
> - goto skip_code;
> - (void) get_user(tp_locvar->sport, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_port);
> - (void) get_user(tp_locvar->v4addr, &((struct sockaddr_in *)
> upeer_sockaddr)->sin_addr.s_addr);
> - tp_locvar->v4addr_len = 4;
> - break;
> - case AF_INET6:
> - if (tp_locvar->uaddr_len < sizeof(struct sockaddr_in6))
> - goto skip_code;
> - (void) get_user(tp_locvar->sport, &((struct sockaddr_in6 *)
> upeer_sockaddr)->sin6_port);
> - if (copy_from_user(tp_locvar->v6addr,
> - &((struct sockaddr_in6 *) upeer_sockaddr)->sin6_addr.in6_u.u6_addr8,
> - sizeof(tp_locvar->v6addr)))
> - memset(tp_locvar->v6addr, 0, sizeof(tp_locvar->v6addr));
> - tp_locvar->v6addr_len = 8;
> - break;
> - }
> - skip_code:
> - )
> + LTTNG_SYSCALL_ACCEPT_code_pre
> ),
> TP_FIELDS(
> sc_exit(ctf_integer(long, ret, ret))
> --
> 2.9.3
--
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list