All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2] crypto: omap-sham: kmap SG pages before appending
@ 2014-03-04 18:30 ` Joel Fernandes
  0 siblings, 0 replies; 7+ messages in thread
From: Joel Fernandes @ 2014-03-04 18:30 UTC (permalink / raw)
  To: linux-crypto, linux-omap; +Cc: lokeshvutla, Joel Fernandes, Herbert Xu

HIGHMEM pages may not be mapped so we must kmap them before accessing.
This resolves a random OOPs error that was showing up during OpenSSL SHA tests.

Signed-off-by: Joel Fernandes <joelf@ti.com>
Cc: Herbert Xu <herbert@gondor.apana.org.au>
---
v2 changes:
	- don't check for HIGHMEM, kmap/kunmap do them anyway (Thanks Herbert).

 drivers/crypto/omap-sham.c |    8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/drivers/crypto/omap-sham.c b/drivers/crypto/omap-sham.c
index e45aaaf..207eac1 100644
--- a/drivers/crypto/omap-sham.c
+++ b/drivers/crypto/omap-sham.c
@@ -636,11 +636,17 @@ static size_t omap_sham_append_buffer(struct omap_sham_reqctx *ctx,
 static size_t omap_sham_append_sg(struct omap_sham_reqctx *ctx)
 {
 	size_t count;
+	const u8 *vaddr;
 
 	while (ctx->sg) {
+		vaddr = kmap(sg_page(ctx->sg));
+
 		count = omap_sham_append_buffer(ctx,
-				sg_virt(ctx->sg) + ctx->offset,
+				vaddr + ctx->offset,
 				ctx->sg->length - ctx->offset);
+
+		kunmap((void *)vaddr);
+
 		if (!count)
 			break;
 		ctx->offset += count;
-- 
1.7.9.5


^ permalink raw reply related	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2014-03-06  0:21 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-03-04 18:30 [PATCH v2] crypto: omap-sham: kmap SG pages before appending Joel Fernandes
2014-03-04 18:30 ` Joel Fernandes
2014-03-05  1:59 ` Herbert Xu
2014-03-05  4:18   ` Fernandes, Joel
2014-03-05  7:11     ` Herbert Xu
2014-03-05 15:42       ` Joel Fernandes
2014-03-06  0:21         ` Herbert Xu

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.