static struct skcipher_alg aesni_skciphers[] = {
        {
                .base = {
-                       .cra_name               = "__ecb(aes)",
-                       .cra_driver_name        = "__ecb-aes-aesni",
+                       .cra_name               = "ecb(aes)",
+                       .cra_driver_name        = "ecb-aes-aesni",
                        .cra_priority           = 400,
-                       .cra_flags              = CRYPTO_ALG_INTERNAL,
                        .cra_blocksize          = AES_BLOCK_SIZE,
                        .cra_ctxsize            = CRYPTO_AES_CTX_SIZE,
                        .cra_module             = THIS_MODULE,
                .decrypt        = ecb_decrypt,
        }, {
                .base = {
-                       .cra_name               = "__cbc(aes)",
-                       .cra_driver_name        = "__cbc-aes-aesni",
+                       .cra_name               = "cbc(aes)",
+                       .cra_driver_name        = "cbc-aes-aesni",
                        .cra_priority           = 400,
-                       .cra_flags              = CRYPTO_ALG_INTERNAL,
                        .cra_blocksize          = AES_BLOCK_SIZE,
                        .cra_ctxsize            = CRYPTO_AES_CTX_SIZE,
                        .cra_module             = THIS_MODULE,
                .decrypt        = cbc_decrypt,
        }, {
                .base = {
-                       .cra_name               = "__cts(cbc(aes))",
-                       .cra_driver_name        = "__cts-cbc-aes-aesni",
+                       .cra_name               = "cts(cbc(aes))",
+                       .cra_driver_name        = "cts-cbc-aes-aesni",
                        .cra_priority           = 400,
-                       .cra_flags              = CRYPTO_ALG_INTERNAL,
                        .cra_blocksize          = AES_BLOCK_SIZE,
                        .cra_ctxsize            = CRYPTO_AES_CTX_SIZE,
                        .cra_module             = THIS_MODULE,
 #ifdef CONFIG_X86_64
        }, {
                .base = {
-                       .cra_name               = "__ctr(aes)",
-                       .cra_driver_name        = "__ctr-aes-aesni",
+                       .cra_name               = "ctr(aes)",
+                       .cra_driver_name        = "ctr-aes-aesni",
                        .cra_priority           = 400,
-                       .cra_flags              = CRYPTO_ALG_INTERNAL,
                        .cra_blocksize          = 1,
                        .cra_ctxsize            = CRYPTO_AES_CTX_SIZE,
                        .cra_module             = THIS_MODULE,
 #endif
        }, {
                .base = {
-                       .cra_name               = "__xts(aes)",
-                       .cra_driver_name        = "__xts-aes-aesni",
+                       .cra_name               = "xts(aes)",
+                       .cra_driver_name        = "xts-aes-aesni",
                        .cra_priority           = 401,
-                       .cra_flags              = CRYPTO_ALG_INTERNAL,
                        .cra_blocksize          = AES_BLOCK_SIZE,
                        .cra_ctxsize            = XTS_AES_CTX_SIZE,
                        .cra_module             = THIS_MODULE,
        }
 };
 
-static
-struct simd_skcipher_alg *aesni_simd_skciphers[ARRAY_SIZE(aesni_skciphers)];
-
 #ifdef CONFIG_X86_64
 asmlinkage void aes_xts_encrypt_iv(const struct crypto_aes_ctx *tweak_key,
                                   u8 iv[AES_BLOCK_SIZE]);
 }                                                                             \
                                                                               \
 static struct skcipher_alg skcipher_algs_##suffix[] = {{                      \
-       .base.cra_name          = "__xts(aes)",                                \
-       .base.cra_driver_name   = "__xts-aes-" driver_name_suffix,             \
+       .base.cra_name          = "xts(aes)",                                  \
+       .base.cra_driver_name   = "xts-aes-" driver_name_suffix,               \
        .base.cra_priority      = priority,                                    \
-       .base.cra_flags         = CRYPTO_ALG_INTERNAL,                         \
        .base.cra_blocksize     = AES_BLOCK_SIZE,                              \
        .base.cra_ctxsize       = XTS_AES_CTX_SIZE,                            \
        .base.cra_module        = THIS_MODULE,                                 \
        .encrypt                = xts_encrypt_##suffix,                        \
        .decrypt                = xts_decrypt_##suffix,                        \
 }, {                                                                          \
-       .base.cra_name          = "__ctr(aes)",                                \
-       .base.cra_driver_name   = "__ctr-aes-" driver_name_suffix,             \
+       .base.cra_name          = "ctr(aes)",                                  \
+       .base.cra_driver_name   = "ctr-aes-" driver_name_suffix,               \
        .base.cra_priority      = priority,                                    \
-       .base.cra_flags         = CRYPTO_ALG_INTERNAL,                         \
        .base.cra_blocksize     = 1,                                           \
        .base.cra_ctxsize       = CRYPTO_AES_CTX_SIZE,                         \
        .base.cra_module        = THIS_MODULE,                                 \
        .encrypt                = ctr_crypt_##suffix,                          \
        .decrypt                = ctr_crypt_##suffix,                          \
 }, {                                                                          \
-       .base.cra_name          = "__xctr(aes)",                               \
-       .base.cra_driver_name   = "__xctr-aes-" driver_name_suffix,            \
+       .base.cra_name          = "xctr(aes)",                                 \
+       .base.cra_driver_name   = "xctr-aes-" driver_name_suffix,              \
        .base.cra_priority      = priority,                                    \
-       .base.cra_flags         = CRYPTO_ALG_INTERNAL,                         \
        .base.cra_blocksize     = 1,                                           \
        .base.cra_ctxsize       = CRYPTO_AES_CTX_SIZE,                         \
        .base.cra_module        = THIS_MODULE,                                 \
        .setkey                 = aesni_skcipher_setkey,                       \
        .encrypt                = xctr_crypt_##suffix,                         \
        .decrypt                = xctr_crypt_##suffix,                         \
-}};                                                                           \
-                                                                              \
-static struct simd_skcipher_alg *                                             \
-simd_skcipher_algs_##suffix[ARRAY_SIZE(skcipher_algs_##suffix)]
+}}
 
 DEFINE_AVX_SKCIPHER_ALGS(aesni_avx, "aesni-avx", 500);
 #if defined(CONFIG_AS_VAES) && defined(CONFIG_AS_VPCLMULQDQ)
        .chunksize              = AES_BLOCK_SIZE,                              \
        .maxauthsize            = 16,                                          \
        .base = {                                                              \
-               .cra_name               = "__gcm(aes)",                        \
-               .cra_driver_name        = "__" generic_driver_name,            \
+               .cra_name               = "gcm(aes)",                          \
+               .cra_driver_name        = generic_driver_name,                 \
                .cra_priority           = (priority),                          \
-               .cra_flags              = CRYPTO_ALG_INTERNAL,                 \
                .cra_blocksize          = 1,                                   \
                .cra_ctxsize            = (ctxsize),                           \
                .cra_module             = THIS_MODULE,                         \
        .chunksize              = AES_BLOCK_SIZE,                              \
        .maxauthsize            = 16,                                          \
        .base = {                                                              \
-               .cra_name               = "__rfc4106(gcm(aes))",               \
-               .cra_driver_name        = "__" rfc_driver_name,                \
+               .cra_name               = "rfc4106(gcm(aes))",                 \
+               .cra_driver_name        = rfc_driver_name,                     \
                .cra_priority           = (priority),                          \
-               .cra_flags              = CRYPTO_ALG_INTERNAL,                 \
                .cra_blocksize          = 1,                                   \
                .cra_ctxsize            = (ctxsize),                           \
                .cra_module             = THIS_MODULE,                         \
        },                                                                     \
-} };                                                                          \
-                                                                              \
-static struct simd_aead_alg *aes_gcm_simdalgs_##suffix[2]                     \
+} }
 
 /* aes_gcm_algs_aesni */
 DEFINE_GCM_ALGS(aesni, /* no flags */ 0,
 
        if (!boot_cpu_has(X86_FEATURE_AVX))
                return 0;
-       err = simd_register_skciphers_compat(skcipher_algs_aesni_avx,
-                                            ARRAY_SIZE(skcipher_algs_aesni_avx),
-                                            simd_skcipher_algs_aesni_avx);
+       err = crypto_register_skciphers(skcipher_algs_aesni_avx,
+                                       ARRAY_SIZE(skcipher_algs_aesni_avx));
        if (err)
                return err;
-       err = simd_register_aeads_compat(aes_gcm_algs_aesni_avx,
-                                        ARRAY_SIZE(aes_gcm_algs_aesni_avx),
-                                        aes_gcm_simdalgs_aesni_avx);
+       err = crypto_register_aeads(aes_gcm_algs_aesni_avx,
+                                   ARRAY_SIZE(aes_gcm_algs_aesni_avx));
        if (err)
                return err;
        /*
            !boot_cpu_has(X86_FEATURE_PCLMULQDQ) ||
            !cpu_has_xfeatures(XFEATURE_MASK_SSE | XFEATURE_MASK_YMM, NULL))
                return 0;
-       err = simd_register_skciphers_compat(skcipher_algs_vaes_avx2,
-                                            ARRAY_SIZE(skcipher_algs_vaes_avx2),
-                                            simd_skcipher_algs_vaes_avx2);
+       err = crypto_register_skciphers(skcipher_algs_vaes_avx2,
+                                       ARRAY_SIZE(skcipher_algs_vaes_avx2));
        if (err)
                return err;
 
                               XFEATURE_MASK_AVX512, NULL))
                return 0;
 
-       err = simd_register_aeads_compat(aes_gcm_algs_vaes_avx10_256,
-                                        ARRAY_SIZE(aes_gcm_algs_vaes_avx10_256),
-                                        aes_gcm_simdalgs_vaes_avx10_256);
+       err = crypto_register_aeads(aes_gcm_algs_vaes_avx10_256,
+                                   ARRAY_SIZE(aes_gcm_algs_vaes_avx10_256));
        if (err)
                return err;
 
                        aes_gcm_algs_vaes_avx10_512[i].base.cra_priority = 1;
        }
 
-       err = simd_register_skciphers_compat(skcipher_algs_vaes_avx512,
-                                            ARRAY_SIZE(skcipher_algs_vaes_avx512),
-                                            simd_skcipher_algs_vaes_avx512);
+       err = crypto_register_skciphers(skcipher_algs_vaes_avx512,
+                                       ARRAY_SIZE(skcipher_algs_vaes_avx512));
        if (err)
                return err;
-       err = simd_register_aeads_compat(aes_gcm_algs_vaes_avx10_512,
-                                        ARRAY_SIZE(aes_gcm_algs_vaes_avx10_512),
-                                        aes_gcm_simdalgs_vaes_avx10_512);
+       err = crypto_register_aeads(aes_gcm_algs_vaes_avx10_512,
+                                   ARRAY_SIZE(aes_gcm_algs_vaes_avx10_512));
        if (err)
                return err;
 #endif /* CONFIG_AS_VAES && CONFIG_AS_VPCLMULQDQ */
        return 0;
 }
 
+#define unregister_skciphers(A) \
+       if (refcount_read(&(A)[0].base.cra_refcnt) != 0) \
+               crypto_unregister_skciphers((A), ARRAY_SIZE(A))
+#define unregister_aeads(A) \
+       if (refcount_read(&(A)[0].base.cra_refcnt) != 0) \
+               crypto_unregister_aeads((A), ARRAY_SIZE(A))
+
 static void unregister_avx_algs(void)
 {
-       if (simd_skcipher_algs_aesni_avx[0])
-               simd_unregister_skciphers(skcipher_algs_aesni_avx,
-                                         ARRAY_SIZE(skcipher_algs_aesni_avx),
-                                         simd_skcipher_algs_aesni_avx);
-       if (aes_gcm_simdalgs_aesni_avx[0])
-               simd_unregister_aeads(aes_gcm_algs_aesni_avx,
-                                     ARRAY_SIZE(aes_gcm_algs_aesni_avx),
-                                     aes_gcm_simdalgs_aesni_avx);
+       unregister_skciphers(skcipher_algs_aesni_avx);
+       unregister_aeads(aes_gcm_algs_aesni_avx);
 #if defined(CONFIG_AS_VAES) && defined(CONFIG_AS_VPCLMULQDQ)
-       if (simd_skcipher_algs_vaes_avx2[0])
-               simd_unregister_skciphers(skcipher_algs_vaes_avx2,
-                                         ARRAY_SIZE(skcipher_algs_vaes_avx2),
-                                         simd_skcipher_algs_vaes_avx2);
-       if (aes_gcm_simdalgs_vaes_avx10_256[0])
-               simd_unregister_aeads(aes_gcm_algs_vaes_avx10_256,
-                                     ARRAY_SIZE(aes_gcm_algs_vaes_avx10_256),
-                                     aes_gcm_simdalgs_vaes_avx10_256);
-       if (simd_skcipher_algs_vaes_avx512[0])
-               simd_unregister_skciphers(skcipher_algs_vaes_avx512,
-                                         ARRAY_SIZE(skcipher_algs_vaes_avx512),
-                                         simd_skcipher_algs_vaes_avx512);
-       if (aes_gcm_simdalgs_vaes_avx10_512[0])
-               simd_unregister_aeads(aes_gcm_algs_vaes_avx10_512,
-                                     ARRAY_SIZE(aes_gcm_algs_vaes_avx10_512),
-                                     aes_gcm_simdalgs_vaes_avx10_512);
+       unregister_skciphers(skcipher_algs_vaes_avx2);
+       unregister_skciphers(skcipher_algs_vaes_avx512);
+       unregister_aeads(aes_gcm_algs_vaes_avx10_256);
+       unregister_aeads(aes_gcm_algs_vaes_avx10_512);
 #endif
 }
 #else /* CONFIG_X86_64 */
 static struct aead_alg aes_gcm_algs_aesni[0];
-static struct simd_aead_alg *aes_gcm_simdalgs_aesni[0];
 
 static int __init register_avx_algs(void)
 {
        if (err)
                return err;
 
-       err = simd_register_skciphers_compat(aesni_skciphers,
-                                            ARRAY_SIZE(aesni_skciphers),
-                                            aesni_simd_skciphers);
+       err = crypto_register_skciphers(aesni_skciphers,
+                                       ARRAY_SIZE(aesni_skciphers));
        if (err)
                goto unregister_cipher;
 
-       err = simd_register_aeads_compat(aes_gcm_algs_aesni,
-                                        ARRAY_SIZE(aes_gcm_algs_aesni),
-                                        aes_gcm_simdalgs_aesni);
+       err = crypto_register_aeads(aes_gcm_algs_aesni,
+                                   ARRAY_SIZE(aes_gcm_algs_aesni));
        if (err)
                goto unregister_skciphers;
 
 
 unregister_avx:
        unregister_avx_algs();
-       simd_unregister_aeads(aes_gcm_algs_aesni,
-                             ARRAY_SIZE(aes_gcm_algs_aesni),
-                             aes_gcm_simdalgs_aesni);
+       crypto_unregister_aeads(aes_gcm_algs_aesni,
+                               ARRAY_SIZE(aes_gcm_algs_aesni));
 unregister_skciphers:
-       simd_unregister_skciphers(aesni_skciphers, ARRAY_SIZE(aesni_skciphers),
-                                 aesni_simd_skciphers);
+       crypto_unregister_skciphers(aesni_skciphers,
+                                   ARRAY_SIZE(aesni_skciphers));
 unregister_cipher:
        crypto_unregister_alg(&aesni_cipher_alg);
        return err;
 
 static void __exit aesni_exit(void)
 {
-       simd_unregister_aeads(aes_gcm_algs_aesni,
-                             ARRAY_SIZE(aes_gcm_algs_aesni),
-                             aes_gcm_simdalgs_aesni);
-       simd_unregister_skciphers(aesni_skciphers, ARRAY_SIZE(aesni_skciphers),
-                                 aesni_simd_skciphers);
+       crypto_unregister_aeads(aes_gcm_algs_aesni,
+                               ARRAY_SIZE(aes_gcm_algs_aesni));
+       crypto_unregister_skciphers(aesni_skciphers,
+                                   ARRAY_SIZE(aesni_skciphers));
        crypto_unregister_alg(&aesni_cipher_alg);
        unregister_avx_algs();
 }