Provided by: dkms_2.3-3ubuntu9.7_all bug

NAME

       dkms - Dynamic Kernel Module Support

SYNOPSIS

       dkms [action] [options] [module/module-version] [/path/to/source-tree]
            [/path/to/tarball.tar] [/path/to/driver.rpm]

DESCRIPTION

       dkms is a framework which allows kernel modules to be dynamically built for each kernel on
       your system in a simplified and organized fashion.

ACTIONS

       add [module/module-version] [/path/to/source-tree] [/path/to/tarball.tar]

           Adds  a  module/module-version  combination  to  the tree for builds and installs.  If
           module/module-version, -m module/module-version, or -m module -v version are passed as
           options,  this  command requires source in /usr/src/<module>-<module-version>/ as well
           as a properly formatted dkms.conf  file.  If  /path/to/source-tree  is  passed  as  an
           option,  and  source-tree contains a dkms.conf file, it will copy /path/to/source-tree
           to /usr/src/module-module-version.  If /path/to/tarball.tar is  passed,  this  command
           behaves like the ldtarball command.

       remove [module/module-version] [-k kernel/arch] [--all]

           Removes  a module/version or module/version/kernel/arch combination from the tree.  If
           the module is currently installed, it first uninstalls  it  and  if  applicable,  will
           replace  it  with  its  original_module.   Use the --all option in order to remove all
           instances for every kernel at once.

       build [module/module-version] [-k kernel/arch]

           Builds the specified module/version combo for the specified  kernel/arch.  If  the  -k
           option  is  not  specified  it builds for the currently running kernel and arch..  All
           builds occur in the directory /var/lib/dkms/<module>/<module-version>/build/.  If  the
           module/module-version  combo  has not been added, dkms will try to add it, and in that
           case build can take the same arguments that add can.

       install [module/module-version] [-k kernel/arch] [/path/to/driver.rpm]

           Installs a built module/version combo onto the kernel it was built for. If the  kernel
           option  is  not  specified it assumes the currently running kernel.  If the module has
           not been built, dkms will try to build it.  If the module has  not  been  added,  dkms
           will  try  to  add  it.   In  both  cases,  the install command can then take the same
           arguments as the build or add commands.  If you pass a .rpm file,  dkms  will  try  to
           install  that file with rpm -Uvh , and it will perform an autoinstall action to mesure
           that everything is built for your kernel if the RPM installed sucessfully.

       uninstall [module/module-version] [-k kernel/arch]

           Uninstalls an installed module/module-version combo from the kernel/arch passed in the
           -k  option,  or  the  current  kernel  if  the -k option was not passed.  upon.  After
           uninstall completion, the driver will be left  in  the  built  state.   To  completely
           remove a driver, the remove action should be utilized.

       match [--templatekernel kernel/arch] [-k kernel/arch]

           Match  installs  modules  onto the specified kernel by looking at the configuration of
           the specified templatekernel.  Every module that is installed  on  the  templatekernel
           within dkms is then installed on that specified kernel.

       mkdriverdisk [-d distro] [-r release] [--media mediatype] [-k kernel/arch]
                    [module/version]

           Creates a floppy driver disk image for use when updated drivers are needed to  install
           an  OS.   Currently, the supported distributions are redhat, suse and UnitedLinux. For
           Red  Hat  driver  disks,  necessary  driver  disk  files  are  looked   for   in   the
           redhat_driver_disk subdirectory of your module source directory.  You must specify the
           distro while using this action.  Driver disks can be made for single kernels or can be
           made  to  support  multiple  kernels.   To create a driver disk image with modules for
           multiple kernels, just  specify  multiple  -k  parameters  on  the  command  line  (-k
           kernel1/arch1 -k kernel2/arch2).

           Red  Hat  began supporting multi-arched driver disks in RHEL3.  To force creation of a
           driver disk with arch information, specify -d  redhat2  or  if  you  specify  multiple
           architectures  on  the  command-line  and use -d redhat , DKMS will create a version 2
           driver disk.  By specifying -d redhat1 , you can force a version 1 driver disk image.

           Note that redhat1 driver disks actually  supported  multiple  architectures  when  the
           second  arch  was i386 and the kernel module was for the BOOT kernel.  DKMS allows for
           this, and as such you can create a redhat1 style driver disk if the only other arch is
           i386 and the kernel name ends in BOOT.

           Red  Hat  introduced  DDv3  starting  with  RHEL6.  To create Red Hat DDv3, specify -d
           redhat3 and specify the specfile to use  with  --spec=specfile.   If  no  specfile  is
           specified, DKMS will use /etc/dkms/template-dkms-redhat-kmod.spec

           See  http://people.redhat.com/dledford for more information on the Red Hat driver disk
           standards and which files are necessary to make a driver disk.

           Fedora Core 5 and higher, RHEL5 and higher require DKMS version 2.0.14  or  higher  to
           generate a proper driver disk image.

           For  suse/UnitedLinux  driver  disks, /usr/share/YaST2/modules/Vendor.ycp will also be
           copied to the driver disk; no other files are needed.  However, for these distros, you
           must  specify  a  -r  release. For SuSE 9.1, it would be -d suse -r 9.1. For SLES9, it
           would be -d suse -r sles9.

           By default the disk image it creates is 1440 (k) in size.  This can be  overridden  by
           specifying  a  different  --size  ####  which  should  should  be given as a number in
           kilobytes divisible by 20.

           You may have more content than will fit on a floppy.  Therefore, DKMS can now generate
           image  files  of  different types.  --media floppy (default) to generate a floppy disk
           image, or --media iso to generate a CD-ROM ISO file, or --media tar to generate a  tar
           file.

           You may copy the floppy or ISO image file to a USB key to be used with OS installer.

       mktarball [module/module-version] [-k kernel/arch] [--archive /path/to/tarball.tar]
                 [--source-only] [--binaries-only]

           Creates a tarball archive for the specified module/version of all files  in  the  DKMS
           tree  for  that  module/version  combination.   This includes the source and any built
           modules for kernels in the tree (as specified).  Otherwise, you can specify a singular
           kernel  to  archive  only,  or  multiple  kernels  to  archive  (-k  kernel1/arch1  -k
           kernel2/arch2).  Optionally, you can use --archive to specify the file that you  would
           like  to  save  this tarball to.  You can also specify --binaries-only if you want the
           resultant tarball not to include the module source.  Likewise,  --source-only  can  be
           used  to  specify  that  no  prebuilt  binaries should be included in the tarball.  In
           general, mktarball is great for systems management purposes  as  you  can  build  your
           driver  on  just one system and then use ldtarball on all of your other systems to get
           the same built modules loaded without having to wait for anything to compile.

       ldtarball

           This takes a tarball made from the mktarball command and loads it into your DKMS tree.
           This  will  leave  any  newly added modules in the built state and dkms install should
           then be called to install any of them.  If files  already  exist  where  ldtarball  is
           attempting  to  place  them,  it will warn and not copy over them.  The --force option
           should be used to override this.

       mkrpm [module/module-version] [-k kernel/arch] [--source-only] [--binaries-only]

           This action allows you to create an RPM package for a specified module / version.   It
           uses  a  template  .spec file found in /etc/dkms/template-dkms-mkrpm.spec as the basis
           for    the    RPM.     Alternatively,    if    DKMS    finds     a     file     called
           /usr/src/<module>-<module-version>/<module>-dkms-mkrpm.spec  it  will  use  that .spec
           file instead.  In general, a DKMS tarball is placed inside the contents of  this  RPM,
           and the RPM itself calls various DKMS commands to load this tarball, build and install
           modules on the end user's system.  If you do not want your RPM to contain any prebuilt
           binaries, be sure to specify --source-only in the mkrpm command.

       mkdeb [module/module-version] [-k kernel/arch] [--binaries-only] [--source-only]

           This  action  allows  you  to  create a debian binary package for a specified module /
           version.  It uses a template debian directory found  in  /etc/dkms/template-dkms-mkdeb
           as   the   basis  for  the  package.  Alternatively,  if  DKMS  finds  a  file  called
           /usr/src/<module>-<module-version>/<module>-dkms-mkdeb  it  will   use   that   folder
           instead. In general, a DKMS tarball is placed inside the contents of this package, and
           the package itself calls various DKMS commands to load this tarball, build and install
           modules  on  the end user's system.  If you do not want your debian package to contain
           any prebuilt binaries, be sure to specify --source-only in the mkdeb command.

       mkbmdeb [module/module-version] [-k kernel/arch]

           Creates a Debian binary package containing just the binary modules in the /lib/modules
           installation  path.  This  package  does  not  depend  on  dkms and does not require a
           toolchain to be installed on the target host. Useful if you want to have a package  to
           install  on  hosts identical to the build system without installing the full toolchain
           on them.  It uses a template debian directory found in /etc/dkms/template-dkms-mkbmdeb
           as the basis for the package.

       mkdsc [module/module-version] [-k kernel/arch] [--binaries-only] [--source-only]

           This  action  allows  you  to  create a debian source package for a specified module /
           version.  It will create a .tar.gz, and a .dsc.  All options supported  by  mkdeb  are
           supported  by  it.   The  main  difference  in  it's  usage  is  that  it will look in
           /etc/dkms/template-dkms-mkdsc as the basis for the  package.  Alternatively,  if  DKMS
           finds a file called /usr/src/<module>-<module-version>/<module>-dkms-mkdsc it will use
           that folder instead. If you do not want your debian  source  package  to  contain  any
           prebuilt binaries, be sure to specify --source-only in the mkdsc command.

       mkkmp [module/module-version] [--spec specfile]

           This  action  allows you to create an Kernel Module Package source RPM for a specified
           module  /  version.   It  uses  the  .spec  file  specified  by  --spec=specfile  else
           $module-kmp.spec as the basis for the RPM.  The generated source RPM may then be built
           using   SuSE's   build.rpm   or   Fedora/RHEL's   mock   chroot   environments.    See
           http://kerneldrivers.org/ for more details on KMPs.

       status [module/module-version] [-k kernel/arch]

           Returns the current status of modules, versions and kernels within the tree as well as
           whether they have been added, built or installed.  Status can  be  shown  for  just  a
           certain    module,   a   certain   kernel,   a   module/version   combination   or   a
           module/version/kernel combination.

       autoinstall

           Attempt to install the latest revision of all modules that  have  been  installed  for
           other kernel revisions.  dkms_autoinstaller is a stub that uses this action to perform
           its work.

OPTIONS

       -m <module>/<module-version>
              The name of the module and module version you wnat to operate on. The  -m  part  of
              this option is optional, and can be omitted in virtually all circumstances.

       -v <module-version>
              The  version  of the module to execute the specified action upon.  This option only
              has to be specified if you pass a -m option without a <module-version> component of
              its own.

       -k <kernel-version>/<arch>
              The  kernel  and  arch to perform the action upon.  You can specify multiple kernel
              version/arch pairs on the  command  line  by  repeating  the  -k  argument  with  a
              different  kernel  version  and  arch.   However,  not all actions support multiple
              kernel versions (it will error out in this case).  The arch part  can  be  omitted,
              and DKMS will assume you want it to be the arch of the currently running system.

       -a, --arch
              The  system architecture to perform the action upon.  It is optional if you pass it
              as part of the -k option. If not specified, it assumes the arch  of  the  currently
              running  system (`uname -m`).  You can specify multiple arch parameters on the same
              command line by repeating the  -a  argument  with  a  different  arch  name.   When
              multiple  architectures  are specified, there must be a 1:1 relationship between -k
              arguments to -a arguments.  DKMS will then assume the first -a argument aligns with
              the first -k kernel and so on for the second, third, etc.

              For  example,  if  you were to specify: -k kernel1 -k kernel2 -a i386 -k kernel3 -a
              i686  -a  x86_64,  DKMS  would  process  this   as:   kernel1-i386,   kernel2-i686,
              kernel3-x86_64.

       -q, --quiet
              Quiet.

       -V, --version
              Prints the currently installed version of dkms and exits.

       -c <dkms.conf-location>
              The  location  of the dkms.conf file.  This is needed for the add action and if not
              specified, it is assumed to be located in /usr/src/<module>-<module-version>/.  See
              below for more information on the format of dkms.conf.

       -d, --distro
              The  distribution being used.  This is only currently needed for mkdriverdisk.  The
              supported  distros  are  redhat,  suse  and  UnitedLinux.   See  the  sections   on
              mkdriverdisk and mkkmp for more information.

       -r, --release
              The  release  being used.  This is only currently used for mkdriverdisk and is only
              used for suse or UnitedLinux distros (eg. -r 9.1).  It  is  used  in  the  internal
              makeup of the driverdisk.

       --size The  size of the driver disk image to be created.  By default, this value is set at
              1440.  Any different size should be given as  an  integer  value  only,  should  be
              divisible  by 20 and should represent the number of kilobytes of the image size you
              desire.

       --config <kernel-.config-location>
              During a build this option is used to specify an alternate location for the  kernel
              .config  file  which  was used to compile that kernel.  Normally, dkms uses the Red
              Hat     standard     location     and     config     filenames      located      in
              /usr/src/linux-<kernel>/configs/.   If  the  config  for  the  kernel  that you are
              building a module for is not located here or does not have  the  expected  name  in
              this  location, you will need to tell dkms where the necessary .config can be found
              so that your kernel can be properly prepared for the module build.

       --archive <tarball-location>
              This option is used during a ldtarball  action  to  specify  the  location  of  the
              tarball  you  wish  to  load  into  your  DKMS  tree.  You only have to specify the
              --archive part of this option if <tarball-location> does not  already  exist  as  a
              file.

       --templatekernel <kernel-version>
              This   option  is  required  for  the  action:  match.   Match  will  look  at  the
              templatekernel specified and install all of the same module/version combinations on
              the other kernel.

       --force
              This  option  can  be  used  in conjunction with ldtarball to force copying over of
              extant files.

       --binaries-only
              This option can be used in conjunction with mktarball in order  to  create  a  DKMS
              tarball  which  does  not contain the source for the module within it.  This can be
              helpful in reducing the size of the tarball if you know that the system which  this
              tarball  will  be loaded upon already has the source installed.  In order to load a
              tarball made as binaries-only you must have the module source in that systems  DKMS
              tree.  If you do not, DKMS will refuse to load a binaries-only tarball.

       --source-only
              This option can be used in conjunction with mktarball or mkrpm or mkdeb in order to
              create a DKMS tarball which does not contain any prebuilt  kernel  module  binaries
              within  it.   This  is  helpful if you simply want to easily tar up your source but
              don't want anything prebuilt within it.  Likewise, if you are using  mkrpm  but  do
              not  want  the  RPM you create to have any prebuilt modules within it, passing this
              option will keep its internal DKMS tarball from containing any prebuilt modules.

       --all  This option can be used to automatically specify all relevant kernels/arches for  a
              module/module-version.   This  is  useful for things like remove , mktarball , etc.
              This saves the trouble of having to actually specify -k kernel1 -a arch1 -k kernel2
              -a arch2 for every kernel you have built your module for.

       --no-prepare-kernel
              This  option  keeps  DKMS from first preparing your kernel before building a module
              for it.  Generally, this option should not be used so as to ensure that modules are
              compiled correctly.

       --no-clean-kernel
              This option keeps DKMS from cleaning your kernel source tree after a build.

       --no-depmod
              This  option  prevents  DKMS  from  running  the  depmod command during install and
              uninstall which will avoid (re)calculating module  dependencies  and  thereby  save
              time.

       --kernelsourcedir <kernel-source-directory-location>
              Using  this  option  you  can specify the location of your kernel source directory.
              Most likely you will not need to set this if your kernel source is  accessible  via
              /lib/modules/$kernel_version/build.

       --directive <"cli-directive=cli-value">
              Using  this  option,  you  can specify additional directives from the command line.
              The --directive option can be used multiple  times  on  the  same  command-line  to
              specify multiple additional command line directives.

       --rpm_safe_upgrade
              This flag should be used when packaging DKMS enabled modules in RPMs.  It should be
              specified during both the add and remove actions in the RPM  spec  to  ensure  that
              DKMS  and  RPM  behave  correctly  in  all scenarios when upgrading between various
              versions of a dkms enabled module RPM package.  See the  sample.spec  file  for  an
              example or read more in the section below on Creating RPMs Which Utilize DKMS.

       --spec specfile
              This  option is used by the mkkmp action to specify which RPM spec file to use when
              generating the KMP.  specfile will be sought in the module source directory.

       --dkmstree path/to/place
              Provides a destination tree for building and  installing  modules  to.   Useful  in
              cases that you don't want to contaminate a system when using solely for building.

       --sourcetree path/to/place
              Provides  a location to build a DKMS package from.  Useful for systems that you may
              not have root access, but would still like to be able to build DKMS packages.

       --installtree path/to/place
              Provides a location to place modules when a dkms install command is issued.

       --legacy-postinst=[0|1]
              Includes a legacy postinstall script so that a DEB or RPM built by DKMS can be used
              on versions prior than DKMS 2.1.  This option currently defaults to 1.

       --dkmsframework path/to/file
              A  supplemental  configuration  file  to  the system-wide dkms framework, typically
              located in /etc/dkms/framework.conf.  All option that are normally  provided  on  a
              command line can be provided in this file.

       -j number
              Run  no  more than number jobs in parallel; see the -j option of make(1).  Defaults
              to the number of CPUs in the system, detected by nproc(1).  Specify 0 to impose  no
              limit on the number of parallel jobs.

ORIGINAL MODULES

       During   the   first  install  of  a  module  for  a  <kernelversion>,  dkms  will  search
       /lib/modules/<kernelversion> for a pre-existing module of the same name. If one is  found,
       it  will  automatically  be  saved  as an "original_module" so that if the newer module is
       later removed, dkms will put the original module  back  in  its  place.   Currently,  DKMS
       searches  for  these  original  modules  with first preference going to modules located in
       /lib/modules/<kernelversion>/updates/ followed by $DEST_MODULE_LOCATION (as  specified  in
       dkms.conf ).  If one cannot be found in either location, a find will be used to locate one
       for that kernel.  If none are found, then during a later uninstall, your kernel  will  not
       have that module replaced.

       If more than one is found, then the first one located (by preference indicated above) will
       be considered the "original_module".  As well, all copies of the same-named module will be
       removed        from        your        kernel       tree       and       placed       into
       /var/lib/dkms/<module>/original_module/$kernelver/collisions   so   that   they   can   be
       *manually*  accessible  later. DKMS will never actually do anything with the modules found
       underneath the /collisions directory, and they will be stored  there  until  you  manually
       delete them.

DKMS.CONF

       When performing an add , a proper dkms.conf file must be found.  A properly formatted conf
       file is essential for communicating to dkms how and where the module should be  installed.
       While  not  all  the directives are required, providing as many as possible helps to limit
       any ambiguity.  Note that  the  dkms.conf  is  really  only  a  shell-script  of  variable
       definitions   which   are  then  sourced  in  by  the  dkms  executable  (of  the  format,
       DIRECTIVE="directive text goes here").  As well, the  directives  are  case-sensitive  and
       should be given in ALL CAPS.

       It  is  important  to  understand  that many of the DKMS directives are arrays whose index
       values are tied together.  These array associations can be considered families, and  there
       are  currently  four such families of directive arrays.  MAKE[#] and MAKE_MATCH[#] make up
       one family.  PATCH[#] and PATCH_MATCH[#] make  up  the  second  family.   The  third   and
       largest     family    consists    of    BUILT_MODULE_NAME[#],    BUILT_MODULE_LOCATION[#],
       DEST_MODULE_NAME[#],         DEST_MODULE_LOCATION[#],          MODULES_CONF_ALIAS_TYPE[#],
       MODULES_CONF_OBSOLETES[#],  MODULES_CONF_OBSOLETE_ONLY[#] and STRIP[#].  The fourth family
       is made up of only  MODULES_CONF[#].   When  indexing  these  arrays  when  creating  your
       dkms.conf, each family should start at index value 0.

       MAKE[#]=
              The  MAKE directive array tells DKMS which make command should be used for building
              your module. The default make command should be put into MAKE[0].  Other entries in
              the  MAKE  array  will  only  be used if their corresponding entry in MAKE_MATCH[#]
              matches, as a regular expression (using egrep), the kernel that the module is being
              built  for.  Note that if no value is placed in MAKE_MATCH[#] for any MAKE[#] where
              # > 0, then that MAKE directive is ignored.  MAKE_MATCH[0] is optional and if it is
              populated,  it  will  be  used  to determine if MAKE[0] should be used to build the
              module for that kernel.  If multiple MAKE_MATCH directives match against the kernel
              being built for, the last matching MAKE[#] will be used to build your module. If no
              MAKE directive is specified or if no MAKE_MATCH matches the kernel being built for,
              DKMS will attempt to use a generic MAKE command to build your module.

              KERNELRELEASE  will  be automatically appended to MAKE[#].  If you want to suppress
              this behavior, you can quote the make command: 'make'.

       MAKE_MATCH[#]=
              See the above entry on MAKE[#] directives.  This array  should  be  populated  with
              regular  expressions  which,  when matched against the kernel being built for, will
              tell DKMS to use the corresponding make command in the MAKE[#] directive  array  to
              build your module.

       BUILT_MODULE_NAME[#]=
              This  directive  gives the name of the module just after it is built.  If your DKMS
              module package contains more than  one  module  to  install,  this  is  a  required
              directive for all of the modules.  This directive should explicitly not contain any
              trailing ".o" or ".ko".  Note that for each  module  within  a  dkms  package,  the
              numeric   value   of   #   must   be   the  same  for  each  of  BUILT_MODULE_NAME,
              BUILT_MODULE_LOCATION,  DEST_MODULE_NAME  and  DEST_MODULE_LOCATION  and  that  the
              numbering     should     start    at    0    (eg.    BUILT_MODULE_NAME[0]="qla2200"
              BUILT_MODULE_NAME[1]="qla2300").

       BUILT_MODULE_LOCATION[#]=
              This directive tells DKMS where to find your built module after it has been  built.
              This  pathname  should be given relative to the root directory of your source files
              (where your dkms.conf file can be found).  If unset,  DKMS  expects  to  find  your
              BUILT_MODULE_NAME[#]  in  the  root  directory of your source files.  Note that for
              each module within a dkms package, the numeric value of # must be the same for each
              of      BUILT_MODULE_NAME,      BUILT_MODULE_LOCATION,     DEST_MODULE_NAME     and
              DEST_MODULE_LOCATION  and   that   the   numbering   should   start   at   0   (eg.
              BUILT_MODULE_LOCATION[0]="some/dir/" BUILT_MODULE_LOCATION[1]="other/dir/").

       DEST_MODULE_NAME[#]=
              This  directive  can  be  used  to  specify  the name of the module as it should be
              installed.   This   will   rename   the   module   from   BUILT_MODULE_NAME[#]   to
              DEST_MODULE_NAME[#].   This  directive  should  explicitly not contain any trailing
              ".o"  or  ".ko".   If  unset,  it  is   assumed   to   be   the   same   value   as
              BUILT_MODULE_NAME[#].  Note that for each module within a dkms package, the numeric
              value of # must be the same for each of  BUILT_MODULE_NAME,  BUILT_MODULE_LOCATION,
              DEST_MODULE_NAME  and DEST_MODULE_LOCATION and that the numbering should start at 0
              (eg. DEST_MODULE_NAME[0]="qla2200_6x" DEST_MODULE_NAME[1]="qla2300_6x").

       DEST_MODULE_LOCATION[#]=
              This directive specifies the destination where a module  should  be  installed  to,
              once  compiled.   It also is used for finding original_modules.  This is a required
              directive, except as noted below. This directive must start with the text "/kernel"
              which  is  in reference to /lib/modules/<kernelversion>/kernel.  Note that for each
              module within a dkms package, the numeric value of # must be the same for  each  of
              BUILT_MODULE_NAME, BUILT_MODULE_LOCATION, DEST_MODULE_NAME and DEST_MODULE_LOCATION
              and     that     the      numbering      should      start      at      0      (eg.
              DEST_MODULE_LOCATION[0]="/kernel/drivers/something/"
              DEST_MODULE_LOCATION[1]="/kernel/drivers/other/").

              DEST_MODULE_LOCATION is ignored on Fedora Core 6 and  higher,  Red  Hat  Enterprise
              Linux  5 and higher, Novell SuSE Linux Enterprise Server 10 and higher, Novell SuSE
              Linux 10.0 and  higher,  and  Ubuntu.  Instead,  the  proper  distribution-specific
              directory is used.

       MODULES_CONF_ALIAS_TYPE[#]=
              This   directive   array   specifies   how   your  modules  should  be  aliased  in
              /etc/modules.conf when your module is installed.  This is done  in  an  intelligent
              fashion  so if DKMS detects an already existing reference in modules.conf, it won't
              add a new line.  If it is not detected, it will add it to the modules.conf  as  the
              last      alias      number      for      that      alias      type     (eg.     if
              MODULES_CONF_ALIAS_TYPE="scsi_hostadapter", no  alias  currently  exists  for  that
              module and the last scsi_hostadapter reference is 6, then your module will be added
              as   "scsi_hostadapter7").    Common   values   for   this    directive    include:
              scsi_hostadapter  ,  sound-slot- and eth.  Note that the numeric value of # is tied
              to the index  of  BUILD_MODULE_NAME,  BUILT_MODULE_LOCATION,  DEST_MODULE_NAME  and
              DEST_MODULE_LOCATION.  The index is also tied to MODULES_CONF_OBSOLETES.

       MODULES_CONF_OBSOLETES[#]=
              This directive array tells DKMS what modules.conf alias references are obsoleted by
              the module you are installing.  If your module obsoletes more than one module, this
              directive should be a comma-delimited list of those modules that are obsoleted (eg.
              for megaraid2, MODULES_CONF_OBSOLETES[0]="megaraid,megaraid_2002").  When  you  are
              installing your module, DKMS ensures that any entries in /etc/modules.conf with the
              same MODULES_CONF_ALIAS_TYPE are changed over to the new module name.  When you are
              uninstalling  your module, depending on the modules in your /lib/modules tree, DKMS
              will  take  different  actions.   If  you  kernel  has  an  original_module,   then
              modules.conf  will  not  be touched and the non-obsolete reference will remain.  If
              the kernel does not have an original_module but  does  have  one  of  the  obsolete
              modules,  it  will  replace those references with the first obsolete module name in
              the comma-delimited list that is also in that  kernel  (thus,  your  obsolete  list
              should  be  prioritized  from  left  to  right).  If no original_module or obsolete
              modules are found within the kernel, the alias entry is removed all-together.  Note
              that   the  numeric  value  of  #  is  tied  to  the  index  of  BUILD_MODULE_NAME,
              BUILT_MODULE_LOCATION, DEST_MODULE_NAME and  DEST_MODULE_LOCATION.   The  index  is
              also tied to MODULES_CONF_ALIAS_TYPE.

       MODULES_CONF_OBSOLETE_ONLY[#]=
              If  set  to yes , this directive will tell DKMS to only modify /etc/modules.conf if
              it finds within it an obsolete reference as specified in the corresponding value of
              MODULES_CONF_OBSOLETES[#] array directive.

       STRIP[#]=
              By  default  strip  is  considered  to be "yes".  If set to "no", DKMS will not run
              strip -g against your built module to remove debug symbols from  it.   STRIP[0]  is
              used as the default for any unset entries in the STRIP array.

       PACKAGE_NAME=
              This  directive  is  used  to  give  the name associated with the entire package of
              modules.  This is the same name that is used with  the  -m  option  when  building,
              adding,  etc.  and  may  not  necessarily  be  the  same  as the MODULE_NAME.  This
              directive must be present in every dkms.conf.

       PACKAGE_VERSION=
              This directive is used to give the version associated with the  entire  package  of
              modules  being  installed within that dkms package.  This directive must be present
              in every dkms.conf.

       CLEAN= CLEAN specifies the make clean command to be used to clean up both before and after
              building the module.  If unset, it is assumed to be "make clean".

       REMAKE_INITRD=
              This  directive  specifies whether your initrd should be remade after the module is
              installed onto the kernel.  Any text after the first character is  ignored  and  if
              the first character is not a "y" or a "Y", it is assumed that REMAKE_INITRD="no".

       UDEV_TRIGGER=
              This  optional  directive specifies, if the udev daemon will be get a trigger event
              after the module is installed for your currently running kernel. Because this  udev
              trigger  might have some unfriendly side effects on some Linux Systems, you can now
              disable this trigger, if your driver does not need it anyway.  UDEV_TRIGGER=yes  is
              assumed  as  the  default,  although  this directive may not be given. This ensures
              backward compatibility to older DKMS releases. Any text after the  first  character
              is  ignored  and  if  the first character is not a "n" or a "N", it is assumed that
              UDEV_TRIGGER="yes".

       MODULES_CONF[#]=
              This directive array specifies what static configuration  text  lines  need  to  be
              added  into  /etc/modules.conf  for  your  module.  See the section on MODULES.CONF
              CHANGES  for   more   information   regarding   the   implications   of   modifying
              /etc/modules.conf

       OBSOLETE_BY=
              This  directive allows you to specify a kernel version that obsoletes the necessity
              for this particular DKMS module.  This can be specified as  a  particular  upstream
              kernel  or  an  ABI  bump  of a kernel.  For example, "2.6.24" would be an upstream
              kernel and "2.6.24-16" would represent an ABI bump for a kernel.  Both are valid in
              this area.

              Please  avoid  the use of OBSOLETE_BY wherever possible.  It's use indicates a lack
              of proper module versioning  using  MODULE_VERSION()  tags  in  the  module  source
              itself.   It is better to fix the MODULE_VERSION() tags than use OBSOLETE_BY.  This
              also introduces a implicit distribution/version dependency on the package,  as  the
              value   of   OBSOLETE_BY   is   meaningful   only   in  the  context  of  a  single
              distribution/version.

              If you feel you must use it, please use as such in dkms.conf:

               ubuntu_804="Ubuntu
               8.04"
               if [ -x /usr/bin/lsb_release ]; then
                 if [ "$(/usr/bin/lsb_release -sir)" == "${ubuntu_804}" ]; then
                   OBSOLETE_BY="2.6.25"
                 fi
               fi

       PATCH[#]=
              Use the PATCH directive array to specify patches which should be  applied  to  your
              source before a build occurs.  All patches are expected to be in -p1 format and are
              applied with the patch -p1 command.  Each directive should specify the filename  of
              the  patch to apply, and all patches must be located in the patches subdirectory of
              your source directory  (  /usr/src/<module>-<module-version>/patches/  ).   If  any
              patch  fails to apply, the build will be halted and the rejections can be inspected
              in /var/lib/dkms/<module>/<module-version>/build/.   If  a  PATCH  should  only  be
              applied conditionally, the PATCH_MATCH[#] array should be used, and a corresponding
              regular expression should be placed in PATCH_MATCH[#] which will alert dkms to only
              use  that PATCH[#] if the regular expression matches the kernel which the module is
              currently being built for.

       PATCH_MATCH[#]=
              See the above description for PATCH[#] directives. If you only want a patch applied
              in  certain scenarios, the PATCH_MATCH array should be utilized by giving a regular
              expression which matches the kernels you intend the corresponding  PATCH[#]  to  be
              applied to before building that module.

       AUTOINSTALL=
              If     this     directive     is     set     to     yes     then     the    service
              /etc/rc.d/init.d/dkms_autoinstaller will automatically try to install  this  module
              on  any  kernel  you  boot  into.   See  the section on dkms_autoinstaller for more
              information.

       BUILD_DEPENDS[#]=
              This optional directive is an array that allows you to  specify  other  modules  as
              dependencies  for  your  module.  Each  array element should be the PACKAGE_NAME of
              another module that is managed by dkms. Do not specify a version or architecture in
              the  dependency.  Note  that  this  directive  is  only advisory; missing or broken
              dependencies cause non-fatal warnings.

       BUILD_EXCLUSIVE_KERNEL=
              This optional directive allows you to specify a regular  expression  which  defines
              the  subset  of  kernels  which  DKMS  is allowed to build your module for.  If the
              kernel being built for does not match against this  regular  expression,  the  dkms
              build  will  error out.  For example, if you set it as ="^2.4.*", your module would
              not be built for 2.6 kernels.

       BUILD_EXCLUSIVE_ARCH=
              This optional directive functions very similarly to  BUILD_EXCLUSIVE_KERNEL  except
              that  it  matches  against  the kernel architecture.  For example, if you set it to
              ="i.86", your module would not be built for ia32e, x86_64, amd64, s390, etc.

       POST_ADD=
              The name of the script to be run after an add is performed.   The  path  should  be
              given relative to the root directory of your source.

       POST_BUILD=
              The  name  of  the  script to be run after a build is performed. The path should be
              given relative to the root directory of your source.

       POST_INSTALL=
              The name of the script to be run after an install is performed. The path should  be
              given relative to the root directory of your source.

       POST_REMOVE=
              The  name  of  the script to be run after a remove is performed. The path should be
              given relative to the root directory of your source.

       PRE_BUILD=
              The name of the script to be run before a build is performed. The  path  should  be
              given relative to the root directory of your source.

       PRE_INSTALL=
              The name of the script to be run before an install is performed. The path should be
              given relative to the root directory of your source.  If the script  exits  with  a
              non-zero  value,  the install will be aborted.  This is typically used to perform a
              custom version comparison.

       DKMS.CONF VARIABLES
              Within your dkms.conf file, you can use certain variables which will be replaced at
              run-time with their values.

       $kernelver
              This  variable can be used within a directive definition and during use, the actual
              kernel version in question will be substituted in its place.   This  is  especially
              useful  in  MAKE  commands  when specifying which INCLUDE statements should be used
              when       compiling       your       module       (eg.       MAKE="make        all
              INCLUDEDIR=/lib/modules/${kernelver}/build/include").

       $dkms_tree
              See  the  section  on /etc/dkms/framework.conf for more information.  This variable
              represents the location of the DKMS tree on the local system.  By default  this  is
              /var/lib/dkms  ,  but  this  value should not be hard-coded into a dkms.conf in the
              event that the local user has changed it on their system.

       $source_tree
              See the section on /etc/dkms/framework.conf for more  information.   This  variable
              represents  the  location  where DKMS keeps source on the local system.  By default
              this is /usr/src , but this value should not be hard-coded into a dkms.conf in  the
              event that the local user has changed it on their system.

       $kernel_source_dir
              This  variable  holds  the  value  of the location of your kernel source directory.
              Usually, this will be /lib/modules/$kernelver/build ,  unless  otherwise  specified
              with the --kernelsourcedir option.

DKMS.CONF OVERRIDES

       You  can  override the module-provided dkms.conf files. Every time after a  dkms.conf file
       is read, dkms will look for and read the following files in order:

       /etc/dkms/<module>.conf
       /etc/dkms/<module>-<module-version>.conf
       /etc/dkms/<module>-<module-version>-<kernel>.conf
       /etc/dkms/<module>-<module-version>-<kernel>-<arch>.conf

       You can use these files to override settings in the module-provided dkms.conf files.

/etc/dkms/framework.conf

       This configuration file controls how the overall DKMS framework handles.  It is sourced in
       every time the dkms command is run.  Mainly it can currently  be  used  to  set  different
       default  values  for  the  variables.   $dkms_tree  , $source_tree and $install_tree which
       control where DKMS looks for its framework.  The $symlink_modules variable controls wheter
       binary modules are copied to /lib/modules or if only symlinks are created there. Note that
       these variables can also be manipulated on the command line with --dkmstree, --sourcetree,
       --installtree and --symlink-modules options.

       The  $autoinstall_all_kernels variable is used by the common postinst for DKMS modules. It
       controls if the build should be done for all installed kernels or only for the current and
       latest installed kernel. It has no command line equivalent.

dkms_autoinstaller

       This  boot-time  service automatically installs any module which has AUTOINSTALL="yes" set
       in its dkms.conf file.  The service works quite simply  and  if  multiple  versions  of  a
       module  are  in  your system's DKMS tree, it will not do anything and instead explain that
       manual intervention is required.

MODULES.CONF / MODPROBE.CONF CHANGES

       Changes that your module will make to /etc/modules.conf or  /etc/modprobe.conf  should  be
       specified  with  the  MODULES_CONF_ALIAS_TYPE[#]  ,  the MODULES_CONF_OBSOLETES[#] and the
       MODULES_CONF[#] directive arrays.  These arrays should also be used even  if  your  distro
       uses /etc/sysconfig/kernel to track kernel modules.

       When  the  first module is installed upon the first kernel within the user's system, these
       entries  in  MODULES_CONF[#]  are  automatically  added  to   /etc/modules.conf   and   if
       REMAKE_INITRD  is specified, then the user's initrd is then remade.  Subsequently, as your
       modules are then later removed from the user's  system,  until  the  final  module/version
       combination  is  removed  from  the final kernel version, those references in modules.conf
       will remain.  Once the last module/version combination is removed,  those  references  are
       then removed.

       As modules/versions are removed and initrds are remade, one of three things will happen if
       you have specified a MODULES_CONF_ALIAS_TYPE.   If  no  original_module  exists  for  that
       kernel,  and  no  MODULES_CONF_OBSOLETES  modules  are  found  in  that  kernel  too,  the
       modules.conf alias references  will  temporarily  be  removed  so  that  the  initrd  will
       successfully  remake.   Once  the  initrd  is  remade,  however; those references are then
       automatically put back into modules.conf (unless you are removing the last instance of the
       module  on  the  last  kernel).   However,  if  no original_module exists, but there is an
       OBSOLETE module found within that kernel, the alias reference is  temporarily  shifted  to
       point  to  the  OBSOLETE  module so that the initrd can be remade.  After it is remade, it
       then automatically puts back the  alias  reference  (unless  you  are  removing  the  last
       instance  of the module on the last kernel).  Lastly, if an original_module does exist for
       the kernel version, then modules.conf is not touched and all references persist  (even  if
       you are removing the last instance of the module on the last kernel).

       Certain  module installations might not only require adding references to modules.conf but
       also require removing conflicting references that might exist in the  user's  system.   If
       this  is  the  case,  the MODULES_CONF_OBSOLETES[#] directive should be utilized to remove
       these references.  More information about this directive can be  found  in  the  DKMS.CONF
       section of this man page.

       Note that the end state of your modules.conf file very much depends on what kernel modules
       exist in the final kernel you remove your DKMS module from.  This is an  imperfect  system
       caused  by  the  fact  that  there  is only one modules.conf file for every kernel on your
       system even though various kernels use different modules.  In a perfect world, there would
       be one modules.conf file for every kernel (just like System.map).

CREATING RPMS WHICH UTILIZE DKMS

       See  the  sample.spec  file  packaged  with DKMS as an example for what your RPM spec file
       might look like.  Creating RPMs which utilize dkms is a fairly  straight-forward  process.
       The  RPM need only to install the source into /usr/src/<module>-<module-version>/ and then
       employ dkms itself to do all the work of installation.  As  such,  the  RPM  should  first
       untar  the  source  into this directory.  From here, within the RPM .spec file, a dkms add
       should be called (remember to use the --rpm_safe_upgrade flag during the add) followed  by
       a  dkms build followed by a dkms install.  Your dkms.conf file should be placed within the
       /usr/src/<module>-<module-version>/ directory.

       Under the removal parts of the .spec file, all that needs to be called is a:  dkms  remove
       -m  <module>  -v <module-version> --all --rpm_safe_upgrade.  Use of the --rpm_safe_upgrade
       flag is imperative for making sure DKMS and RPM play nicely together in all  scenarios  of
       using  the  -Uvh flag with RPM to upgrade dkms enabled packages.  It will only function if
       used during both the add and remove actions within the same RPM spec file. Its  use  makes
       sure   that   when   upgrading   between  different  releases  of  an  RPM  for  the  same
       <module-version>, DKMS does not do anything dumb (eg. it ensures  a  smooth  upgrade  from
       megaraid-2.09-5.noarch.rpm to megaraid-2.09-6.noarch.rpm).

       It  should be noted that a binary RPM which contains source is not a traditional practice.
       However, given the benefits of dkms it hopefully will become so.  As the RPM created which
       utilizes  dkms  is not architecture specific, BuildArch: noarch should be specified in the
       .spec file to indicate that the package can work regardless of  the  system  architecture.
       Also  note  that  DKMS  RPM  upgrades  (-U  option) will automatically work because of the
       structure of the dkms tree.

       Lastly,    as    a    matter    of    convention,    you    should    name    your    RPM:
       <package>-<version>-<rpm-version>dkms.noarch.rpm.    The   word   dkms   as  part  of  the
       rpm-version signifies that the RPM works within the DKMS framework.

AUTHOR

       Gary Lerhaupt

WEBPAGE

       https://github.com/dell-oss/dkms

WHITE-PAPERS

       http://linux.dell.com/dkms/dkms-ols2004.pdf

       http://www.dell.com/downloads/global/power/1q04-ler.pdf

       http://www.linuxjournal.com/article.php?sid=6896

MAILING-LIST

       dkms-devel@dell.com http://lists.us.dell.com/mailman/listinfo/dkms-devel

REFERENCES

       Kernel Module Packages http://kerneldrivers.org

       Novell Kernel Module Packages http://www.suse.de/~agruen/KMPM

       Fedora Kernel Module Packages http://fedoraproject.org/wiki/Extras/KernelModuleProposal