kmod - Linux kernel module handling
Go to file
Gustavo Sverzut Barbieri 87ca03bd07 module refcount should start at 1.
the current way was having the referenced modules to be released given
the unref comparison checking for "> 0".
2011-12-04 17:24:08 -02:00
libkmod module refcount should start at 1. 2011-12-04 17:24:08 -02:00
m4 Import skeleton from libabc 2011-11-21 12:35:15 -02:00
test Clean 'shadowed declaration' warnings 2011-12-02 10:00:03 -02:00
.gitignore Add cscope.out and .swp files to gitignore 2011-11-25 00:32:28 -02:00
autogen.sh autogen: use "$@" and exec last program 2011-12-03 02:32:36 -02:00
configure.ac Add some good practices to autofoo 2011-11-22 17:47:52 -02:00
COPYING License library as LGPL 2011-12-03 04:30:41 -02:00
Makefile.am Do not ship autogen.sh in the tarball 2011-12-02 17:54:42 -02:00
NEWS Rename libabc to libkmod 2011-11-21 14:35:35 -02:00
README README with purpose and initial overview. 2011-12-03 03:55:35 -02:00
TODO TODO: update file 2011-12-03 20:51:01 -02:00

libkmod - linux kernel module handling library

ABSTRACT
========

libkmod was created to allow programs to easily insert, remove and
list modules, also checking its properties, dependencies and aliases.

there is no shared/global context information and it can be used by
multiple sites on a single program, also being able to be used from
threads, although it's not thread safe (you must lock explicitly).


OVERVIEW
========

Every user should create and manage it's own library context with:

   struct kmod_ctx *ctx = kmod_new(kernel_dirname);
   kmod_unref(ctx);


Modules can be created with by various means:

   struct kmod_module *mod;
   int err;

   err = kmod_module_new_from_path(ctx, path, &mod);
   if (err < 0) {
      /* code */
   } else {
      /* code */
      kmod_module_unref(mod);
   }

   err = kmod_module_new_from_name(ctx, name, &mod);
   if (err < 0) {
      /* code */
   } else {
      /* code */
      kmod_module_unref(mod);
   }


Or could be resolved from a known alias to a list of alternatives:

   struct kmod_list *list, *itr;
   int err;
   err = kmod_module_new_from_lookup(ctx, alias, &list);
   if (err < 0) {
      /* code */
   } else {
      kmod_list_foreach(itr, list) {
         struct kmod_module *mod = kmod_module_get_module(itr);
         /* code */
      }
   }