Skip to content
Snippets Groups Projects
Commit 7f4736bd authored by Ruchika Gupta's avatar Ruchika Gupta Committed by York Sun
Browse files

drivers/crypto/fsl : Allocate output ring with size aligned to CACHELNE SIZE


The output ring needs to be invalidated before enqueuing the job to SEC.
While allocation of space to output ring, it should be taken care that the
size is cacheline size aligned inorder to prevent invalidating valid data.

The patch also correct the method of aligning end of structs while flushing caches

    Since start = align(start_of_struct), it is incorrect to assign
    end = align(start + struct_size). It should instead be,
    end = align(start_of_struct + struct_size).

Signed-off-by: default avatarSaksham Jain <saksham@nxp.com>
Signed-off-by: default avatarRuchika Gupta <ruchika.gupta@nxp.com>
Reviewed-by: default avatarYork Sun <york.sun@nxp.com>
parent 9e71bb9c
No related branches found
No related tags found
No related merge requests found
...@@ -95,14 +95,16 @@ static int jr_init(void) ...@@ -95,14 +95,16 @@ static int jr_init(void)
JR_SIZE * sizeof(dma_addr_t)); JR_SIZE * sizeof(dma_addr_t));
if (!jr.input_ring) if (!jr.input_ring)
return -1; return -1;
jr.op_size = roundup(JR_SIZE * sizeof(struct op_ring),
ARCH_DMA_MINALIGN);
jr.output_ring = jr.output_ring =
(struct op_ring *)memalign(ARCH_DMA_MINALIGN, (struct op_ring *)memalign(ARCH_DMA_MINALIGN, jr.op_size);
JR_SIZE * sizeof(struct op_ring));
if (!jr.output_ring) if (!jr.output_ring)
return -1; return -1;
memset(jr.input_ring, 0, JR_SIZE * sizeof(dma_addr_t)); memset(jr.input_ring, 0, JR_SIZE * sizeof(dma_addr_t));
memset(jr.output_ring, 0, JR_SIZE * sizeof(struct op_ring)); memset(jr.output_ring, 0, jr.op_size);
start_jr0(); start_jr0();
...@@ -190,8 +192,8 @@ static int jr_enqueue(uint32_t *desc_addr, ...@@ -190,8 +192,8 @@ static int jr_enqueue(uint32_t *desc_addr,
unsigned long start = (unsigned long)&jr.info[head] & unsigned long start = (unsigned long)&jr.info[head] &
~(ARCH_DMA_MINALIGN - 1); ~(ARCH_DMA_MINALIGN - 1);
unsigned long end = ALIGN(start + sizeof(struct jr_info), unsigned long end = ALIGN((unsigned long)&jr.info[head] +
ARCH_DMA_MINALIGN); sizeof(struct jr_info), ARCH_DMA_MINALIGN);
flush_dcache_range(start, end); flush_dcache_range(start, end);
#ifdef CONFIG_PHYS_64BIT #ifdef CONFIG_PHYS_64BIT
...@@ -216,11 +218,19 @@ static int jr_enqueue(uint32_t *desc_addr, ...@@ -216,11 +218,19 @@ static int jr_enqueue(uint32_t *desc_addr,
#endif /* ifdef CONFIG_PHYS_64BIT */ #endif /* ifdef CONFIG_PHYS_64BIT */
start = (unsigned long)&jr.input_ring[head] & ~(ARCH_DMA_MINALIGN - 1); start = (unsigned long)&jr.input_ring[head] & ~(ARCH_DMA_MINALIGN - 1);
end = ALIGN(start + sizeof(phys_addr_t), ARCH_DMA_MINALIGN); end = ALIGN((unsigned long)&jr.input_ring[head] +
sizeof(dma_addr_t), ARCH_DMA_MINALIGN);
flush_dcache_range(start, end); flush_dcache_range(start, end);
jr.head = (head + 1) & (jr.size - 1); jr.head = (head + 1) & (jr.size - 1);
/* Invalidate output ring */
start = (unsigned long)jr.output_ring &
~(ARCH_DMA_MINALIGN - 1);
end = ALIGN((unsigned long)jr.output_ring + jr.op_size,
ARCH_DMA_MINALIGN);
invalidate_dcache_range(start, end);
sec_out32(&regs->irja, 1); sec_out32(&regs->irja, 1);
return 0; return 0;
...@@ -241,12 +251,6 @@ static int jr_dequeue(void) ...@@ -241,12 +251,6 @@ static int jr_dequeue(void)
#endif #endif
while (sec_in32(&regs->orsf) && CIRC_CNT(jr.head, jr.tail, jr.size)) { while (sec_in32(&regs->orsf) && CIRC_CNT(jr.head, jr.tail, jr.size)) {
unsigned long start = (unsigned long)jr.output_ring &
~(ARCH_DMA_MINALIGN - 1);
unsigned long end = ALIGN(start +
sizeof(struct op_ring)*JR_SIZE,
ARCH_DMA_MINALIGN);
invalidate_dcache_range(start, end);
found = 0; found = 0;
......
...@@ -72,6 +72,8 @@ struct jobring { ...@@ -72,6 +72,8 @@ struct jobring {
int write_idx; int write_idx;
/* Size of the rings. */ /* Size of the rings. */
int size; int size;
/* Op ring size aligned to cache line size */
int op_size;
/* The ip and output rings have to be accessed by SEC. So the /* The ip and output rings have to be accessed by SEC. So the
* pointers will ahve to point to the housekeeping region provided * pointers will ahve to point to the housekeeping region provided
* by SEC * by SEC
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment