[ltt-dev] [PATCH v2 2/2] Make ltt support separate socketcall tracepoint.
Mathieu Desnoyers
compudj at krystal.dyndns.org
Wed Feb 11 00:26:10 EST 2009
* Zhaolei (zhaolei at cn.fujitsu.com) wrote:
> So ltt can trace these socket syscalls.
>
Merged for 2.6.29-rc4. Thanks !
Mathieu
> Signed-off-by: Zhao Lei <zhaolei at cn.fujitsu.com>
> ---
> ltt/probes/net-trace.c | 112 +++++++++++++++++++++++++++++++++++++++++------
> 1 files changed, 97 insertions(+), 15 deletions(-)
>
> diff --git a/ltt/probes/net-trace.c b/ltt/probes/net-trace.c
> index a30530d..83cf33a 100644
> --- a/ltt/probes/net-trace.c
> +++ b/ltt/probes/net-trace.c
> @@ -75,30 +75,112 @@ void probe_ipv6_addr_del(struct inet6_ifaddr *ifa)
> addr[3], addr[2], addr[1], addr[0]);
> }
>
> -void probe_socket_sendmsg(struct socket *sock, struct msghdr *msg,
> - size_t size, int ret)
> +void probe_socket_create(int family, int type, int protocol,
> + struct socket *sock, int ret)
> +{
> + trace_mark_tp(net, socket_create, socket_create, probe_socket_create,
> + "family %d type %d protocol %d sock %p ret %d",
> + family, type, protocol, sock, ret);
> +}
> +
> +void probe_socket_bind(int fd, struct sockaddr __user *umyaddr, int addrlen,
> + int ret)
> +{
> + trace_mark_tp(net, socket_bind, socket_bind, probe_socket_bind,
> + "fd %d umyaddr %p addrlen %d ret %d",
> + fd, umyaddr, addrlen, ret);
> +}
> +
> +void probe_socket_connect(int fd, struct sockaddr __user *uservaddr,
> + int addrlen, int ret)
> +{
> + trace_mark_tp(net, socket_connect, socket_connect, probe_socket_connect,
> + "fd %d uservaddr %p addrlen %d ret %d",
> + fd, uservaddr, addrlen, ret);
> +}
> +
> +void probe_socket_listen(int fd, int backlog, int ret)
> +{
> + trace_mark_tp(net, socket_listen, socket_listen, probe_socket_listen,
> + "fd %d backlog %d ret %d",
> + fd, backlog, ret);
> +}
> +
> +void probe_socket_accept(int fd, struct sockaddr __user *upeer_sockaddr,
> + int __user *upeer_addrlen, int flags, int ret)
> +{
> + trace_mark_tp(net, socket_accept, socket_accept, probe_socket_accept,
> + "fd %d upeer_sockaddr %p upeer_addrlen %p flags %d ret %d",
> + fd, upeer_sockaddr, upeer_addrlen, flags, ret);
> +}
> +
> +void probe_socket_getsockname(int fd, struct sockaddr __user *usockaddr,
> + int __user *usockaddr_len, int ret)
> +{
> + trace_mark_tp(net, socket_getsockname, socket_getsockname,
> + probe_socket_getsockname,
> + "fd %d usockaddr %p usockaddr_len %p ret %d",
> + fd, usockaddr, usockaddr_len, ret);
> +}
> +
> +void probe_socket_getpeername(int fd, struct sockaddr __user *usockaddr,
> + int __user *usockaddr_len, int ret)
> +{
> + trace_mark_tp(net, socket_getpeername, socket_getpeername,
> + probe_socket_getpeername,
> + "fd %d usockaddr %p usockaddr_len %p ret %d",
> + fd, usockaddr, usockaddr_len, ret);
> +}
> +
> +void probe_socket_socketpair(int family, int type, int protocol,
> + int __user *usockvec, int ret)
> +{
> + trace_mark_tp(net, socket_socketpair, socket_socketpair,
> + probe_socket_socketpair,
> + "family %d type %d protocol %d usockvec %p ret %d",
> + family, type, protocol, usockvec, ret);
> +}
> +
> +void probe_socket_sendmsg(struct socket *sock, struct msghdr *msg, size_t size,
> + int ret)
> {
> trace_mark_tp(net, socket_sendmsg, socket_sendmsg, probe_socket_sendmsg,
> - "sock %p family %d type %d protocol %d size %zu",
> - sock, sock->sk->sk_family, sock->sk->sk_type,
> - sock->sk->sk_protocol, size);
> + "sock %p msg %p size %zu ret %d",
> + sock, msg, size, ret);
> }
>
> -void probe_socket_recvmsg(struct socket *sock, struct msghdr *msg,
> - size_t size, int flags, int ret)
> +void probe_socket_recvmsg(struct socket *sock, struct msghdr *msg, size_t size,
> + int flags, int ret)
> {
> trace_mark_tp(net, socket_recvmsg, socket_recvmsg, probe_socket_recvmsg,
> - "sock %p family %d type %d protocol %d size %zu",
> - sock, sock->sk->sk_family, sock->sk->sk_type,
> - sock->sk->sk_protocol, size);
> + "sock %p msg %p size %zu flags %d ret %d",
> + sock, msg, size, flags, ret);
> }
>
> -void probe_socket_create(struct socket *sock, int fd)
> +void probe_socket_setsockopt(int fd, int level, int optname,
> + char __user *optval, int optlen, int ret)
> {
> - trace_mark_tp(net, socket_create, socket_create, probe_socket_create,
> - "sock %p family %d type %d protocol %d fd %d",
> - sock, sock->sk->sk_family, sock->sk->sk_type,
> - sock->sk->sk_protocol, fd);
> + trace_mark_tp(net, socket_setsockopt, socket_setsockopt,
> + probe_socket_setsockopt,
> + "fd %d level %d optname %d optval %p optlen %d ret %d",
> + fd, level, optname, optval, optlen, ret);
> +}
> +
> +void probe_socket_getsockopt(int fd, int level, int optname,
> + char __user *optval, int __user *optlen, int ret)
> +{
> + trace_mark_tp(net, socket_getsockopt, socket_getsockopt,
> + probe_socket_getsockopt,
> + "fd %d level %d optname %d optval %p optlen %p ret %d",
> + fd, level, optname, optval, optlen, ret);
> +}
> +
> +void probe_socket_shutdown(int fd, int how, int ret)
> +{
> + trace_mark_tp(net, socket_shutdown, socket_shutdown,
> + probe_socket_shutdown,
> + "fd %d how %d ret %d",
> + fd, how, ret);
> }
>
> void probe_socket_call(int call, unsigned long a0)
> --
> 1.5.5.3
>
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
--
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
More information about the lttng-dev
mailing list