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
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
*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;
+}
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);
kmod_module_get_dependencies;
kmod_module_get_module;
+ kmod_module_get_filtered_blacklist;
+
kmod_module_get_name;
kmod_module_get_path;
test-path-from-name
test-get-dependencies
test-mod-double-ref
+test-blacklist
--- /dev/null
+#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;
+}