aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/crypto
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/crypto')
-rw-r--r--drivers/crypto/mv_cesa.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/drivers/crypto/mv_cesa.c b/drivers/crypto/mv_cesa.c
index 4262932d4a27..2b4f07aa89e8 100644
--- a/drivers/crypto/mv_cesa.c
+++ b/drivers/crypto/mv_cesa.c
@@ -51,6 +51,8 @@ enum engine_status {
51struct req_progress { 51struct req_progress {
52 struct sg_mapping_iter src_sg_it; 52 struct sg_mapping_iter src_sg_it;
53 struct sg_mapping_iter dst_sg_it; 53 struct sg_mapping_iter dst_sg_it;
54 void (*complete) (void);
55 void (*process) (int is_first);
54 56
55 /* src mostly */ 57 /* src mostly */
56 int sg_src_left; 58 int sg_src_left;
@@ -251,6 +253,9 @@ static void mv_crypto_algo_completion(void)
251 struct ablkcipher_request *req = ablkcipher_request_cast(cpg->cur_req); 253 struct ablkcipher_request *req = ablkcipher_request_cast(cpg->cur_req);
252 struct mv_req_ctx *req_ctx = ablkcipher_request_ctx(req); 254 struct mv_req_ctx *req_ctx = ablkcipher_request_ctx(req);
253 255
256 sg_miter_stop(&cpg->p.src_sg_it);
257 sg_miter_stop(&cpg->p.dst_sg_it);
258
254 if (req_ctx->op != COP_AES_CBC) 259 if (req_ctx->op != COP_AES_CBC)
255 return ; 260 return ;
256 261
@@ -294,11 +299,9 @@ static void dequeue_complete_req(void)
294 if (cpg->p.hw_processed_bytes < cpg->p.hw_nbytes) { 299 if (cpg->p.hw_processed_bytes < cpg->p.hw_nbytes) {
295 /* process next scatter list entry */ 300 /* process next scatter list entry */
296 cpg->eng_st = ENGINE_BUSY; 301 cpg->eng_st = ENGINE_BUSY;
297 mv_process_current_q(0); 302 cpg->p.process(0);
298 } else { 303 } else {
299 sg_miter_stop(&cpg->p.src_sg_it); 304 cpg->p.complete();
300 sg_miter_stop(&cpg->p.dst_sg_it);
301 mv_crypto_algo_completion();
302 cpg->eng_st = ENGINE_IDLE; 305 cpg->eng_st = ENGINE_IDLE;
303 local_bh_disable(); 306 local_bh_disable();
304 req->complete(req, 0); 307 req->complete(req, 0);
@@ -331,6 +334,8 @@ static void mv_enqueue_new_req(struct ablkcipher_request *req)
331 cpg->cur_req = &req->base; 334 cpg->cur_req = &req->base;
332 memset(p, 0, sizeof(struct req_progress)); 335 memset(p, 0, sizeof(struct req_progress));
333 p->hw_nbytes = req->nbytes; 336 p->hw_nbytes = req->nbytes;
337 p->complete = mv_crypto_algo_completion;
338 p->process = mv_process_current_q;
334 339
335 num_sgs = count_sgs(req->src, req->nbytes); 340 num_sgs = count_sgs(req->src, req->nbytes);
336 sg_miter_start(&p->src_sg_it, req->src, num_sgs, SG_MITER_FROM_SG); 341 sg_miter_start(&p->src_sg_it, req->src, num_sgs, SG_MITER_FROM_SG);