mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
crypto: caam - print debug messages at debug level
The CAAM driver used to put its debug messages inside #ifdef DEBUG and then prints the messages at KERN_ERR level. Replace this with proper functions printing at KERN_DEBUG level. The #ifdef DEBUG gets unnecessary when the right functions are used. This replaces: - print_hex_dump(KERN_ERR ...) inside #ifdef DEBUG with print_hex_dump_debug(...) - dev_err() inside #ifdef DEBUG with dev_dbg() - printk(KERN_ERR ...) inside #ifdef DEBUG with dev_dbg() Some parts of the driver use these functions already, so it is only consequent to use the debug function consistently. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
32f75e67f3
commit
6e00550319
@ -576,13 +576,11 @@ static int aead_setkey(struct crypto_aead *aead,
|
|||||||
if (crypto_authenc_extractkeys(&keys, key, keylen) != 0)
|
if (crypto_authenc_extractkeys(&keys, key, keylen) != 0)
|
||||||
goto badkey;
|
goto badkey;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "keylen %d enckeylen %d authkeylen %d\n",
|
||||||
printk(KERN_ERR "keylen %d enckeylen %d authkeylen %d\n",
|
|
||||||
keys.authkeylen + keys.enckeylen, keys.enckeylen,
|
keys.authkeylen + keys.enckeylen, keys.enckeylen,
|
||||||
keys.authkeylen);
|
keys.authkeylen);
|
||||||
print_hex_dump(KERN_ERR, "key in @"__stringify(__LINE__)": ",
|
print_hex_dump_debug("key in @"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If DKP is supported, use it in the shared descriptor to generate
|
* If DKP is supported, use it in the shared descriptor to generate
|
||||||
@ -616,11 +614,10 @@ static int aead_setkey(struct crypto_aead *aead,
|
|||||||
memcpy(ctx->key + ctx->adata.keylen_pad, keys.enckey, keys.enckeylen);
|
memcpy(ctx->key + ctx->adata.keylen_pad, keys.enckey, keys.enckeylen);
|
||||||
dma_sync_single_for_device(jrdev, ctx->key_dma, ctx->adata.keylen_pad +
|
dma_sync_single_for_device(jrdev, ctx->key_dma, ctx->adata.keylen_pad +
|
||||||
keys.enckeylen, ctx->dir);
|
keys.enckeylen, ctx->dir);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "ctx.key@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("ctx.key@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, ctx->key,
|
DUMP_PREFIX_ADDRESS, 16, 4, ctx->key,
|
||||||
ctx->adata.keylen_pad + keys.enckeylen, 1);
|
ctx->adata.keylen_pad + keys.enckeylen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
skip_split_key:
|
skip_split_key:
|
||||||
ctx->cdata.keylen = keys.enckeylen;
|
ctx->cdata.keylen = keys.enckeylen;
|
||||||
@ -671,10 +668,8 @@ static int gcm_setkey(struct crypto_aead *aead,
|
|||||||
struct caam_ctx *ctx = crypto_aead_ctx(aead);
|
struct caam_ctx *ctx = crypto_aead_ctx(aead);
|
||||||
struct device *jrdev = ctx->jrdev;
|
struct device *jrdev = ctx->jrdev;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
dma_sync_single_for_device(jrdev, ctx->key_dma, keylen, ctx->dir);
|
dma_sync_single_for_device(jrdev, ctx->key_dma, keylen, ctx->dir);
|
||||||
@ -692,10 +687,8 @@ static int rfc4106_setkey(struct crypto_aead *aead,
|
|||||||
if (keylen < 4)
|
if (keylen < 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
|
|
||||||
@ -718,10 +711,8 @@ static int rfc4543_setkey(struct crypto_aead *aead,
|
|||||||
if (keylen < 4)
|
if (keylen < 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
|
|
||||||
@ -750,10 +741,8 @@ static int skcipher_setkey(struct crypto_skcipher *skcipher, const u8 *key,
|
|||||||
OP_ALG_AAI_CTR_MOD128);
|
OP_ALG_AAI_CTR_MOD128);
|
||||||
const bool is_rfc3686 = alg->caam.rfc3686;
|
const bool is_rfc3686 = alg->caam.rfc3686;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
/*
|
/*
|
||||||
* AES-CTR needs to load IV in CONTEXT1 reg
|
* AES-CTR needs to load IV in CONTEXT1 reg
|
||||||
* at an offset of 128bits (16bytes)
|
* at an offset of 128bits (16bytes)
|
||||||
@ -942,9 +931,7 @@ static void aead_encrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct aead_request *req = context;
|
struct aead_request *req = context;
|
||||||
struct aead_edesc *edesc;
|
struct aead_edesc *edesc;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct aead_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct aead_edesc, hw_desc[0]);
|
||||||
|
|
||||||
@ -964,9 +951,7 @@ static void aead_decrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct aead_request *req = context;
|
struct aead_request *req = context;
|
||||||
struct aead_edesc *edesc;
|
struct aead_edesc *edesc;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct aead_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct aead_edesc, hw_desc[0]);
|
||||||
|
|
||||||
@ -994,9 +979,7 @@ static void skcipher_encrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
||||||
int ivsize = crypto_skcipher_ivsize(skcipher);
|
int ivsize = crypto_skcipher_ivsize(skcipher);
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct skcipher_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct skcipher_edesc, hw_desc[0]);
|
||||||
|
|
||||||
@ -1013,12 +996,11 @@ static void skcipher_encrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
scatterwalk_map_and_copy(req->iv, req->dst, req->cryptlen -
|
scatterwalk_map_and_copy(req->iv, req->dst, req->cryptlen -
|
||||||
ivsize, ivsize, 0);
|
ivsize, ivsize, 0);
|
||||||
|
|
||||||
#ifdef DEBUG
|
|
||||||
if (ivsize)
|
if (ivsize)
|
||||||
print_hex_dump(KERN_ERR, "dstiv @"__stringify(__LINE__)": ",
|
print_hex_dump_debug("dstiv @"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->iv,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->iv,
|
||||||
edesc->src_nents > 1 ? 100 : ivsize, 1);
|
edesc->src_nents > 1 ? 100 : ivsize, 1);
|
||||||
#endif
|
|
||||||
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
||||||
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
||||||
@ -1033,12 +1015,10 @@ static void skcipher_decrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
{
|
{
|
||||||
struct skcipher_request *req = context;
|
struct skcipher_request *req = context;
|
||||||
struct skcipher_edesc *edesc;
|
struct skcipher_edesc *edesc;
|
||||||
#ifdef DEBUG
|
|
||||||
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
||||||
int ivsize = crypto_skcipher_ivsize(skcipher);
|
int ivsize = crypto_skcipher_ivsize(skcipher);
|
||||||
|
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct skcipher_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct skcipher_edesc, hw_desc[0]);
|
||||||
if (err)
|
if (err)
|
||||||
@ -1046,10 +1026,8 @@ static void skcipher_decrypt_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
|
|
||||||
skcipher_unmap(jrdev, edesc, req);
|
skcipher_unmap(jrdev, edesc, req);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("dstiv @"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "dstiv @"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, req->iv, ivsize, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->iv, ivsize, 1);
|
|
||||||
#endif
|
|
||||||
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
||||||
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
||||||
@ -1245,6 +1223,7 @@ static void init_skcipher_job(struct skcipher_request *req,
|
|||||||
{
|
{
|
||||||
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
|
||||||
struct caam_ctx *ctx = crypto_skcipher_ctx(skcipher);
|
struct caam_ctx *ctx = crypto_skcipher_ctx(skcipher);
|
||||||
|
struct device *jrdev = ctx->jrdev;
|
||||||
int ivsize = crypto_skcipher_ivsize(skcipher);
|
int ivsize = crypto_skcipher_ivsize(skcipher);
|
||||||
u32 *desc = edesc->hw_desc;
|
u32 *desc = edesc->hw_desc;
|
||||||
u32 *sh_desc;
|
u32 *sh_desc;
|
||||||
@ -1252,12 +1231,11 @@ static void init_skcipher_job(struct skcipher_request *req,
|
|||||||
dma_addr_t src_dma, dst_dma, ptr;
|
dma_addr_t src_dma, dst_dma, ptr;
|
||||||
int len, sec4_sg_index = 0;
|
int len, sec4_sg_index = 0;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("presciv@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "presciv@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, req->iv, ivsize, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->iv, ivsize, 1);
|
dev_dbg(jrdev, "asked=%d, cryptlen%d\n",
|
||||||
pr_err("asked=%d, cryptlen%d\n",
|
|
||||||
(int)edesc->src_nents > 1 ? 100 : req->cryptlen, req->cryptlen);
|
(int)edesc->src_nents > 1 ? 100 : req->cryptlen, req->cryptlen);
|
||||||
#endif
|
|
||||||
caam_dump_sg(KERN_ERR, "src @" __stringify(__LINE__)": ",
|
caam_dump_sg(KERN_ERR, "src @" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->src,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->src,
|
||||||
edesc->src_nents > 1 ? 100 : req->cryptlen, 1);
|
edesc->src_nents > 1 ? 100 : req->cryptlen, 1);
|
||||||
@ -1450,11 +1428,10 @@ static int gcm_encrypt(struct aead_request *req)
|
|||||||
|
|
||||||
/* Create and submit job descriptor */
|
/* Create and submit job descriptor */
|
||||||
init_gcm_job(req, edesc, all_contig, true);
|
init_gcm_job(req, edesc, all_contig, true);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "aead jobdesc@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("aead jobdesc@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
ret = caam_jr_enqueue(jrdev, desc, aead_encrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, aead_encrypt_done, req);
|
||||||
@ -1560,11 +1537,10 @@ static int aead_encrypt(struct aead_request *req)
|
|||||||
|
|
||||||
/* Create and submit job descriptor */
|
/* Create and submit job descriptor */
|
||||||
init_authenc_job(req, edesc, all_contig, true);
|
init_authenc_job(req, edesc, all_contig, true);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "aead jobdesc@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("aead jobdesc@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
ret = caam_jr_enqueue(jrdev, desc, aead_encrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, aead_encrypt_done, req);
|
||||||
@ -1595,11 +1571,10 @@ static int gcm_decrypt(struct aead_request *req)
|
|||||||
|
|
||||||
/* Create and submit job descriptor*/
|
/* Create and submit job descriptor*/
|
||||||
init_gcm_job(req, edesc, all_contig, false);
|
init_gcm_job(req, edesc, all_contig, false);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "aead jobdesc@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("aead jobdesc@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
ret = caam_jr_enqueue(jrdev, desc, aead_decrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, aead_decrypt_done, req);
|
||||||
@ -1643,11 +1618,10 @@ static int aead_decrypt(struct aead_request *req)
|
|||||||
|
|
||||||
/* Create and submit job descriptor*/
|
/* Create and submit job descriptor*/
|
||||||
init_authenc_job(req, edesc, all_contig, false);
|
init_authenc_job(req, edesc, all_contig, false);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "aead jobdesc@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("aead jobdesc@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
ret = caam_jr_enqueue(jrdev, desc, aead_decrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, aead_decrypt_done, req);
|
||||||
@ -1804,11 +1778,9 @@ static struct skcipher_edesc *skcipher_edesc_alloc(struct skcipher_request *req,
|
|||||||
|
|
||||||
edesc->iv_dma = iv_dma;
|
edesc->iv_dma = iv_dma;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("skcipher sec4_sg@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "skcipher sec4_sg@" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->sec4_sg,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->sec4_sg,
|
sec4_sg_bytes, 1);
|
||||||
sec4_sg_bytes, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return edesc;
|
return edesc;
|
||||||
}
|
}
|
||||||
@ -1829,11 +1801,11 @@ static int skcipher_encrypt(struct skcipher_request *req)
|
|||||||
|
|
||||||
/* Create and submit job descriptor*/
|
/* Create and submit job descriptor*/
|
||||||
init_skcipher_job(req, edesc, true);
|
init_skcipher_job(req, edesc, true);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "skcipher jobdesc@" __stringify(__LINE__)": ",
|
print_hex_dump_debug("skcipher jobdesc@" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
ret = caam_jr_enqueue(jrdev, desc, skcipher_encrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, skcipher_encrypt_done, req);
|
||||||
|
|
||||||
@ -1873,11 +1845,10 @@ static int skcipher_decrypt(struct skcipher_request *req)
|
|||||||
/* Create and submit job descriptor*/
|
/* Create and submit job descriptor*/
|
||||||
init_skcipher_job(req, edesc, false);
|
init_skcipher_job(req, edesc, false);
|
||||||
desc = edesc->hw_desc;
|
desc = edesc->hw_desc;
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "skcipher jobdesc@" __stringify(__LINE__)": ",
|
print_hex_dump_debug("skcipher jobdesc@" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, edesc->hw_desc,
|
||||||
desc_bytes(edesc->hw_desc), 1);
|
desc_bytes(edesc->hw_desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, skcipher_decrypt_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, skcipher_decrypt_done, req);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
|
@ -115,11 +115,9 @@ void cnstr_shdsc_aead_null_encap(u32 * const desc, struct alginfo *adata,
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("aead null enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"aead null enc shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_aead_null_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_aead_null_encap);
|
||||||
|
|
||||||
@ -204,11 +202,9 @@ void cnstr_shdsc_aead_null_decap(u32 * const desc, struct alginfo *adata,
|
|||||||
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS2 |
|
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS2 |
|
||||||
FIFOLD_TYPE_LAST2 | FIFOLD_TYPE_ICV);
|
FIFOLD_TYPE_LAST2 | FIFOLD_TYPE_ICV);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("aead null dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"aead null dec shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_aead_null_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_aead_null_decap);
|
||||||
|
|
||||||
@ -358,10 +354,9 @@ void cnstr_shdsc_aead_encap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("aead enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "aead enc shdesc@" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_aead_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_aead_encap);
|
||||||
|
|
||||||
@ -475,10 +470,9 @@ void cnstr_shdsc_aead_decap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS2 |
|
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS2 |
|
||||||
FIFOLD_TYPE_LAST2 | FIFOLD_TYPE_ICV);
|
FIFOLD_TYPE_LAST2 | FIFOLD_TYPE_ICV);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("aead dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "aead dec shdesc@" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_aead_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_aead_decap);
|
||||||
|
|
||||||
@ -613,11 +607,9 @@ copy_iv:
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_2_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("aead givenc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"aead givenc shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_aead_givencap);
|
EXPORT_SYMBOL(cnstr_shdsc_aead_givencap);
|
||||||
|
|
||||||
@ -742,10 +734,9 @@ void cnstr_shdsc_gcm_encap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("gcm enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "gcm enc shdesc@" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_gcm_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_gcm_encap);
|
||||||
|
|
||||||
@ -838,10 +829,9 @@ void cnstr_shdsc_gcm_decap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
||||||
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("gcm dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "gcm dec shdesc@" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_gcm_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_gcm_decap);
|
||||||
|
|
||||||
@ -933,11 +923,9 @@ void cnstr_shdsc_rfc4106_encap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("rfc4106 enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"rfc4106 enc shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_rfc4106_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_rfc4106_encap);
|
||||||
|
|
||||||
@ -1030,11 +1018,9 @@ void cnstr_shdsc_rfc4106_decap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
||||||
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("rfc4106 dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"rfc4106 dec shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_rfc4106_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_rfc4106_decap);
|
||||||
|
|
||||||
@ -1115,11 +1101,9 @@ void cnstr_shdsc_rfc4543_encap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
append_seq_store(desc, icvsize, LDST_CLASS_1_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("rfc4543 enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"rfc4543 enc shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_rfc4543_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_rfc4543_encap);
|
||||||
|
|
||||||
@ -1205,11 +1189,9 @@ void cnstr_shdsc_rfc4543_decap(u32 * const desc, struct alginfo *cdata,
|
|||||||
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
append_seq_fifo_load(desc, icvsize, FIFOLD_CLASS_CLASS1 |
|
||||||
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
FIFOLD_TYPE_ICV | FIFOLD_TYPE_LAST1);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("rfc4543 dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"rfc4543 dec shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_rfc4543_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_rfc4543_decap);
|
||||||
|
|
||||||
@ -1416,11 +1398,9 @@ void cnstr_shdsc_skcipher_encap(u32 * const desc, struct alginfo *cdata,
|
|||||||
/* Perform operation */
|
/* Perform operation */
|
||||||
skcipher_append_src_dst(desc);
|
skcipher_append_src_dst(desc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("skcipher enc shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"skcipher enc shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_skcipher_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_skcipher_encap);
|
||||||
|
|
||||||
@ -1487,11 +1467,9 @@ void cnstr_shdsc_skcipher_decap(u32 * const desc, struct alginfo *cdata,
|
|||||||
/* Perform operation */
|
/* Perform operation */
|
||||||
skcipher_append_src_dst(desc);
|
skcipher_append_src_dst(desc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("skcipher dec shdesc@" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
"skcipher dec shdesc@" __stringify(__LINE__)": ",
|
1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_skcipher_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_skcipher_decap);
|
||||||
|
|
||||||
@ -1538,11 +1516,9 @@ void cnstr_shdsc_xts_skcipher_encap(u32 * const desc, struct alginfo *cdata)
|
|||||||
/* Perform operation */
|
/* Perform operation */
|
||||||
skcipher_append_src_dst(desc);
|
skcipher_append_src_dst(desc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("xts skcipher enc shdesc@" __stringify(__LINE__)
|
||||||
print_hex_dump(KERN_ERR,
|
": ", DUMP_PREFIX_ADDRESS, 16, 4,
|
||||||
"xts skcipher enc shdesc@" __stringify(__LINE__) ": ",
|
desc, desc_bytes(desc), 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_xts_skcipher_encap);
|
EXPORT_SYMBOL(cnstr_shdsc_xts_skcipher_encap);
|
||||||
|
|
||||||
@ -1588,11 +1564,9 @@ void cnstr_shdsc_xts_skcipher_decap(u32 * const desc, struct alginfo *cdata)
|
|||||||
/* Perform operation */
|
/* Perform operation */
|
||||||
skcipher_append_src_dst(desc);
|
skcipher_append_src_dst(desc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("xts skcipher dec shdesc@" __stringify(__LINE__)
|
||||||
print_hex_dump(KERN_ERR,
|
": ", DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
"xts skcipher dec shdesc@" __stringify(__LINE__) ": ",
|
desc_bytes(desc), 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cnstr_shdsc_xts_skcipher_decap);
|
EXPORT_SYMBOL(cnstr_shdsc_xts_skcipher_decap);
|
||||||
|
|
||||||
|
@ -214,13 +214,11 @@ static int aead_setkey(struct crypto_aead *aead, const u8 *key,
|
|||||||
if (crypto_authenc_extractkeys(&keys, key, keylen) != 0)
|
if (crypto_authenc_extractkeys(&keys, key, keylen) != 0)
|
||||||
goto badkey;
|
goto badkey;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "keylen %d enckeylen %d authkeylen %d\n",
|
||||||
dev_err(jrdev, "keylen %d enckeylen %d authkeylen %d\n",
|
|
||||||
keys.authkeylen + keys.enckeylen, keys.enckeylen,
|
keys.authkeylen + keys.enckeylen, keys.enckeylen,
|
||||||
keys.authkeylen);
|
keys.authkeylen);
|
||||||
print_hex_dump(KERN_ERR, "key in @" __stringify(__LINE__)": ",
|
print_hex_dump_debug("key in @" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If DKP is supported, use it in the shared descriptor to generate
|
* If DKP is supported, use it in the shared descriptor to generate
|
||||||
@ -387,10 +385,8 @@ static int gcm_setkey(struct crypto_aead *aead,
|
|||||||
struct device *jrdev = ctx->jrdev;
|
struct device *jrdev = ctx->jrdev;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
dma_sync_single_for_device(jrdev->parent, ctx->key_dma, keylen,
|
dma_sync_single_for_device(jrdev->parent, ctx->key_dma, keylen,
|
||||||
@ -487,10 +483,8 @@ static int rfc4106_setkey(struct crypto_aead *aead,
|
|||||||
if (keylen < 4)
|
if (keylen < 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
/*
|
/*
|
||||||
@ -591,10 +585,8 @@ static int rfc4543_setkey(struct crypto_aead *aead,
|
|||||||
if (keylen < 4)
|
if (keylen < 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
memcpy(ctx->key, key, keylen);
|
memcpy(ctx->key, key, keylen);
|
||||||
/*
|
/*
|
||||||
@ -646,10 +638,9 @@ static int skcipher_setkey(struct crypto_skcipher *skcipher, const u8 *key,
|
|||||||
const bool is_rfc3686 = alg->caam.rfc3686;
|
const bool is_rfc3686 = alg->caam.rfc3686;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key in @" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key in @" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, keylen, 1);
|
|
||||||
#endif
|
|
||||||
/*
|
/*
|
||||||
* AES-CTR needs to load IV in CONTEXT1 reg
|
* AES-CTR needs to load IV in CONTEXT1 reg
|
||||||
* at an offset of 128bits (16bytes)
|
* at an offset of 128bits (16bytes)
|
||||||
@ -1199,23 +1190,19 @@ static void skcipher_done(struct caam_drv_req *drv_req, u32 status)
|
|||||||
struct device *qidev = caam_ctx->qidev;
|
struct device *qidev = caam_ctx->qidev;
|
||||||
int ivsize = crypto_skcipher_ivsize(skcipher);
|
int ivsize = crypto_skcipher_ivsize(skcipher);
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(qidev, "%s %d: status 0x%x\n", __func__, __LINE__, status);
|
||||||
dev_err(qidev, "%s %d: status 0x%x\n", __func__, __LINE__, status);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(drv_req, typeof(*edesc), drv_req);
|
edesc = container_of(drv_req, typeof(*edesc), drv_req);
|
||||||
|
|
||||||
if (status)
|
if (status)
|
||||||
caam_jr_strstatus(qidev, status);
|
caam_jr_strstatus(qidev, status);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("dstiv @" __stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "dstiv @" __stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, req->iv,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->iv,
|
edesc->src_nents > 1 ? 100 : ivsize, 1);
|
||||||
edesc->src_nents > 1 ? 100 : ivsize, 1);
|
|
||||||
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
caam_dump_sg(KERN_ERR, "dst @" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->dst,
|
||||||
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
edesc->dst_nents > 1 ? 100 : req->cryptlen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
skcipher_unmap(qidev, edesc, req);
|
skcipher_unmap(qidev, edesc, req);
|
||||||
|
|
||||||
|
@ -235,11 +235,10 @@ static int ahash_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, true, ctrlpriv->era);
|
ctx->ctx_len, true, ctrlpriv->era);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR,
|
print_hex_dump_debug("ahash update shdesc@"__stringify(__LINE__)": ",
|
||||||
"ahash update shdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ahash_update_first shared descriptor */
|
/* ahash_update_first shared descriptor */
|
||||||
desc = ctx->sh_desc_update_first;
|
desc = ctx->sh_desc_update_first;
|
||||||
@ -247,11 +246,9 @@ static int ahash_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, false, ctrlpriv->era);
|
ctx->ctx_len, false, ctrlpriv->era);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("ahash update first shdesc@"__stringify(__LINE__)
|
||||||
print_hex_dump(KERN_ERR,
|
": ", DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
"ahash update first shdesc@"__stringify(__LINE__)": ",
|
desc_bytes(desc), 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ahash_final shared descriptor */
|
/* ahash_final shared descriptor */
|
||||||
desc = ctx->sh_desc_fin;
|
desc = ctx->sh_desc_fin;
|
||||||
@ -259,11 +256,10 @@ static int ahash_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, true, ctrlpriv->era);
|
ctx->ctx_len, true, ctrlpriv->era);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_fin_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_fin_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "ahash final shdesc@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("ahash final shdesc@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
desc_bytes(desc), 1);
|
desc_bytes(desc), 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ahash_digest shared descriptor */
|
/* ahash_digest shared descriptor */
|
||||||
desc = ctx->sh_desc_digest;
|
desc = ctx->sh_desc_digest;
|
||||||
@ -271,12 +267,10 @@ static int ahash_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, false, ctrlpriv->era);
|
ctx->ctx_len, false, ctrlpriv->era);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_digest_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_digest_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR,
|
print_hex_dump_debug("ahash digest shdesc@"__stringify(__LINE__)": ",
|
||||||
"ahash digest shdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
desc_bytes(desc), 1);
|
||||||
desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -320,9 +314,9 @@ static int axcbc_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, ctx->key_dma);
|
ctx->ctx_len, ctx->key_dma);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
print_hex_dump_debug("axcbc update first shdesc@" __stringify(__LINE__)" : ",
|
print_hex_dump_debug("axcbc update first shdesc@" __stringify(__LINE__)
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
" : ", DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
1);
|
desc_bytes(desc), 1);
|
||||||
|
|
||||||
/* shared descriptor for ahash_digest */
|
/* shared descriptor for ahash_digest */
|
||||||
desc = ctx->sh_desc_digest;
|
desc = ctx->sh_desc_digest;
|
||||||
@ -369,8 +363,8 @@ static int acmac_set_sh_desc(struct crypto_ahash *ahash)
|
|||||||
ctx->ctx_len, 0);
|
ctx->ctx_len, 0);
|
||||||
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
dma_sync_single_for_device(jrdev, ctx->sh_desc_update_first_dma,
|
||||||
desc_bytes(desc), ctx->dir);
|
desc_bytes(desc), ctx->dir);
|
||||||
print_hex_dump_debug("acmac update first shdesc@" __stringify(__LINE__)" : ",
|
print_hex_dump_debug("acmac update first shdesc@" __stringify(__LINE__)
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
" : ", DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
desc_bytes(desc), 1);
|
desc_bytes(desc), 1);
|
||||||
|
|
||||||
/* shared descriptor for ahash_digest */
|
/* shared descriptor for ahash_digest */
|
||||||
@ -421,12 +415,11 @@ static int hash_digest_key(struct caam_hash_ctx *ctx, u32 *keylen, u8 *key,
|
|||||||
append_seq_store(desc, digestsize, LDST_CLASS_2_CCB |
|
append_seq_store(desc, digestsize, LDST_CLASS_2_CCB |
|
||||||
LDST_SRCDST_BYTE_CONTEXT);
|
LDST_SRCDST_BYTE_CONTEXT);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("key_in@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "key_in@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key, *keylen, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, *keylen, 1);
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
result.err = 0;
|
result.err = 0;
|
||||||
init_completion(&result.completion);
|
init_completion(&result.completion);
|
||||||
@ -436,11 +429,10 @@ static int hash_digest_key(struct caam_hash_ctx *ctx, u32 *keylen, u8 *key,
|
|||||||
/* in progress */
|
/* in progress */
|
||||||
wait_for_completion(&result.completion);
|
wait_for_completion(&result.completion);
|
||||||
ret = result.err;
|
ret = result.err;
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR,
|
print_hex_dump_debug("digested key@"__stringify(__LINE__)": ",
|
||||||
"digested key@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, key,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key, digestsize, 1);
|
digestsize, 1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
dma_unmap_single(jrdev, key_dma, *keylen, DMA_BIDIRECTIONAL);
|
dma_unmap_single(jrdev, key_dma, *keylen, DMA_BIDIRECTIONAL);
|
||||||
|
|
||||||
@ -455,15 +447,14 @@ static int ahash_setkey(struct crypto_ahash *ahash,
|
|||||||
const u8 *key, unsigned int keylen)
|
const u8 *key, unsigned int keylen)
|
||||||
{
|
{
|
||||||
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
||||||
|
struct device *jrdev = ctx->jrdev;
|
||||||
int blocksize = crypto_tfm_alg_blocksize(&ahash->base);
|
int blocksize = crypto_tfm_alg_blocksize(&ahash->base);
|
||||||
int digestsize = crypto_ahash_digestsize(ahash);
|
int digestsize = crypto_ahash_digestsize(ahash);
|
||||||
struct caam_drv_private *ctrlpriv = dev_get_drvdata(ctx->jrdev->parent);
|
struct caam_drv_private *ctrlpriv = dev_get_drvdata(ctx->jrdev->parent);
|
||||||
int ret;
|
int ret;
|
||||||
u8 *hashed_key = NULL;
|
u8 *hashed_key = NULL;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "keylen %d\n", keylen);
|
||||||
printk(KERN_ERR "keylen %d\n", keylen);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (keylen > blocksize) {
|
if (keylen > blocksize) {
|
||||||
hashed_key = kmemdup(key, keylen, GFP_KERNEL | GFP_DMA);
|
hashed_key = kmemdup(key, keylen, GFP_KERNEL | GFP_DMA);
|
||||||
@ -592,11 +583,9 @@ static void ahash_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
||||||
int digestsize = crypto_ahash_digestsize(ahash);
|
int digestsize = crypto_ahash_digestsize(ahash);
|
||||||
struct caam_hash_state *state = ahash_request_ctx(req);
|
struct caam_hash_state *state = ahash_request_ctx(req);
|
||||||
#ifdef DEBUG
|
|
||||||
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
||||||
|
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
||||||
if (err)
|
if (err)
|
||||||
@ -606,11 +595,9 @@ static void ahash_done(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
memcpy(req->result, state->caam_ctx, digestsize);
|
memcpy(req->result, state->caam_ctx, digestsize);
|
||||||
kfree(edesc);
|
kfree(edesc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("ctx@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "ctx@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
ctx->ctx_len, 1);
|
||||||
ctx->ctx_len, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
req->base.complete(&req->base, err);
|
req->base.complete(&req->base, err);
|
||||||
}
|
}
|
||||||
@ -623,11 +610,9 @@ static void ahash_done_bi(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
||||||
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
||||||
struct caam_hash_state *state = ahash_request_ctx(req);
|
struct caam_hash_state *state = ahash_request_ctx(req);
|
||||||
#ifdef DEBUG
|
|
||||||
int digestsize = crypto_ahash_digestsize(ahash);
|
int digestsize = crypto_ahash_digestsize(ahash);
|
||||||
|
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
||||||
if (err)
|
if (err)
|
||||||
@ -637,15 +622,13 @@ static void ahash_done_bi(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
switch_buf(state);
|
switch_buf(state);
|
||||||
kfree(edesc);
|
kfree(edesc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("ctx@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "ctx@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
ctx->ctx_len, 1);
|
||||||
ctx->ctx_len, 1);
|
|
||||||
if (req->result)
|
if (req->result)
|
||||||
print_hex_dump(KERN_ERR, "result@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("result@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->result,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->result,
|
||||||
digestsize, 1);
|
digestsize, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
req->base.complete(&req->base, err);
|
req->base.complete(&req->base, err);
|
||||||
}
|
}
|
||||||
@ -658,11 +641,9 @@ static void ahash_done_ctx_src(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
||||||
int digestsize = crypto_ahash_digestsize(ahash);
|
int digestsize = crypto_ahash_digestsize(ahash);
|
||||||
struct caam_hash_state *state = ahash_request_ctx(req);
|
struct caam_hash_state *state = ahash_request_ctx(req);
|
||||||
#ifdef DEBUG
|
|
||||||
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
||||||
|
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
||||||
if (err)
|
if (err)
|
||||||
@ -672,11 +653,9 @@ static void ahash_done_ctx_src(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
memcpy(req->result, state->caam_ctx, digestsize);
|
memcpy(req->result, state->caam_ctx, digestsize);
|
||||||
kfree(edesc);
|
kfree(edesc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("ctx@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "ctx@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
ctx->ctx_len, 1);
|
||||||
ctx->ctx_len, 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
req->base.complete(&req->base, err);
|
req->base.complete(&req->base, err);
|
||||||
}
|
}
|
||||||
@ -689,11 +668,9 @@ static void ahash_done_ctx_dst(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
struct crypto_ahash *ahash = crypto_ahash_reqtfm(req);
|
||||||
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
struct caam_hash_ctx *ctx = crypto_ahash_ctx(ahash);
|
||||||
struct caam_hash_state *state = ahash_request_ctx(req);
|
struct caam_hash_state *state = ahash_request_ctx(req);
|
||||||
#ifdef DEBUG
|
|
||||||
int digestsize = crypto_ahash_digestsize(ahash);
|
int digestsize = crypto_ahash_digestsize(ahash);
|
||||||
|
|
||||||
dev_err(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
dev_dbg(jrdev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
#endif
|
|
||||||
|
|
||||||
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
edesc = container_of(desc, struct ahash_edesc, hw_desc[0]);
|
||||||
if (err)
|
if (err)
|
||||||
@ -703,15 +680,13 @@ static void ahash_done_ctx_dst(struct device *jrdev, u32 *desc, u32 err,
|
|||||||
switch_buf(state);
|
switch_buf(state);
|
||||||
kfree(edesc);
|
kfree(edesc);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("ctx@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "ctx@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, state->caam_ctx,
|
ctx->ctx_len, 1);
|
||||||
ctx->ctx_len, 1);
|
|
||||||
if (req->result)
|
if (req->result)
|
||||||
print_hex_dump(KERN_ERR, "result@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("result@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, req->result,
|
DUMP_PREFIX_ADDRESS, 16, 4, req->result,
|
||||||
digestsize, 1);
|
digestsize, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
req->base.complete(&req->base, err);
|
req->base.complete(&req->base, err);
|
||||||
}
|
}
|
||||||
@ -887,11 +862,9 @@ static int ahash_update_ctx(struct ahash_request *req)
|
|||||||
|
|
||||||
append_seq_out_ptr(desc, state->ctx_dma, ctx->ctx_len, 0);
|
append_seq_out_ptr(desc, state->ctx_dma, ctx->ctx_len, 0);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
desc_bytes(desc), 1);
|
||||||
desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done_bi, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done_bi, req);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -904,13 +877,12 @@ static int ahash_update_ctx(struct ahash_request *req)
|
|||||||
*buflen = *next_buflen;
|
*buflen = *next_buflen;
|
||||||
*next_buflen = last_buflen;
|
*next_buflen = last_buflen;
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "buf@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("buf@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, buf, *buflen, 1);
|
DUMP_PREFIX_ADDRESS, 16, 4, buf, *buflen, 1);
|
||||||
print_hex_dump(KERN_ERR, "next buf@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("next buf@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, next_buf,
|
DUMP_PREFIX_ADDRESS, 16, 4, next_buf,
|
||||||
*next_buflen, 1);
|
*next_buflen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
unmap_ctx:
|
unmap_ctx:
|
||||||
@ -970,10 +942,9 @@ static int ahash_final_ctx(struct ahash_request *req)
|
|||||||
LDST_SGF);
|
LDST_SGF);
|
||||||
append_seq_out_ptr(desc, state->ctx_dma, digestsize, 0);
|
append_seq_out_ptr(desc, state->ctx_dma, digestsize, 0);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_src, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_src, req);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -1051,10 +1022,9 @@ static int ahash_finup_ctx(struct ahash_request *req)
|
|||||||
|
|
||||||
append_seq_out_ptr(desc, state->ctx_dma, digestsize, 0);
|
append_seq_out_ptr(desc, state->ctx_dma, digestsize, 0);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_src, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_src, req);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -1128,10 +1098,9 @@ static int ahash_digest(struct ahash_request *req)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -1183,10 +1152,9 @@ static int ahash_final_no_ctx(struct ahash_request *req)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto unmap;
|
goto unmap;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -1308,11 +1276,9 @@ static int ahash_update_no_ctx(struct ahash_request *req)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto unmap_ctx;
|
goto unmap_ctx;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
desc_bytes(desc), 1);
|
||||||
desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_dst, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_dst, req);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -1328,13 +1294,12 @@ static int ahash_update_no_ctx(struct ahash_request *req)
|
|||||||
*buflen = *next_buflen;
|
*buflen = *next_buflen;
|
||||||
*next_buflen = 0;
|
*next_buflen = 0;
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "buf@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("buf@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, buf, *buflen, 1);
|
DUMP_PREFIX_ADDRESS, 16, 4, buf, *buflen, 1);
|
||||||
print_hex_dump(KERN_ERR, "next buf@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("next buf@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, next_buf,
|
DUMP_PREFIX_ADDRESS, 16, 4, next_buf, *next_buflen,
|
||||||
*next_buflen, 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
unmap_ctx:
|
unmap_ctx:
|
||||||
@ -1409,10 +1374,9 @@ static int ahash_finup_no_ctx(struct ahash_request *req)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto unmap;
|
goto unmap;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done, req);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -1512,11 +1476,9 @@ static int ahash_update_first(struct ahash_request *req)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto unmap_ctx;
|
goto unmap_ctx;
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc,
|
desc_bytes(desc), 1);
|
||||||
desc_bytes(desc), 1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_dst, req);
|
ret = caam_jr_enqueue(jrdev, desc, ahash_done_ctx_dst, req);
|
||||||
if (ret)
|
if (ret)
|
||||||
@ -1534,11 +1496,10 @@ static int ahash_update_first(struct ahash_request *req)
|
|||||||
req->nbytes, 0);
|
req->nbytes, 0);
|
||||||
switch_buf(state);
|
switch_buf(state);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "next buf@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("next buf@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, next_buf,
|
DUMP_PREFIX_ADDRESS, 16, 4, next_buf, *next_buflen,
|
||||||
*next_buflen, 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
unmap_ctx:
|
unmap_ctx:
|
||||||
|
@ -113,10 +113,8 @@ static void rng_done(struct device *jrdev, u32 *desc, u32 err, void *context)
|
|||||||
/* Buffer refilled, invalidate cache */
|
/* Buffer refilled, invalidate cache */
|
||||||
dma_sync_single_for_cpu(jrdev, bd->addr, RN_BUF_SIZE, DMA_FROM_DEVICE);
|
dma_sync_single_for_cpu(jrdev, bd->addr, RN_BUF_SIZE, DMA_FROM_DEVICE);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("rng refreshed buf@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
||||||
print_hex_dump(KERN_ERR, "rng refreshed buf@: ",
|
bd->buf, RN_BUF_SIZE, 1);
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, bd->buf, RN_BUF_SIZE, 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int submit_job(struct caam_rng_ctx *ctx, int to_current)
|
static inline int submit_job(struct caam_rng_ctx *ctx, int to_current)
|
||||||
@ -209,10 +207,10 @@ static inline int rng_create_sh_desc(struct caam_rng_ctx *ctx)
|
|||||||
dev_err(jrdev, "unable to map shared descriptor\n");
|
dev_err(jrdev, "unable to map shared descriptor\n");
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "rng shdesc@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
print_hex_dump_debug("rng shdesc@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
||||||
desc, desc_bytes(desc), 1);
|
desc, desc_bytes(desc), 1);
|
||||||
#endif
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -233,10 +231,10 @@ static inline int rng_create_job_desc(struct caam_rng_ctx *ctx, int buf_id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
append_seq_out_ptr_intlen(desc, bd->addr, RN_BUF_SIZE, 0);
|
append_seq_out_ptr_intlen(desc, bd->addr, RN_BUF_SIZE, 0);
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "rng job desc@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
print_hex_dump_debug("rng job desc@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
||||||
desc, desc_bytes(desc), 1);
|
desc, desc_bytes(desc), 1);
|
||||||
#endif
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,9 +16,7 @@ void split_key_done(struct device *dev, u32 *desc, u32 err,
|
|||||||
{
|
{
|
||||||
struct split_key_result *res = context;
|
struct split_key_result *res = context;
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(dev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
||||||
dev_err(dev, "%s %d: err 0x%x\n", __func__, __LINE__, err);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
caam_jr_strstatus(dev, err);
|
caam_jr_strstatus(dev, err);
|
||||||
@ -55,12 +53,10 @@ int gen_split_key(struct device *jrdev, u8 *key_out,
|
|||||||
adata->keylen_pad = split_key_pad_len(adata->algtype &
|
adata->keylen_pad = split_key_pad_len(adata->algtype &
|
||||||
OP_ALG_ALGSEL_MASK);
|
OP_ALG_ALGSEL_MASK);
|
||||||
|
|
||||||
#ifdef DEBUG
|
dev_dbg(jrdev, "split keylen %d split keylen padded %d\n",
|
||||||
dev_err(jrdev, "split keylen %d split keylen padded %d\n",
|
|
||||||
adata->keylen, adata->keylen_pad);
|
adata->keylen, adata->keylen_pad);
|
||||||
print_hex_dump(KERN_ERR, "ctx.key@" __stringify(__LINE__)": ",
|
print_hex_dump_debug("ctx.key@" __stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key_in, keylen, 1);
|
DUMP_PREFIX_ADDRESS, 16, 4, key_in, keylen, 1);
|
||||||
#endif
|
|
||||||
|
|
||||||
if (adata->keylen_pad > max_keylen)
|
if (adata->keylen_pad > max_keylen)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -102,10 +98,9 @@ int gen_split_key(struct device *jrdev, u8 *key_out,
|
|||||||
append_fifo_store(desc, dma_addr, adata->keylen,
|
append_fifo_store(desc, dma_addr, adata->keylen,
|
||||||
LDST_CLASS_2_CCB | FIFOST_TYPE_SPLIT_KEK);
|
LDST_CLASS_2_CCB | FIFOST_TYPE_SPLIT_KEK);
|
||||||
|
|
||||||
#ifdef DEBUG
|
print_hex_dump_debug("jobdesc@"__stringify(__LINE__)": ",
|
||||||
print_hex_dump(KERN_ERR, "jobdesc@"__stringify(__LINE__)": ",
|
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc),
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, desc, desc_bytes(desc), 1);
|
1);
|
||||||
#endif
|
|
||||||
|
|
||||||
result.err = 0;
|
result.err = 0;
|
||||||
init_completion(&result.completion);
|
init_completion(&result.completion);
|
||||||
@ -115,11 +110,10 @@ int gen_split_key(struct device *jrdev, u8 *key_out,
|
|||||||
/* in progress */
|
/* in progress */
|
||||||
wait_for_completion(&result.completion);
|
wait_for_completion(&result.completion);
|
||||||
ret = result.err;
|
ret = result.err;
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "ctx.key@"__stringify(__LINE__)": ",
|
print_hex_dump_debug("ctx.key@"__stringify(__LINE__)": ",
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, key_out,
|
DUMP_PREFIX_ADDRESS, 16, 4, key_out,
|
||||||
adata->keylen_pad, 1);
|
adata->keylen_pad, 1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dma_unmap_single(jrdev, dma_addr, adata->keylen_pad, DMA_BIDIRECTIONAL);
|
dma_unmap_single(jrdev, dma_addr, adata->keylen_pad, DMA_BIDIRECTIONAL);
|
||||||
|
@ -35,11 +35,9 @@ static inline void dma_to_sec4_sg_one(struct sec4_sg_entry *sec4_sg_ptr,
|
|||||||
sec4_sg_ptr->bpid_offset = cpu_to_caam32(offset &
|
sec4_sg_ptr->bpid_offset = cpu_to_caam32(offset &
|
||||||
SEC4_SG_OFFSET_MASK);
|
SEC4_SG_OFFSET_MASK);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
|
||||||
print_hex_dump(KERN_ERR, "sec4_sg_ptr@: ",
|
print_hex_dump_debug("sec4_sg_ptr@: ", DUMP_PREFIX_ADDRESS, 16, 4,
|
||||||
DUMP_PREFIX_ADDRESS, 16, 4, sec4_sg_ptr,
|
sec4_sg_ptr, sizeof(struct sec4_sg_entry), 1);
|
||||||
sizeof(struct sec4_sg_entry), 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user