Commit eaccf275 authored by Mark Drayton's avatar Mark Drayton

Make bcc_symcache_new(tid) work with symbols from /tmp/perf-pid.map

parent f02448c6
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include "bcc_perf_map.h" #include "bcc_perf_map.h"
int bcc_perf_map_nspid(int pid) { int bcc_perf_map_nstgid(int pid) {
char status_path[64]; char status_path[64];
FILE *status; FILE *status;
...@@ -30,19 +30,22 @@ int bcc_perf_map_nspid(int pid) { ...@@ -30,19 +30,22 @@ int bcc_perf_map_nspid(int pid) {
if (!status) if (!status)
return -1; return -1;
// return the original PID if the NSpid line is missing // return the original PID if we fail to work out the TGID
int nspid = pid; int nstgid = pid;
size_t size = 0; size_t size = 0;
char *line = NULL; char *line = NULL;
while (getline(&line, &size, status) != -1) { while (getline(&line, &size, status) != -1) {
if (strstr(line, "NSpid:") != NULL) // check Tgid line first in case CONFIG_PID_NS is off
if (strstr(line, "Tgid:") != NULL)
nstgid = (int)strtol(strrchr(line, '\t'), NULL, 10);
if (strstr(line, "NStgid:") != NULL)
// PID namespaces can be nested -- last number is innermost PID // PID namespaces can be nested -- last number is innermost PID
nspid = (int)strtol(strrchr(line, '\t'), NULL, 10); nstgid = (int)strtol(strrchr(line, '\t'), NULL, 10);
} }
free(line); free(line);
return nspid; return nstgid;
} }
bool bcc_perf_map_path(char *map_path, size_t map_len, int pid) { bool bcc_perf_map_path(char *map_path, size_t map_len, int pid) {
...@@ -58,9 +61,9 @@ bool bcc_perf_map_path(char *map_path, size_t map_len, int pid) { ...@@ -58,9 +61,9 @@ bool bcc_perf_map_path(char *map_path, size_t map_len, int pid) {
if (strcmp(target, "/") == 0) if (strcmp(target, "/") == 0)
target[0] = '\0'; target[0] = '\0';
int nspid = bcc_perf_map_nspid(pid); int nstgid = bcc_perf_map_nstgid(pid);
snprintf(map_path, map_len, "%s/tmp/perf-%d.map", target, nspid); snprintf(map_path, map_len, "%s/tmp/perf-%d.map", target, nstgid);
return true; return true;
} }
......
...@@ -27,7 +27,7 @@ extern "C" { ...@@ -27,7 +27,7 @@ extern "C" {
typedef int (*bcc_perf_map_symcb)(const char *, uint64_t, uint64_t, int, typedef int (*bcc_perf_map_symcb)(const char *, uint64_t, uint64_t, int,
void *); void *);
int bcc_perf_map_nspid(int pid); int bcc_perf_map_nstgid(int pid);
bool bcc_perf_map_path(char *map_path, size_t map_len, int pid); bool bcc_perf_map_path(char *map_path, size_t map_len, int pid);
int bcc_perf_map_foreach_sym(const char *path, bcc_perf_map_symcb callback, int bcc_perf_map_foreach_sym(const char *path, bcc_perf_map_symcb callback,
void* payload); void* payload);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment