Commit d5e4e999 authored by Alex Porosanu's avatar Alex Porosanu Committed by Herbert Xu

crypto: caam - fix RNG state handle instantiation descriptor

The way the DECO runs a descriptor through the direct (debug)
interface is different from the JRI interface: the DECO will
continue to try and execute the next commands, after the descriptor
buffer has ended. This leads to unpredictable results and possibly
to locking up of the DECO. This patch adds a halt command at the
end of the descriptor to ensure the DECO halts when it reaches
the end of the descriptor buffer.
Signed-off-by: default avatarAlex Porosanu <alexandru.porosanu@freescale.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent f5b38c5f
...@@ -73,6 +73,8 @@ static void build_instantiation_desc(u32 *desc) ...@@ -73,6 +73,8 @@ static void build_instantiation_desc(u32 *desc)
/* generate secure keys (non-test) */ /* generate secure keys (non-test) */
append_operation(desc, OP_TYPE_CLASS1_ALG | OP_ALG_ALGSEL_RNG | append_operation(desc, OP_TYPE_CLASS1_ALG | OP_ALG_ALGSEL_RNG |
OP_ALG_RNG4_SK); OP_ALG_RNG4_SK);
append_jump(desc, JUMP_CLASS_CLASS1 | JUMP_TYPE_HALT);
} }
static int instantiate_rng(struct device *ctrldev) static int instantiate_rng(struct device *ctrldev)
...@@ -83,7 +85,7 @@ static int instantiate_rng(struct device *ctrldev) ...@@ -83,7 +85,7 @@ static int instantiate_rng(struct device *ctrldev)
u32 *desc; u32 *desc;
int i, ret = 0; int i, ret = 0;
desc = kmalloc(CAAM_CMD_SZ * 6, GFP_KERNEL | GFP_DMA); desc = kmalloc(CAAM_CMD_SZ * 7, GFP_KERNEL | GFP_DMA);
if (!desc) { if (!desc) {
dev_err(ctrldev, "can't allocate RNG init descriptor memory\n"); dev_err(ctrldev, "can't allocate RNG init descriptor memory\n");
return -ENOMEM; return -ENOMEM;
......
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