livepatch: fix deferred module patching order
authorJosh Poimboeuf <jpoimboe@redhat.com>
Fri, 9 Jan 2015 20:03:04 +0000 (14:03 -0600)
committerJiri Kosina <jkosina@suse.cz>
Fri, 9 Jan 2015 21:27:47 +0000 (22:27 +0100)
When applying multiple patches to a module, if the module is loaded
after the patches are loaded, the patches are applied in reverse order:

  $ insmod patch1.ko
  [   43.172992] livepatch: enabling patch 'patch1'

  $ insmod patch2.ko
  [   46.571563] livepatch: enabling patch 'patch2'

  $ modprobe nfsd
  [   52.888922] livepatch: applying patch 'patch2' to loading module 'nfsd'
  [   52.899847] livepatch: applying patch 'patch1' to loading module 'nfsd'

Fix the loading order by storing the klp_patches list in queue order.

Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
kernel/livepatch/core.c

index ce42d3b930dcbdfe2f0b198bfca5ec4ff841a8c1..3d9c00b5223af9f224d9ea5659de9e4ff1698f6d 100644 (file)
@@ -739,7 +739,7 @@ static int klp_init_patch(struct klp_patch *patch)
                        goto free;
        }
 
-       list_add(&patch->list, &klp_patches);
+       list_add_tail(&patch->list, &klp_patches);
 
        mutex_unlock(&klp_mutex);