Home | History | Annotate | only in /external/kmod/libkmod
Up to higher level directory
NameDateSize
.gitignore05-Oct-201745
COPYING05-Oct-201725.8K
docs/05-Oct-2017
libkmod-config.c05-Oct-201727.8K
libkmod-elf.c05-Oct-201727.1K
libkmod-file.c05-Oct-20177.6K
libkmod-index.c05-Oct-201722.9K
libkmod-index.h05-Oct-20171.7K
libkmod-internal.h05-Oct-20179.4K
libkmod-list.c05-Oct-20176.8K
libkmod-module.c05-Oct-201768.2K
libkmod-signature.c05-Oct-20174.1K
libkmod.c05-Oct-201722K
libkmod.h05-Oct-20179.2K
libkmod.pc.in05-Oct-2017255
libkmod.sym05-Oct-20172K
Makefile05-Oct-2017332
python/05-Oct-2017
README05-Oct-20171.3K

README

      1 libkmod - linux kernel module handling library
      2 
      3 ABSTRACT
      4 ========
      5 
      6 libkmod was created to allow programs to easily insert, remove and
      7 list modules, also checking its properties, dependencies and aliases.
      8 
      9 there is no shared/global context information and it can be used by
     10 multiple sites on a single program, also being able to be used from
     11 threads, although it's not thread safe (you must lock explicitly).
     12 
     13 
     14 OVERVIEW
     15 ========
     16 
     17 Every user should create and manage it's own library context with:
     18 
     19    struct kmod_ctx *ctx = kmod_new(kernel_dirname);
     20    kmod_unref(ctx);
     21 
     22 
     23 Modules can be created by various means:
     24 
     25    struct kmod_module *mod;
     26    int err;
     27 
     28    err = kmod_module_new_from_path(ctx, path, &mod);
     29    if (err < 0) {
     30       /* code */
     31    } else {
     32       /* code */
     33       kmod_module_unref(mod);
     34    }
     35 
     36    err = kmod_module_new_from_name(ctx, name, &mod);
     37    if (err < 0) {
     38       /* code */
     39    } else {
     40       /* code */
     41       kmod_module_unref(mod);
     42    }
     43 
     44 
     45 Or could be resolved from a known alias to a list of alternatives:
     46 
     47    struct kmod_list *list, *itr;
     48    int err;
     49    err = kmod_module_new_from_lookup(ctx, alias, &list);
     50    if (err < 0) {
     51       /* code */
     52    } else {
     53       kmod_list_foreach(itr, list) {
     54          struct kmod_module *mod = kmod_module_get_module(itr);
     55          /* code */
     56       }
     57    }
     58 
     59