("VFS to access SMB3 servers e.g. Samba, Macs, Azure and Windows (and "
        "also older servers complying with the SNIA CIFS Specification)");
 MODULE_VERSION(CIFS_VERSION);
-MODULE_SOFTDEP("pre: des");
 MODULE_SOFTDEP("pre: ecb");
 MODULE_SOFTDEP("pre: hmac");
 MODULE_SOFTDEP("pre: md4");
 
 
 */
 
-#include <linux/crypto.h>
 #include <linux/module.h>
 #include <linux/slab.h>
+#include <linux/fips.h>
 #include <linux/fs.h>
 #include <linux/string.h>
 #include <linux/kernel.h>
 #include <linux/random.h>
+#include <crypto/des.h>
 #include "cifs_fs_sb.h"
 #include "cifs_unicode.h"
 #include "cifspdu.h"
 smbhash(unsigned char *out, const unsigned char *in, unsigned char *key)
 {
        unsigned char key2[8];
-       struct crypto_cipher *tfm_des;
+       struct des_ctx ctx;
 
        str_to_key(key, key2);
 
-       tfm_des = crypto_alloc_cipher("des", 0, 0);
-       if (IS_ERR(tfm_des)) {
-               cifs_dbg(VFS, "could not allocate des crypto API\n");
-               return PTR_ERR(tfm_des);
+       if (fips_enabled) {
+               cifs_dbg(VFS, "FIPS compliance enabled: DES not permitted\n");
+               return -ENOENT;
        }
 
-       crypto_cipher_setkey(tfm_des, key2, 8);
-       crypto_cipher_encrypt_one(tfm_des, out, in);
-       crypto_free_cipher(tfm_des);
+       des_expand_key(&ctx, key2, DES_KEY_SIZE);
+       des_encrypt(&ctx, out, in);
+       memzero_explicit(&ctx, sizeof(ctx));
 
        return 0;
 }