Commit a8fc391a authored by Marcelo Cerri's avatar Marcelo Cerri Committed by Herbert Xu

crypto: nx - add offset to nx_build_sg_lists()

This patch includes one more parameter to nx_build_sg_lists() to skip
the given number of bytes from beginning of each sg list.

This is needed in order to implement the fixes for the AES modes to make
them able to process larger chunks of data.
Reviewed-by: default avatarJoy Latten <jmlatten@linux.vnet.ibm.com>
Signed-off-by: default avatarMarcelo Cerri <mhcerri@linux.vnet.ibm.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent b8b4a416
...@@ -85,7 +85,7 @@ static int cbc_aes_nx_crypt(struct blkcipher_desc *desc, ...@@ -85,7 +85,7 @@ static int cbc_aes_nx_crypt(struct blkcipher_desc *desc,
else else
NX_CPB_FDM(csbcpb) &= ~NX_FDM_ENDE_ENCRYPT; NX_CPB_FDM(csbcpb) &= ~NX_FDM_ENDE_ENCRYPT;
rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, 0,
csbcpb->cpb.aes_cbc.iv); csbcpb->cpb.aes_cbc.iv);
if (rc) if (rc)
goto out; goto out;
......
...@@ -293,7 +293,7 @@ static int ccm_nx_decrypt(struct aead_request *req, ...@@ -293,7 +293,7 @@ static int ccm_nx_decrypt(struct aead_request *req,
if (rc) if (rc)
goto out; goto out;
rc = nx_build_sg_lists(nx_ctx, desc, req->dst, req->src, nbytes, rc = nx_build_sg_lists(nx_ctx, desc, req->dst, req->src, nbytes, 0,
csbcpb->cpb.aes_ccm.iv_or_ctr); csbcpb->cpb.aes_ccm.iv_or_ctr);
if (rc) if (rc)
goto out; goto out;
...@@ -339,7 +339,7 @@ static int ccm_nx_encrypt(struct aead_request *req, ...@@ -339,7 +339,7 @@ static int ccm_nx_encrypt(struct aead_request *req,
if (rc) if (rc)
goto out; goto out;
rc = nx_build_sg_lists(nx_ctx, desc, req->dst, req->src, nbytes, rc = nx_build_sg_lists(nx_ctx, desc, req->dst, req->src, nbytes, 0,
csbcpb->cpb.aes_ccm.iv_or_ctr); csbcpb->cpb.aes_ccm.iv_or_ctr);
if (rc) if (rc)
goto out; goto out;
......
...@@ -98,7 +98,7 @@ static int ctr_aes_nx_crypt(struct blkcipher_desc *desc, ...@@ -98,7 +98,7 @@ static int ctr_aes_nx_crypt(struct blkcipher_desc *desc,
goto out; goto out;
} }
rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, 0,
csbcpb->cpb.aes_ctr.iv); csbcpb->cpb.aes_ctr.iv);
if (rc) if (rc)
goto out; goto out;
......
...@@ -85,7 +85,7 @@ static int ecb_aes_nx_crypt(struct blkcipher_desc *desc, ...@@ -85,7 +85,7 @@ static int ecb_aes_nx_crypt(struct blkcipher_desc *desc,
else else
NX_CPB_FDM(csbcpb) &= ~NX_FDM_ENDE_ENCRYPT; NX_CPB_FDM(csbcpb) &= ~NX_FDM_ENDE_ENCRYPT;
rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, NULL); rc = nx_build_sg_lists(nx_ctx, desc, dst, src, nbytes, 0, NULL);
if (rc) if (rc)
goto out; goto out;
......
...@@ -226,7 +226,7 @@ static int gcm_aes_nx_crypt(struct aead_request *req, int enc) ...@@ -226,7 +226,7 @@ static int gcm_aes_nx_crypt(struct aead_request *req, int enc)
csbcpb->cpb.aes_gcm.bit_length_data = nbytes * 8; csbcpb->cpb.aes_gcm.bit_length_data = nbytes * 8;
rc = nx_build_sg_lists(nx_ctx, &desc, req->dst, req->src, nbytes, rc = nx_build_sg_lists(nx_ctx, &desc, req->dst, req->src, nbytes, 0,
csbcpb->cpb.aes_gcm.iv_or_cnt); csbcpb->cpb.aes_gcm.iv_or_cnt);
if (rc) if (rc)
goto out; goto out;
......
...@@ -211,6 +211,8 @@ struct nx_sg *nx_walk_and_build(struct nx_sg *nx_dst, ...@@ -211,6 +211,8 @@ struct nx_sg *nx_walk_and_build(struct nx_sg *nx_dst,
* @dst: destination scatterlist * @dst: destination scatterlist
* @src: source scatterlist * @src: source scatterlist
* @nbytes: length of data described in the scatterlists * @nbytes: length of data described in the scatterlists
* @offset: number of bytes to fast-forward past at the beginning of
* scatterlists.
* @iv: destination for the iv data, if the algorithm requires it * @iv: destination for the iv data, if the algorithm requires it
* *
* This is common code shared by all the AES algorithms. It uses the block * This is common code shared by all the AES algorithms. It uses the block
...@@ -222,6 +224,7 @@ int nx_build_sg_lists(struct nx_crypto_ctx *nx_ctx, ...@@ -222,6 +224,7 @@ int nx_build_sg_lists(struct nx_crypto_ctx *nx_ctx,
struct scatterlist *dst, struct scatterlist *dst,
struct scatterlist *src, struct scatterlist *src,
unsigned int nbytes, unsigned int nbytes,
unsigned int offset,
u8 *iv) u8 *iv)
{ {
struct nx_sg *nx_insg = nx_ctx->in_sg; struct nx_sg *nx_insg = nx_ctx->in_sg;
...@@ -230,8 +233,10 @@ int nx_build_sg_lists(struct nx_crypto_ctx *nx_ctx, ...@@ -230,8 +233,10 @@ int nx_build_sg_lists(struct nx_crypto_ctx *nx_ctx,
if (iv) if (iv)
memcpy(iv, desc->info, AES_BLOCK_SIZE); memcpy(iv, desc->info, AES_BLOCK_SIZE);
nx_insg = nx_walk_and_build(nx_insg, nx_ctx->ap->sglen, src, 0, nbytes); nx_insg = nx_walk_and_build(nx_insg, nx_ctx->ap->sglen, src,
nx_outsg = nx_walk_and_build(nx_outsg, nx_ctx->ap->sglen, dst, 0, nbytes); offset, nbytes);
nx_outsg = nx_walk_and_build(nx_outsg, nx_ctx->ap->sglen, dst,
offset, nbytes);
/* these lengths should be negative, which will indicate to phyp that /* these lengths should be negative, which will indicate to phyp that
* the input and output parameters are scatterlists, not linear * the input and output parameters are scatterlists, not linear
......
...@@ -156,7 +156,7 @@ int nx_hcall_sync(struct nx_crypto_ctx *ctx, struct vio_pfo_op *op, ...@@ -156,7 +156,7 @@ int nx_hcall_sync(struct nx_crypto_ctx *ctx, struct vio_pfo_op *op,
struct nx_sg *nx_build_sg_list(struct nx_sg *, u8 *, unsigned int, u32); struct nx_sg *nx_build_sg_list(struct nx_sg *, u8 *, unsigned int, u32);
int nx_build_sg_lists(struct nx_crypto_ctx *, struct blkcipher_desc *, int nx_build_sg_lists(struct nx_crypto_ctx *, struct blkcipher_desc *,
struct scatterlist *, struct scatterlist *, unsigned int, struct scatterlist *, struct scatterlist *, unsigned int,
u8 *); unsigned int, u8 *);
struct nx_sg *nx_walk_and_build(struct nx_sg *, unsigned int, struct nx_sg *nx_walk_and_build(struct nx_sg *, unsigned int,
struct scatterlist *, unsigned int, struct scatterlist *, unsigned int,
unsigned int); unsigned int);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment