]> git.ipfire.org Git - thirdparty/kmod.git/commitdiff
add kmod_module_get_filtered_blacklist()
authorGustavo Sverzut Barbieri <barbieri@profusion.mobi>
Thu, 8 Dec 2011 07:17:43 +0000 (05:17 -0200)
committerLucas De Marchi <lucas.demarchi@profusion.mobi>
Thu, 8 Dec 2011 13:17:16 +0000 (11:17 -0200)
This function will filter the given list against the known blacklist,
returning a new list with remaining modules with the reference
incremented.

Makefile.am
libkmod/libkmod.c
libkmod/libkmod.h
libkmod/libkmod.sym
test/.gitignore
test/test-blacklist.c [new file with mode: 0644]

index da91e5c7e252bf12671b2f9f08ee9271fcae5288..b6ba9d8312dbfd3dc79fbfa0b1e630dae63b9b1d 100644 (file)
@@ -60,6 +60,7 @@ test_test_loaded_LDADD = libkmod/libkmod.la
 noinst_PROGRAMS = test/test-insmod test/test-rmmod test/test-rmmod2 \
                  test/test-lookup test/test-path-from-name \
                  test/test-get-dependencies test/test-mod-double-ref \
+                 test/test-blacklist \
                  $(check_PROGRAMS)
 
 test_test_rmmod_SOURCES = test/test-rmmod.c
@@ -82,3 +83,6 @@ test_test_get_dependencies_LDADD = libkmod/libkmod.la
 
 test_test_mod_double_ref_SOURCES = test/test-mod-double-ref.c
 test_test_mod_double_ref_LDADD = libkmod/libkmod.la
+
+test_test_blacklist_SOURCES = test/test-blacklist.c
+test_test_blacklist_LDADD = libkmod/libkmod.la
index fa1fdbbbc35e097f9b28b41096b2158296512ea4..20418e02bab407f820e23c8e774c9f613cc06c6b 100644 (file)
@@ -476,3 +476,46 @@ fail:
        *list = kmod_list_remove_n_latest(*list, nmatch);
        return err;
 }
+
+
+KMOD_EXPORT int kmod_module_get_filtered_blacklist(const struct kmod_ctx *ctx, const struct kmod_list *input, struct kmod_list **output)
+{
+       const struct kmod_config *config;
+       const struct kmod_list *li;
+
+       if (ctx == NULL || output == NULL)
+               return -ENOENT;
+
+       *output = NULL;
+       if (input == NULL)
+               return 0;
+
+       config = ctx->config;
+       kmod_list_foreach(li, input) {
+               struct kmod_module *mod = li->data;
+               const struct kmod_list *lb;
+               struct kmod_list *node;
+               bool filtered = false;
+               kmod_list_foreach(lb, config->blacklists) {
+                       const char *name = lb->data;
+                       if (streq(name, kmod_module_get_name(mod))) {
+                               filtered = true;
+                               break;
+                       }
+               }
+               if (filtered)
+                       continue;
+
+               node = kmod_list_append(*output, mod);
+               if (node == NULL)
+                       goto fail;
+               *output = node;
+               kmod_module_ref(mod);
+       }
+       return 0;
+
+fail:
+       kmod_module_unref_list(*output);
+       *output = NULL;
+       return -ENOMEM;
+}
index 81fa5a45f15cd7038b835fea5e2188c028e6bf52..72f74d03dad607127703f542b94394b9caa96336 100644 (file)
@@ -96,6 +96,8 @@ int kmod_module_unref_list(struct kmod_list *list);
 struct kmod_module *kmod_module_get_module(const struct kmod_list *entry);
 struct kmod_list *kmod_module_get_dependencies(const struct kmod_module *mod);
 
+int kmod_module_get_filtered_blacklist(const struct kmod_ctx *ctx, const struct kmod_list *input, struct kmod_list **output);
+
 int kmod_module_remove_module(struct kmod_module *mod, unsigned int flags);
 int kmod_module_insert_module(struct kmod_module *mod, unsigned int flags);
 
index ec3f8544380ba180a42081eb5527834ff818a62c..1b46c918359c1755b4a61bd22e7cefe63d2e011b 100644 (file)
@@ -25,6 +25,8 @@ global:
        kmod_module_get_dependencies;
        kmod_module_get_module;
 
+       kmod_module_get_filtered_blacklist;
+
        kmod_module_get_name;
        kmod_module_get_path;
 
index c22a72127964b9e97a373f79e2e66a80ba8165c2..0722c91ee155e1b61ed64567a69a7e3c52d0e526 100644 (file)
@@ -8,3 +8,4 @@ test-lookup
 test-path-from-name
 test-get-dependencies
 test-mod-double-ref
+test-blacklist
diff --git a/test/test-blacklist.c b/test/test-blacklist.c
new file mode 100644 (file)
index 0000000..515bfb8
--- /dev/null
@@ -0,0 +1,76 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <stddef.h>
+#include <errno.h>
+#include <unistd.h>
+#include <inttypes.h>
+#include <string.h>
+#include <libkmod.h>
+
+
+int main(int argc, char *argv[])
+{
+       const char *alias;
+       struct kmod_ctx *ctx;
+       struct kmod_list *list = NULL, *l;
+       int err;
+
+       printf("libkmod version %s\n", VERSION);
+
+       if (argc < 2) {
+               fprintf(stderr, "ERR: Provide an alias name\n");
+               return EXIT_FAILURE;
+       }
+
+       alias = argv[1];
+
+       ctx = kmod_new(NULL);
+       if (ctx == NULL)
+               exit(EXIT_FAILURE);
+
+       err = kmod_module_new_from_lookup(ctx, alias, &list);
+       if (err < 0)
+               goto fail_lookup;
+
+       if (list == NULL)
+               printf("No module matches '%s'\n", alias);
+       else
+               printf("Alias: '%s'\nModules matching:\n", alias);
+
+       kmod_list_foreach(l, list) {
+               struct kmod_module *mod = kmod_module_get_module(l);
+               printf("\t%s\n", kmod_module_get_name(mod));
+               kmod_module_unref(mod);
+       }
+
+       if (list != NULL) {
+               struct kmod_list *filtered;
+               err = kmod_module_get_filtered_blacklist(ctx, list, &filtered);
+               if (err < 0) {
+                       printf("Could not filter: %s\n", strerror(-err));
+                       goto fail;
+               }
+               if (filtered == NULL)
+                       printf("All modules were filtered out!\n");
+               else
+                       printf("Modules remaining after filter:\n");
+
+               kmod_list_foreach(l, filtered) {
+               struct kmod_module *mod = kmod_module_get_module(l);
+               printf("\t%s\n", kmod_module_get_name(mod));
+               kmod_module_unref(mod);
+               }
+               kmod_module_unref_list(filtered);
+       }
+
+       kmod_module_unref_list(list);
+       kmod_unref(ctx);
+
+       return EXIT_SUCCESS;
+
+fail:
+       kmod_module_unref_list(list);
+fail_lookup:
+       kmod_unref(ctx);
+       return EXIT_FAILURE;
+}