Commit 991c569c authored by Kim Phillips's avatar Kim Phillips Committed by Herbert Xu

crypto: caam - fix descriptor length adjustments for protocol descriptors

init_desc, by always ORing with 1 for the descriptor header inclusion
into the descriptor length, and init_sh_desc_pdb, by always specifying
the descriptor length modification for the PDB via options, would not
allow for odd length PDBs to be embedded in the constructed descriptor
length.  Fix this by simply changing the OR to an addition.

also round-up pdb_bytes to the next SEC command unit size, to
allow for, e.g., optional packet header bytes that aren't a
multiple of CAAM_CMD_SZ.
Reported-by: default avatarRadu-Andrei BULIE <radu.bulie@freescale.com>
Signed-off-by: default avatarKim Phillips <kim.phillips@freescale.com>
Cc: Yashpal Dutta <yashpal.dutta@freescale.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent c4b66406
...@@ -51,7 +51,7 @@ static inline void *sh_desc_pdb(u32 *desc) ...@@ -51,7 +51,7 @@ static inline void *sh_desc_pdb(u32 *desc)
static inline void init_desc(u32 *desc, u32 options) static inline void init_desc(u32 *desc, u32 options)
{ {
*desc = options | HDR_ONE | 1; *desc = (options | HDR_ONE) + 1;
} }
static inline void init_sh_desc(u32 *desc, u32 options) static inline void init_sh_desc(u32 *desc, u32 options)
...@@ -62,7 +62,7 @@ static inline void init_sh_desc(u32 *desc, u32 options) ...@@ -62,7 +62,7 @@ static inline void init_sh_desc(u32 *desc, u32 options)
static inline void init_sh_desc_pdb(u32 *desc, u32 options, size_t pdb_bytes) static inline void init_sh_desc_pdb(u32 *desc, u32 options, size_t pdb_bytes)
{ {
u32 pdb_len = pdb_bytes / CAAM_CMD_SZ + 1; u32 pdb_len = (pdb_bytes + CAAM_CMD_SZ - 1) / CAAM_CMD_SZ;
init_sh_desc(desc, (((pdb_len + 1) << HDR_START_IDX_SHIFT) + pdb_len) | init_sh_desc(desc, (((pdb_len + 1) << HDR_START_IDX_SHIFT) + pdb_len) |
options); options);
......
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