Fix: liblttng-ust-dl ip context
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Wed, 10 Jun 2015 11:20:31 +0000 (13:20 +0200)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Wed, 10 Jun 2015 11:51:25 +0000 (13:51 +0200)
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
liblttng-ust-dl/ust_baddr.c
liblttng-ust-dl/ust_baddr.h
liblttng-ust-dl/ustdl.c

index f5b95b0bde43f54c8ef8de1c98bb95639c3ad49e..e407f6aac20ee0ad1fea8013004405b9170fa302 100644 (file)
@@ -18,4 +18,5 @@
 
 #define _LGPL_SOURCE
 #define TRACEPOINT_CREATE_PROBES
+#define TP_IP_PARAM ip
 #include "ust_baddr.h"
index 2c757f7ff41fa9e483eaa1a1b9d48ad9a5f56cff..0ca71dbf96eb77f4ea9902f61ec4bd4c1fbf9195 100644 (file)
@@ -37,7 +37,8 @@ extern "C" {
 #include <lttng/tracepoint.h>
 
 TRACEPOINT_EVENT(ust_baddr, push,
-       TP_ARGS(void *, baddr, const char*, sopath, int64_t, size, int64_t, mtime),
+       TP_ARGS(void *, baddr, const char*, sopath, int64_t, size,
+               int64_t, mtime, void *, ip),
        TP_FIELDS(
                ctf_integer_hex(void *, baddr, baddr)
                ctf_string(sopath, sopath)
@@ -47,7 +48,7 @@ TRACEPOINT_EVENT(ust_baddr, push,
 )
 
 TRACEPOINT_EVENT(ust_baddr, pop,
-       TP_ARGS(void *, baddr),
+       TP_ARGS(void *, baddr, void *, ip),
        TP_FIELDS(
                ctf_integer_hex(void *, baddr, baddr)
        )
index b6abca7b6e13c7562bbb4d1b8fccbcaea64bdf2b..fde537f62f057b94c646bd1af824665d7ed274ec 100644 (file)
@@ -67,7 +67,7 @@ int _lttng_ust_dl_libc_dlclose(void *handle)
 }
 
 static
-void lttng_ust_baddr_push(void *so_base, const char *so_name)
+void lttng_ust_baddr_push(void *so_base, const char *so_name, void *ip)
 {
        char resolved_path[PATH_MAX];
        struct stat sostat;
@@ -83,7 +83,7 @@ void lttng_ust_baddr_push(void *so_base, const char *so_name)
        }
 
        tracepoint(ust_baddr, push,
-               so_base, resolved_path, sostat.st_size, sostat.st_mtime);
+               so_base, resolved_path, sostat.st_size, sostat.st_mtime, ip);
        return;
 }
 
@@ -94,7 +94,8 @@ void *dlopen(const char *filename, int flag)
                struct link_map *p = NULL;
                if (dlinfo(handle, RTLD_DI_LINKMAP, &p) != -1 && p != NULL
                                && p->l_addr != 0)
-                       lttng_ust_baddr_push((void *) p->l_addr, p->l_name);
+                       lttng_ust_baddr_push((void *) p->l_addr, p->l_name,
+                               __builtin_return_address(0));
        }
        return handle;
 }
@@ -105,7 +106,8 @@ int dlclose(void *handle)
                struct link_map *p = NULL;
                if (dlinfo(handle, RTLD_DI_LINKMAP, &p) != -1 && p != NULL
                                && p->l_addr != 0)
-                       tracepoint(ust_baddr, pop, (void *) p->l_addr);
+                       tracepoint(ust_baddr, pop, (void *) p->l_addr,
+                               __builtin_return_address(0));
        }
        return _lttng_ust_dl_libc_dlclose(handle);
 }
This page took 0.026259 seconds and 4 git commands to generate.