diff options
author | hunt <hunt> | 2007-10-12 19:42:32 +0000 |
---|---|---|
committer | hunt <hunt> | 2007-10-12 19:42:32 +0000 |
commit | 2972246a08bfc7c516455ecc4ef976e10c0ddb2c (patch) | |
tree | 030cb7ae2694103f6c9abb64e5419a0df11368eb /runtime/staprun/symbols.c | |
parent | 7651c16b0e3d7dba7265be5e83720e324bdf64b0 (diff) | |
download | systemtap-steved-2972246a08bfc7c516455ecc4ef976e10c0ddb2c.tar.gz systemtap-steved-2972246a08bfc7c516455ecc4ef976e10c0ddb2c.tar.xz systemtap-steved-2972246a08bfc7c516455ecc4ef976e10c0ddb2c.zip |
2007-10-12 Martin Hunt <hunt@redhat.com>
Changes to separate the symbols from the command channel.
* cap.c (init_cap): Add CAP_DAC_OVERRIDE.
* staprun.h: Change init_ctl_channel prototype.
* ctl.c (init_ctl_channel): Modify to open either
a command or symbol channel. Use ".cmd" and ".symbols"
as the new names.
* mainloop.c (init_stapio): Call init_ctl_channel(0);
* staprun.c (cleanup): Call stop_symbol_thread().
(main): Call start_symbol_thread().
* staprun_funcs.c (handle_symbols): Make a thread.
(start_symbol_thread): New.
(stop_symbol_thread): New.
Diffstat (limited to 'runtime/staprun/symbols.c')
-rw-r--r-- | runtime/staprun/symbols.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/runtime/staprun/symbols.c b/runtime/staprun/symbols.c index 61b56b2e..315362fa 100644 --- a/runtime/staprun/symbols.c +++ b/runtime/staprun/symbols.c @@ -140,7 +140,10 @@ err0: } #undef SECDIR -void send_module (char *mname) +/* + * For modules, we send the name, section names, and offsets + */ +static void send_module (char *mname) { char data[32768]; int len = get_sections(mname, data, sizeof(data)); @@ -152,6 +155,9 @@ void send_module (char *mname) } } +/* + * Send either all modules, or a specific one. + */ int do_module (void *data) { struct _stp_module *mod = (struct _stp_module *)data; @@ -183,6 +189,11 @@ static int compar(const void *p1, const void *p2) #define MAX_SYMBOLS 32*1024 +/* + * Read /proc/kallsyms and send all kernel symbols to the + * systemtap module. Ignore module symbols; the systemtap module + * can access them directly. + */ void do_kernel_symbols(void) { FILE *kallsyms=NULL; |