Merge pull request #436 from jpoimboe/descriptor

make "descriptor" a special static local variable
This commit is contained in:
Seth Jennings 2014-10-02 23:11:00 -05:00
commit c6506ec549
4 changed files with 48 additions and 15 deletions

View File

@ -534,12 +534,20 @@ char *special_static_prefix(struct symbol *sym)
if (!strncmp(sym->name, "__warned.", 9)) if (!strncmp(sym->name, "__warned.", 9))
return "__warned."; return "__warned.";
if (!strncmp(sym->name, "descriptor.", 11))
return "descriptor.";
} }
if (sym->type == STT_SECTION && if (sym->type == STT_SECTION) {
!strncmp(sym->name, ".bss.__key.", 11)) if (!strncmp(sym->name, ".bss.__key.", 11))
return ".bss.__key."; return ".bss.__key.";
/* __verbose section contains the descriptor variables */
if (!strcmp(sym->name, "__verbose"))
return sym->name;
}
return NULL; return NULL;
} }
@ -941,14 +949,6 @@ void kpatch_correlate_static_local_variables(struct kpatch_elf *base,
if (special_static_prefix(sym)) if (special_static_prefix(sym))
continue; continue;
/*
* The static variables in the __verbose section contain
* debugging information specific to the patched object and
* shouldn't be correlated.
*/
if (!strcmp(sym->sec->name, "__verbose"))
continue;
if (!strchr(sym->name, '.')) if (!strchr(sym->name, '.'))
continue; continue;

View File

@ -0,0 +1,21 @@
Index: src/fs/aio.c
===================================================================
--- src.orig/fs/aio.c
+++ src/fs/aio.c
@@ -229,9 +229,16 @@ static int __init aio_setup(void)
}
__initcall(aio_setup);
+void kpatch_aio_foo(void)
+{
+ if (!jiffies)
+ printk("kpatch aio foo\n");
+}
+
static void put_aio_ring_file(struct kioctx *ctx)
{
struct file *aio_ring_file = ctx->aio_ring_file;
+ kpatch_aio_foo();
if (aio_ring_file) {
truncate_setsize(aio_ring_file->f_inode, 0);

View File

@ -0,0 +1,7 @@
#!/bin/bash
if $(nm kpatch-gcc-static-local-var-4.ko | grep -q free_ioctx); then
exit 1
else
exit 0
fi

View File

@ -2,19 +2,24 @@ Index: src/fs/aio.c
=================================================================== ===================================================================
--- src.orig/fs/aio.c --- src.orig/fs/aio.c
+++ src/fs/aio.c +++ src/fs/aio.c
@@ -1642,3 +1642,15 @@ SYSCALL_DEFINE5(io_getevents, aio_contex @@ -1626,6 +1626,20 @@ SYSCALL_DEFINE3(io_cancel, aio_context_t
}
return ret; return ret;
} }
+
+static int aio_max_nr_orig;
+void kpatch_load_aio_max_nr(void) +void kpatch_load_aio_max_nr(void)
+{ +{
+ aio_max_nr_orig = aio_max_nr;
+ aio_max_nr = 0x40000; + aio_max_nr = 0x40000;
+} +}
+void kpatch_unload_aio_max_nr(void) +void kpatch_unload_aio_max_nr(void)
+{ +{
+ aio_max_nr = 0x10000; + aio_max_nr = aio_max_nr_orig;
+} +}
+#include "kpatch-macros.h" +#include "kpatch-macros.h"
+KPATCH_LOAD_HOOK(kpatch_load_aio_max_nr); +KPATCH_LOAD_HOOK(kpatch_load_aio_max_nr);
+KPATCH_UNLOAD_HOOK(kpatch_unload_aio_max_nr); +KPATCH_UNLOAD_HOOK(kpatch_unload_aio_max_nr);
+
/* io_getevents:
* Attempts to read at least min_nr events and up to nr events from
* the completion queue for the aio_context specified by ctx_id. If