put_unaligned_be32(2, iv + GCM_IV_SIZE);
 
                while (walk.nbytes >= (2 * AES_BLOCK_SIZE)) {
-                       int blocks = walk.nbytes / AES_BLOCK_SIZE;
+                       const int blocks =
+                               walk.nbytes / (2 * AES_BLOCK_SIZE) * 2;
                        u8 *dst = walk.dst.virt.addr;
                        u8 *src = walk.src.virt.addr;
+                       int remaining = blocks;
 
                        do {
                                __aes_arm64_encrypt(ctx->aes_key.key_enc,
 
                                dst += AES_BLOCK_SIZE;
                                src += AES_BLOCK_SIZE;
-                       } while (--blocks > 0);
+                       } while (--remaining > 0);
 
-                       ghash_do_update(walk.nbytes / AES_BLOCK_SIZE, dg,
+                       ghash_do_update(blocks, dg,
                                        walk.dst.virt.addr, &ctx->ghash_key,
                                        NULL, pmull_ghash_update_p64);
 
                put_unaligned_be32(2, iv + GCM_IV_SIZE);
 
                while (walk.nbytes >= (2 * AES_BLOCK_SIZE)) {
-                       int blocks = walk.nbytes / AES_BLOCK_SIZE;
+                       int blocks = walk.nbytes / (2 * AES_BLOCK_SIZE) * 2;
                        u8 *dst = walk.dst.virt.addr;
                        u8 *src = walk.src.virt.addr;