phpman > man > dkms(8)

Markdown | JSON | MCP    

DKMS(8)                                System Manager's Manual                               DKMS(8)



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 mod‐
           ule/module-version, -m module/module-version, or -m module -v version are passed  as  op‐
           tions,  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 ld‐‐
           tarball 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 ev‐
           ery 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/mod‐
           ule-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.

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

           Undoes the build for 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. Finally all binary kernel modules are  removed.
           Use the --all option in order to remove all instances for every kernel at once.

       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 op‐
           tion 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 be sure that everything is  built
           for your kernel if the RPM installed successfully.

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

           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. Use the  --all  option  in
           order  to  uninstall all instances for every kernel at once.  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 subdi‐
           rectory 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  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

           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 im‐
           age, 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 ar‐
           chive only, or multiple kernels to archive (-k kernel1/arch1 -k kernel2/arch2).   Option‐
           ally,  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  in‐
           clude 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 ldtar‐‐
           ball on all of your other systems to get the same built modules loaded without having  to
           wait for anything to compile.

       ldtarball [/path/to/tarball.tar] [--force]

           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]

           This action allows you to create a debian binary package for a specified  module  /  ver‐
           sion.   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 tar‐
           ball 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.

       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]

           This action allows you to create a debian source package for a specified  module  /  ver‐
           sion.   It  will  create  a .tar.gz, and a .dsc.  All options supported by mkdeb are sup‐
           ported 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.

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

           This action allows you to create an Kernel Module Package source RPM for a specified mod‐
           ule / 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  combi‐
           nation.

       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 want 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  ver‐
              sion/arch pairs on the command line by repeating the -k argument with a different ker‐
              nel 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 architec‐
              tures are specified, there must be a 1:1 relationship between -k arguments to -a argu‐
              ments.   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  divisi‐
              ble 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 tar‐
              ball 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 com‐
              piled 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 mul‐
              tiple 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 au‐
       tomatically  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 re‐
       moved 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 cur‐
       rently 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 con‐
       sists of BUILT_MODULE_NAME[#], BUILT_MODULE_LOCATION[#], DEST_MODULE_NAME[#], DEST_MODULE_LO‐
       CATION[#],    MODULES_CONF_ALIAS_TYPE[#],    MODULES_CONF_OBSOLETES[#],    MODULES_CONF_OBSO‐
       LETE_ONLY[#] and STRIP[#].  The fourth family is made up of only MODULES_CONF[#].   When  in‐
       dexing 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  popu‐
              lated,  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  regu‐
              lar 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 mod‐
              ule 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_MOD‐
              ULE_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  in‐
              stalled.    This  will  rename  the  module  from  BUILT_MODULE_NAME[#]  to  DEST_MOD‐‐
              ULE_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  direc‐
              tive,  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_MOD‐
              ULE_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/some‐
              thing/" DEST_MODULE_LOCATION[1]="/kernel/drivers/other/").

              DEST_MODULE_LOCATION is ignored on Fedora and Red Hat Enterprise  Linux,  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 de‐
              tects 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  ex‐
              ists  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 BUILT_MODULE_NAME, BUILT_MODULE_LOCATION, DEST_MODULE_NAME and  DEST_MOD‐
              ULE_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  in‐
              stalling 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  unin‐
              stalling  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  BUILT_MODULE_NAME,  BUILT_MODULE_LOCATION,  DEST_MODULE_NAME  and DEST_MOD‐
              ULE_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 MOD‐‐
              ULES_CONF_OBSOLETES[#] array directive.

       NO_WEAK_MODULES=
              The NO_WEAK_MODULES parameter prevents dkms from creating a symlink into the  weak-up‐
              dates  directory, which is the default on Red Hat derivatives. The weak modules facil‐
              ity was designed to eliminate the need to rebuild kernel modules when kernel  upgrades
              occur and relies on the symbols within the kABI.

              Fedora does not guaranteed a stable kABI so it should be disabled in the specific mod‐
              ule override by setting it to "yes". For example, for an Nvidia DKMS module you  would
              set the following in /etc/dkms/nvidia.conf:

              NO_WEAK_MODULES="yes"

       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  mod‐
              ules  being installed within that dkms package.  This directive must be present in ev‐
              ery 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 in‐
              stalled 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".

       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 ex‐
              pression 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 depen‐
              dencies for your module. Each array element should be the PACKAGE_NAME of another mod‐
              ule  that  is  managed by dkms. Do not specify a version or architecture in the depen‐
              dency. 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 cus‐
              tom 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 use‐
              ful in MAKE commands when specifying which INCLUDE statements should be used when com‐
              piling  your module (eg. MAKE="make all INCLUDEDIR=/lib/modules/${kernelver}/build/in‐
              clude").

       $dkms_tree
              See the section on /etc/dkms/framework.conf for more information.  This variable  rep‐
              resents  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 rep‐
              resents 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.   Usu‐
              ally, 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, $install_tree
              control where DKMS looks for its framework.

       $symlink_modules
              controls  whether  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.

       $sign_tool
              Script  to  be  run at build for signing modules.  Two arguments will be passed to the
              script. The first argument is the target kernel version , the  second  is  the  module
              file path.  If the script exits with a non-zero value, the build will be aborted.

       $autoinstall_all_kernels
              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 interven‐
       tion is required.

MODULES.CONF / MODPROBE.CONF CHANGES
       Changes that your module will make to /etc/modules.conf or /etc/modprobe.conf should be spec‐
       ified  with  the  MODULES_CONF_ALIAS_TYPE[#]  ,  the  MODULES_CONF_OBSOLETES[#]  and the MOD‐‐
       ULES_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 en‐
       tries 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 origi‐
       nal_module does exist for the kernel version, then modules.conf is not touched and all refer‐
       ences 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 ref‐
       erences.  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 (re‐
       member 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-ver‐
       sion>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/dkms

MAILING-LIST
       dkms-devel AT dell.com http://lists.us.dell.com/mailman/listinfo/dkms-devel



dkms-2.8.7                                 01 October 2021                                   DKMS(8)
dkms(8)
NAME SYNOPSIS DESCRIPTION ACTIONS
autoinstall
OPTIONS
-m / -v -k / -a, --arch -q, --quiet -V, --version -c -d, --distro -r, --release --config --archive --templatekernel --force --binaries-only --source-only --no-prepare-kernel --no-clean-kernel --no-depmod --kernelsourcedir --directive --spec specfile --dkmstree path/to/place --sourcetree path/to/place --installtree path/to/place --legacy-postinst=[0|1] --dkmsframework path/to/file -j number
ORIGINAL MODULES
MAKE[#]= STRIP[#]= PATCH[#]= AUTOINSTALL= DKMS.CONF VARIABLES $kernelver DKMS.CONF OVERRIDES MODULES.CONF / MODPROBE.CONF CHANGES
CREATING RPMS WHICH UTILIZE DKMS AUTHOR WEBPAGE MAILING-LIST

Generated by phpman v3.7.12 Author: Che Dong Under GNU General Public License
2026-06-13 14:48 @216.73.216.28
CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Valid XHTML 1.0 TransitionalValid CSS!

^_back to top