[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