diff options
-rw-r--r-- | buildrun.cxx | 1 | ||||
-rw-r--r-- | runtime/autoconf-grsecurity.c | 11 | ||||
-rw-r--r-- | runtime/print.c | 30 |
3 files changed, 29 insertions, 13 deletions
diff --git a/buildrun.cxx b/buildrun.cxx index 796663e0..1820002d 100644 --- a/buildrun.cxx +++ b/buildrun.cxx @@ -154,6 +154,7 @@ compile_pass (systemtap_session& s) output_autoconf(s, o, "autoconf-procfs-owner.c", "STAPCONF_PROCFS_OWNER", NULL); output_autoconf(s, o, "autoconf-alloc-percpu-align.c", "STAPCONF_ALLOC_PERCPU_ALIGN", NULL); output_autoconf(s, o, "autoconf-x86-gs.c", "STAPCONF_X86_GS", NULL); + output_autoconf(s, o, "autoconf-grsecurity.c", "STAPCONF_GRSECURITY", NULL); #if 0 /* NB: For now, the performance hit of probe_kernel_read/write (vs. our diff --git a/runtime/autoconf-grsecurity.c b/runtime/autoconf-grsecurity.c new file mode 100644 index 00000000..ee2e4e55 --- /dev/null +++ b/runtime/autoconf-grsecurity.c @@ -0,0 +1,11 @@ +/* PR10551: pax/grsecurity changes linux/module.h */ + +#include <linux/module.h> + +struct module *t; +unsigned size; + +void foo (void) +{ + size += t->init_size_rw + t->init_size_rx + t->core_size_rw + t->core_size_rx; +} diff --git a/runtime/print.c b/runtime/print.c index 69e04073..b11e659b 100644 --- a/runtime/print.c +++ b/runtime/print.c @@ -216,28 +216,32 @@ static void _stp_print_char (const char c) static void _stp_print_kernel_info(char *vstr, int ctx, int num_probes) { + printk(KERN_DEBUG + "%s: systemtap: %s, base: %p, memory: %lu+%lu+%u+%u" #ifdef DEBUG_MEM - printk(KERN_DEBUG "%s: systemtap: %s, base: %p, memory: %lu+%lu+%u+%u+%u data+text+ctx+net+alloc, probes: %d\n", + "+%u" +#endif + " data+text+ctx+net" +#ifdef DEBUG_MEM + "+alloc" +#endif + ", probes: %d\n", THIS_MODULE->name, vstr, - THIS_MODULE->module_core, + THIS_MODULE->module_core, +#ifndef STAPCONF_GRSECURITY (unsigned long) (THIS_MODULE->core_size - THIS_MODULE->core_text_size), (unsigned long) THIS_MODULE->core_text_size, - ctx, - _stp_allocated_net_memory, - _stp_allocated_memory - _stp_allocated_net_memory, - num_probes); #else - printk(KERN_DEBUG "%s: systemtap: %s, base: %p, memory: %lu+%lu+%u+%u data+text+ctx+net, probes: %d\n", - THIS_MODULE->name, - vstr, - THIS_MODULE->module_core, - (unsigned long) (THIS_MODULE->core_size - THIS_MODULE->core_text_size), - (unsigned long) THIS_MODULE->core_text_size, + (unsigned long) (THIS_MODULE->core_size_rw - THIS_MODULE->core_size_rx), + (unsigned long) THIS_MODULE->core_size_rx, +#endif ctx, _stp_allocated_net_memory, - num_probes); +#ifdef DEBUG_MEM + _stp_allocated_memory - _stp_allocated_net_memory, #endif + num_probes); } /** @} */ |