diff options
| author | Horia Geantă <[email protected]> | 2018-09-14 18:34:28 +0300 | 
|---|---|---|
| committer | Herbert Xu <[email protected]> | 2018-09-21 13:04:46 +0800 | 
| commit | 13cc6f48c7434ce46ba6dbc90003a136a263d75a (patch) | |
| tree | b3dabc5927363a5aa8fb153106a679415e848fee /tools/lib/api | |
| parent | 24568b47d48ec8c906fd0f589489a08b17e1edca (diff) | |
crypto: caam/jr - fix ablkcipher_edesc pointer arithmetic
In some cases the zero-length hw_desc array at the end of
ablkcipher_edesc struct requires for 4B of tail padding.
Due to tail padding and the way pointers to S/G table and IV
are computed:
	edesc->sec4_sg = (void *)edesc + sizeof(struct ablkcipher_edesc) +
			 desc_bytes;
	iv = (u8 *)edesc->hw_desc + desc_bytes + sec4_sg_bytes;
first 4 bytes of IV are overwritten by S/G table.
Update computation of pointer to S/G table to rely on offset of hw_desc
member and not on sizeof() operator.
Cc: <[email protected]> # 4.13+
Fixes: 115957bb3e59 ("crypto: caam - fix IV DMA mapping and updating")
Signed-off-by: Horia Geantă <[email protected]>
Signed-off-by: Herbert Xu <[email protected]>
Diffstat (limited to 'tools/lib/api')
0 files changed, 0 insertions, 0 deletions