/* AES-specific context */
        int keylen;
        u8 key[AES_KEYSIZE_128];
-       struct crypto_sync_skcipher *fallback;
+       struct crypto_skcipher *fallback;
 };
 
 struct sahara_aes_reqctx {
        unsigned long mode;
+       struct skcipher_request fallback_req;   // keep at the end
 };
 
 /*
        /*
         * The requested key size is not supported by HW, do a fallback.
         */
-       crypto_sync_skcipher_clear_flags(ctx->fallback, CRYPTO_TFM_REQ_MASK);
-       crypto_sync_skcipher_set_flags(ctx->fallback, tfm->base.crt_flags &
+       crypto_skcipher_clear_flags(ctx->fallback, CRYPTO_TFM_REQ_MASK);
+       crypto_skcipher_set_flags(ctx->fallback, tfm->base.crt_flags &
                                                 CRYPTO_TFM_REQ_MASK);
-       return crypto_sync_skcipher_setkey(ctx->fallback, key, keylen);
+       return crypto_skcipher_setkey(ctx->fallback, key, keylen);
 }
 
 static int sahara_aes_crypt(struct skcipher_request *req, unsigned long mode)
 
 static int sahara_aes_ecb_encrypt(struct skcipher_request *req)
 {
+       struct sahara_aes_reqctx *rctx = skcipher_request_ctx(req);
        struct sahara_ctx *ctx = crypto_skcipher_ctx(
                crypto_skcipher_reqtfm(req));
-       int err;
 
        if (unlikely(ctx->keylen != AES_KEYSIZE_128)) {
-               SYNC_SKCIPHER_REQUEST_ON_STACK(subreq, ctx->fallback);
-
-               skcipher_request_set_sync_tfm(subreq, ctx->fallback);
-               skcipher_request_set_callback(subreq, req->base.flags,
-                                             NULL, NULL);
-               skcipher_request_set_crypt(subreq, req->src, req->dst,
-                                          req->cryptlen, req->iv);
-               err = crypto_skcipher_encrypt(subreq);
-               skcipher_request_zero(subreq);
-               return err;
+               skcipher_request_set_tfm(&rctx->fallback_req, ctx->fallback);
+               skcipher_request_set_callback(&rctx->fallback_req,
+                                             req->base.flags,
+                                             req->base.complete,
+                                             req->base.data);
+               skcipher_request_set_crypt(&rctx->fallback_req, req->src,
+                                          req->dst, req->cryptlen, req->iv);
+               return crypto_skcipher_encrypt(&rctx->fallback_req);
        }
 
        return sahara_aes_crypt(req, FLAGS_ENCRYPT);
 
 static int sahara_aes_ecb_decrypt(struct skcipher_request *req)
 {
+       struct sahara_aes_reqctx *rctx = skcipher_request_ctx(req);
        struct sahara_ctx *ctx = crypto_skcipher_ctx(
                crypto_skcipher_reqtfm(req));
-       int err;
 
        if (unlikely(ctx->keylen != AES_KEYSIZE_128)) {
-               SYNC_SKCIPHER_REQUEST_ON_STACK(subreq, ctx->fallback);
-
-               skcipher_request_set_sync_tfm(subreq, ctx->fallback);
-               skcipher_request_set_callback(subreq, req->base.flags,
-                                             NULL, NULL);
-               skcipher_request_set_crypt(subreq, req->src, req->dst,
-                                          req->cryptlen, req->iv);
-               err = crypto_skcipher_decrypt(subreq);
-               skcipher_request_zero(subreq);
-               return err;
+               skcipher_request_set_tfm(&rctx->fallback_req, ctx->fallback);
+               skcipher_request_set_callback(&rctx->fallback_req,
+                                             req->base.flags,
+                                             req->base.complete,
+                                             req->base.data);
+               skcipher_request_set_crypt(&rctx->fallback_req, req->src,
+                                          req->dst, req->cryptlen, req->iv);
+               return crypto_skcipher_decrypt(&rctx->fallback_req);
        }
 
        return sahara_aes_crypt(req, 0);
 
 static int sahara_aes_cbc_encrypt(struct skcipher_request *req)
 {
+       struct sahara_aes_reqctx *rctx = skcipher_request_ctx(req);
        struct sahara_ctx *ctx = crypto_skcipher_ctx(
                crypto_skcipher_reqtfm(req));
-       int err;
 
        if (unlikely(ctx->keylen != AES_KEYSIZE_128)) {
-               SYNC_SKCIPHER_REQUEST_ON_STACK(subreq, ctx->fallback);
-
-               skcipher_request_set_sync_tfm(subreq, ctx->fallback);
-               skcipher_request_set_callback(subreq, req->base.flags,
-                                             NULL, NULL);
-               skcipher_request_set_crypt(subreq, req->src, req->dst,
-                                          req->cryptlen, req->iv);
-               err = crypto_skcipher_encrypt(subreq);
-               skcipher_request_zero(subreq);
-               return err;
+               skcipher_request_set_tfm(&rctx->fallback_req, ctx->fallback);
+               skcipher_request_set_callback(&rctx->fallback_req,
+                                             req->base.flags,
+                                             req->base.complete,
+                                             req->base.data);
+               skcipher_request_set_crypt(&rctx->fallback_req, req->src,
+                                          req->dst, req->cryptlen, req->iv);
+               return crypto_skcipher_encrypt(&rctx->fallback_req);
        }
 
        return sahara_aes_crypt(req, FLAGS_ENCRYPT | FLAGS_CBC);
 
 static int sahara_aes_cbc_decrypt(struct skcipher_request *req)
 {
+       struct sahara_aes_reqctx *rctx = skcipher_request_ctx(req);
        struct sahara_ctx *ctx = crypto_skcipher_ctx(
                crypto_skcipher_reqtfm(req));
-       int err;
 
        if (unlikely(ctx->keylen != AES_KEYSIZE_128)) {
-               SYNC_SKCIPHER_REQUEST_ON_STACK(subreq, ctx->fallback);
-
-               skcipher_request_set_sync_tfm(subreq, ctx->fallback);
-               skcipher_request_set_callback(subreq, req->base.flags,
-                                             NULL, NULL);
-               skcipher_request_set_crypt(subreq, req->src, req->dst,
-                                          req->cryptlen, req->iv);
-               err = crypto_skcipher_decrypt(subreq);
-               skcipher_request_zero(subreq);
-               return err;
+               skcipher_request_set_tfm(&rctx->fallback_req, ctx->fallback);
+               skcipher_request_set_callback(&rctx->fallback_req,
+                                             req->base.flags,
+                                             req->base.complete,
+                                             req->base.data);
+               skcipher_request_set_crypt(&rctx->fallback_req, req->src,
+                                          req->dst, req->cryptlen, req->iv);
+               return crypto_skcipher_decrypt(&rctx->fallback_req);
        }
 
        return sahara_aes_crypt(req, FLAGS_CBC);
        const char *name = crypto_tfm_alg_name(&tfm->base);
        struct sahara_ctx *ctx = crypto_skcipher_ctx(tfm);
 
-       ctx->fallback = crypto_alloc_sync_skcipher(name, 0,
+       ctx->fallback = crypto_alloc_skcipher(name, 0,
                                              CRYPTO_ALG_NEED_FALLBACK);
        if (IS_ERR(ctx->fallback)) {
                pr_err("Error allocating fallback algo %s\n", name);
                return PTR_ERR(ctx->fallback);
        }
 
-       crypto_skcipher_set_reqsize(tfm, sizeof(struct sahara_aes_reqctx));
+       crypto_skcipher_set_reqsize(tfm, sizeof(struct sahara_aes_reqctx) +
+                                        crypto_skcipher_reqsize(ctx->fallback));
 
        return 0;
 }
 {
        struct sahara_ctx *ctx = crypto_skcipher_ctx(tfm);
 
-       crypto_free_sync_skcipher(ctx->fallback);
+       crypto_free_skcipher(ctx->fallback);
 }
 
 static u32 sahara_sha_init_hdr(struct sahara_dev *dev,