cifs.upcall(8) — Linux manual page

NAME | SYNOPSIS | DESCRIPTION | OPTIONS | ENVIRONMENT VARIABLES | CONFIGURATION FOR KEYCTL | SEE ALSO | AUTHOR | COLOPHON

CIFS.UPCALL(8)           System Manager's Manual           CIFS.UPCALL(8)

NAME         top

       cifs.upcall - Userspace upcall helper for Common Internet File
       System (CIFS)

SYNOPSIS         top

          cifs.upcall [--trust-dns|-t] [--version|-v] [--legacy-uid|-l]
                 [--krb5conf=/path/to/krb5.conf|-k /path/to/krb5.conf]
                 [--keytab=/path/to/keytab|-K /path/to/keytab]
                 [--expire|-e nsecs] {keyid}

DESCRIPTION         top

       This tool is part of the cifs-utils suite.

       cifs.upcall is a userspace helper program for the linux CIFS
       client filesystem. There are a number of activities that the
       kernel cannot easily do itself. This program is a callout program
       that does these things for the kernel and then returns the result.

       cifs.upcall is generally intended to be run when the kernel calls
       request-key(8) for a particular key type. While it can be run
       directly from the command-line, it's not generally intended to be
       run that way.

OPTIONS         top

       -c     This option is deprecated and is currently ignored.

       --no-env-probe|-E
              Normally, cifs.upcall will probe the environment variable
              space of the process that initiated the upcall in order to
              fetch the value of $KRB5CCNAME. This can assist the program
              with finding credential caches in non-default locations. If
              this option is set, then the program won't do this and will
              rely on finding credcaches in the default locations
              specified in krb5.conf. Note that this is never performed
              when the uid is 0. The default credcache location is always
              used when the uid is 0, regardless of the environment
              variable setting in the process.

       --krb5conf|-k=/path/to/krb5.conf
              This option allows administrators to set an alternate
              location for the krb5.conf file that cifs.upcall will use.

       --keytab=|-K=/path/to/keytab
              This option allows administrators to specify a keytab file
              to be used. When a user has no credential cache already
              established, cifs.upcall will attempt to use this keytab to
              acquire them. The default is the system-wide keytab
              /etc/krb5.keytab.

       --trust-dns|-t
              With krb5 upcalls, the name used as the host portion of the
              service principal defaults to the hostname portion of the
              UNC. This option allows the upcall program to reverse
              resolve the network address of the server in order to get
              the hostname.

              This is less secure than not trusting DNS. When using this
              option, it's possible that an attacker could get control of
              DNS and trick the client into mounting a different server
              altogether. It's preferable to instead add server
              principals to the KDC for every possible hostname, but this
              option exists for cases where that isn't possible. The
              default is to not trust reverse hostname lookups in this
              fashion.

       --legacy-uid|-l
              Traditionally, the kernel has sent only a single uid=
              parameter to the upcall for the SPNEGO upcall that's used
              to determine what user's credential cache to use.  This
              parameter is affected by the uid= mount option, which also
              governs the ownership of files on the mount.

              Newer kernels send a creduid= option as well, which
              contains what uid it thinks actually owns the credentials
              that it's looking for. At mount time, this is generally set
              to the real uid of the user doing the mount. For
              multisession mounts, it's set to the fsuid of the mount
              user. Set this option if you want cifs.upcall to use the
              older uid= parameter instead of the creduid= parameter.

       --expire|-e
              Override default timeout value (600 seconds) for
              dns_resolver key.

       --version|-v
              Print version number and exit.

ENVIRONMENT VARIABLES         top

       GSS_USE_PROXY="yes"
              Enable usage of gssproxy for credential retrieval. This
              includes keytab based client initiation as well as
              (Resource Based) Constrained Delegation.  See
              gssproxy-mech(8).

CONFIGURATION FOR KEYCTL         top

       cifs.upcall is designed to be called from the kernel via the
       request-key callout program. This requires that request-key be
       told where and how to call this program.  The current cifs.upcall
       program handles two different key types:

       cifs.spnego
              This keytype is for retrieving kerberos session keys

       dns_resolver
              This key type is for resolving hostnames into IP addresses.
              Support for this key type may eventually be deprecated (see
              below).

              To make this program useful for CIFS, you'll need to set up
              entries for them in request-key.conf(5). Here's an example
              of an entry for each key type:

                 #OPERATION  TYPE           D C PROGRAM ARG1 ARG2...
                 #=========  =============  = = ================================
                 create      cifs.spnego    * * /usr/local/sbin/cifs.upcall %k
                 create      dns_resolver   * * /usr/local/sbin/cifs.upcall %k

              See request-key.conf(5) for more info on each field.

              The keyutils package has also started including a
              dns_resolver handling program as well that is preferred
              over the one in cifs.upcall. If you are using a keyutils
              version equal to or greater than 1.5, you should use
              key.dns_resolver to handle the dns_resolver keytype instead
              of cifs.upcall. See key.dns_resolver(8) for more info.

SEE ALSO         top

       request-key.conf(5), mount.cifs(8), key.dns_resolver(8)

AUTHOR         top

       Igor Mammedov wrote the cifs.upcall program.

       Jeff Layton authored this manpage.

       The maintainer of the Linux CIFS VFS is Steve French.

       The Linux CIFS Mailing list is the preferred place to ask
       questions regarding these programs.

COLOPHON         top

       This page is part of the LinuxCIFS utils (network filesystem
       mounts from Linux (e.g. to Samba, ksmbd, etc.)) project.
       Information about the project can be found at 
       ⟨https://wiki.samba.org/index.php/LinuxCIFS_utils⟩.  If you have a
       bug report for this manual page, send it to
       linux-cifs@vger.kernel.org, samba-technical@lists.samba.org.  This
       page was obtained from the project's upstream Git repository
       ⟨git://git.samba.org/cifs-utils.git⟩ on 2025-08-11.  (At that
       time, the date of the most recent commit that was found in the
       repository was 2025-06-10.)  If you discover any rendering
       problems in this HTML version of the page, or you believe there is
       a better or more up-to-date source for the page, or you have
       corrections or improvements to the information in this COLOPHON
       (which is not part of the original manual page), send a mail to
       man-pages@man7.org

                                                           CIFS.UPCALL(8)

Pages that refer to this page: mount.cifs(8)