*sg = NULL;
 }
 
-static void s5p_sg_copy_buf(void *buf, struct scatterlist *sg,
-                           unsigned int nbytes, int out)
-{
-       struct scatter_walk walk;
-
-       if (!nbytes)
-               return;
-
-       scatterwalk_start(&walk, sg);
-       scatterwalk_copychunks(buf, &walk, nbytes, out);
-       scatterwalk_done(&walk, out, 0);
-}
-
 static void s5p_sg_done(struct s5p_aes_dev *dev)
 {
        struct skcipher_request *req = dev->req;
                dev_dbg(dev->dev,
                        "Copying %d bytes of output data back to original place\n",
                        dev->req->cryptlen);
-               s5p_sg_copy_buf(sg_virt(dev->sg_dst_cpy), dev->req->dst,
-                               dev->req->cryptlen, 1);
+               memcpy_to_sglist(dev->req->dst, 0, sg_virt(dev->sg_dst_cpy),
+                                dev->req->cryptlen);
        }
        s5p_free_sg_cpy(dev, &dev->sg_src_cpy);
        s5p_free_sg_cpy(dev, &dev->sg_dst_cpy);
                return -ENOMEM;
        }
 
-       s5p_sg_copy_buf(pages, src, dev->req->cryptlen, 0);
+       memcpy_from_sglist(pages, src, 0, dev->req->cryptlen);
 
        sg_init_table(*dst, 1);
        sg_set_buf(*dst, pages, len);
        if (ctx->bufcnt)
                memcpy(buf, ctx->dd->xmit_buf, ctx->bufcnt);
 
-       scatterwalk_map_and_copy(buf + ctx->bufcnt, sg, ctx->skip,
-                                new_len, 0);
+       memcpy_from_sglist(buf + ctx->bufcnt, sg, ctx->skip, new_len);
        sg_init_table(ctx->sgl, 1);
        sg_set_buf(ctx->sgl, buf, len);
        ctx->sg = ctx->sgl;
                if (len > nbytes)
                        len = nbytes;
 
-               scatterwalk_map_and_copy(ctx->buffer + ctx->bufcnt, req->src,
-                                        0, len, 0);
+               memcpy_from_sglist(ctx->buffer + ctx->bufcnt, req->src, 0, len);
                ctx->bufcnt += len;
                nbytes -= len;
                ctx->skip = len;
                hash_later = ctx->total - xmit_len;
                /* copy hash_later bytes from end of req->src */
                /* previous bytes are in xmit_buf, so no overwrite */
-               scatterwalk_map_and_copy(ctx->buffer, req->src,
-                                        req->nbytes - hash_later,
-                                        hash_later, 0);
+               memcpy_from_sglist(ctx->buffer, req->src,
+                                  req->nbytes - hash_later, hash_later);
        }
 
        if (xmit_len > BUFLEN) {
                /* have buffered data only */
                if (unlikely(!ctx->bufcnt)) {
                        /* first update didn't fill up buffer */
-                       scatterwalk_map_and_copy(ctx->dd->xmit_buf, req->src,
-                                                0, xmit_len, 0);
+                       memcpy_from_sglist(ctx->dd->xmit_buf, req->src,
+                                          0, xmit_len);
                }
 
                sg_init_table(ctx->sgl, 1);
                return 0;
 
        if (ctx->bufcnt + req->nbytes <= BUFLEN) {
-               scatterwalk_map_and_copy(ctx->buffer + ctx->bufcnt, req->src,
-                                        0, req->nbytes, 0);
+               memcpy_from_sglist(ctx->buffer + ctx->bufcnt, req->src,
+                                  0, req->nbytes);
                ctx->bufcnt += req->nbytes;
                return 0;
        }