aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/crypto
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/crypto')
-rw-r--r--drivers/crypto/omap-sham.c47
1 files changed, 21 insertions, 26 deletions
diff --git a/drivers/crypto/omap-sham.c b/drivers/crypto/omap-sham.c
index db206284835a..6340c5ef4712 100644
--- a/drivers/crypto/omap-sham.c
+++ b/drivers/crypto/omap-sham.c
@@ -84,9 +84,7 @@
84#define FLAGS_CPU 0x0200 84#define FLAGS_CPU 0x0200
85#define FLAGS_HMAC 0x0400 85#define FLAGS_HMAC 0x0400
86#define FLAGS_ERROR 0x0800 86#define FLAGS_ERROR 0x0800
87 87#define FLAGS_BUSY 0x1000
88/* 3rd byte */
89#define FLAGS_BUSY 16
90 88
91#define OP_UPDATE 1 89#define OP_UPDATE 1
92#define OP_FINAL 2 90#define OP_FINAL 2
@@ -629,32 +627,37 @@ static void omap_sham_finish_req(struct ahash_request *req, int err)
629 if ((ctx->flags & FLAGS_FINAL) || err) 627 if ((ctx->flags & FLAGS_FINAL) || err)
630 omap_sham_cleanup(req); 628 omap_sham_cleanup(req);
631 629
632 clear_bit(FLAGS_BUSY, &ctx->dd->flags); 630 ctx->dd->flags &= ~FLAGS_BUSY;
633 631
634 if (req->base.complete) 632 if (req->base.complete)
635 req->base.complete(&req->base, err); 633 req->base.complete(&req->base, err);
636} 634}
637 635
638static int omap_sham_handle_queue(struct omap_sham_dev *dd) 636static int omap_sham_handle_queue(struct omap_sham_dev *dd,
637 struct ahash_request *req)
639{ 638{
640 struct crypto_async_request *async_req, *backlog; 639 struct crypto_async_request *async_req, *backlog;
641 struct omap_sham_reqctx *ctx; 640 struct omap_sham_reqctx *ctx;
642 struct ahash_request *req, *prev_req; 641 struct ahash_request *prev_req;
643 unsigned long flags; 642 unsigned long flags;
644 int err = 0; 643 int err = 0, ret = 0;
645
646 if (test_and_set_bit(FLAGS_BUSY, &dd->flags))
647 return 0;
648 644
649 spin_lock_irqsave(&dd->lock, flags); 645 spin_lock_irqsave(&dd->lock, flags);
650 backlog = crypto_get_backlog(&dd->queue); 646 if (req)
647 ret = ahash_enqueue_request(&dd->queue, req);
648 if (dd->flags & FLAGS_BUSY) {
649 spin_unlock_irqrestore(&dd->lock, flags);
650 return ret;
651 }
651 async_req = crypto_dequeue_request(&dd->queue); 652 async_req = crypto_dequeue_request(&dd->queue);
652 if (!async_req) 653 if (async_req) {
653 clear_bit(FLAGS_BUSY, &dd->flags); 654 dd->flags |= FLAGS_BUSY;
655 backlog = crypto_get_backlog(&dd->queue);
656 }
654 spin_unlock_irqrestore(&dd->lock, flags); 657 spin_unlock_irqrestore(&dd->lock, flags);
655 658
656 if (!async_req) 659 if (!async_req)
657 return 0; 660 return ret;
658 661
659 if (backlog) 662 if (backlog)
660 backlog->complete(backlog, -EINPROGRESS); 663 backlog->complete(backlog, -EINPROGRESS);
@@ -690,7 +693,7 @@ static int omap_sham_handle_queue(struct omap_sham_dev *dd)
690 693
691 dev_dbg(dd->dev, "exit, err: %d\n", err); 694 dev_dbg(dd->dev, "exit, err: %d\n", err);
692 695
693 return err; 696 return ret;
694} 697}
695 698
696static int omap_sham_enqueue(struct ahash_request *req, unsigned int op) 699static int omap_sham_enqueue(struct ahash_request *req, unsigned int op)
@@ -698,18 +701,10 @@ static int omap_sham_enqueue(struct ahash_request *req, unsigned int op)
698 struct omap_sham_reqctx *ctx = ahash_request_ctx(req); 701 struct omap_sham_reqctx *ctx = ahash_request_ctx(req);
699 struct omap_sham_ctx *tctx = crypto_tfm_ctx(req->base.tfm); 702 struct omap_sham_ctx *tctx = crypto_tfm_ctx(req->base.tfm);
700 struct omap_sham_dev *dd = tctx->dd; 703 struct omap_sham_dev *dd = tctx->dd;
701 unsigned long flags;
702 int err;
703 704
704 ctx->op = op; 705 ctx->op = op;
705 706
706 spin_lock_irqsave(&dd->lock, flags); 707 return omap_sham_handle_queue(dd, req);
707 err = ahash_enqueue_request(&dd->queue, req);
708 spin_unlock_irqrestore(&dd->lock, flags);
709
710 omap_sham_handle_queue(dd);
711
712 return err;
713} 708}
714 709
715static int omap_sham_update(struct ahash_request *req) 710static int omap_sham_update(struct ahash_request *req)
@@ -1041,7 +1036,7 @@ static void omap_sham_done_task(unsigned long data)
1041 /* finish curent request */ 1036 /* finish curent request */
1042 omap_sham_finish_req(req, err); 1037 omap_sham_finish_req(req, err);
1043 /* start new request */ 1038 /* start new request */
1044 omap_sham_handle_queue(dd); 1039 omap_sham_handle_queue(dd, NULL);
1045 } 1040 }
1046} 1041}
1047 1042
@@ -1049,7 +1044,7 @@ static void omap_sham_queue_task(unsigned long data)
1049{ 1044{
1050 struct omap_sham_dev *dd = (struct omap_sham_dev *)data; 1045 struct omap_sham_dev *dd = (struct omap_sham_dev *)data;
1051 1046
1052 omap_sham_handle_queue(dd); 1047 omap_sham_handle_queue(dd, NULL);
1053} 1048}
1054 1049
1055static irqreturn_t omap_sham_irq(int irq, void *dev_id) 1050static irqreturn_t omap_sham_irq(int irq, void *dev_id)