Lines Matching refs:ss

3  * sun8i-ss-hash.c - hardware cryptographic offloader for
27 #include "sun8i-ss.h"
41 dev_err(tfmctx->ss->dev, "shash digest error ret=%d\n", ret);
103 op->ss = algt->ss;
109 dev_err(algt->ss->dev, "Fallback driver could no be loaded\n");
123 err = pm_runtime_get_sync(op->ss->dev);
128 pm_runtime_put_noidle(op->ss->dev);
141 pm_runtime_put_sync_suspend(tfmctx->ss->dev);
286 static int sun8i_ss_run_hash_task(struct sun8i_ss_dev *ss,
295 ss->flows[flow].stat_req++;
310 mutex_lock(&ss->mlock);
313 writel(rctx->t_dst[i - 1].addr, ss->base + SS_KEY_ADR_REG);
314 writel(rctx->t_dst[i - 1].addr, ss->base + SS_IV_ADR_REG);
317 dev_dbg(ss->dev,
323 writel(rctx->t_src[i].addr, ss->base + SS_SRC_ADR_REG);
324 writel(rctx->t_dst[i].addr, ss->base + SS_DST_ADR_REG);
325 writel(rctx->t_src[i].len, ss->base + SS_LEN_ADR_REG);
326 writel(BIT(0) | BIT(1), ss->base + SS_INT_CTL_REG);
328 reinit_completion(&ss->flows[flow].complete);
329 ss->flows[flow].status = 0;
332 writel(v, ss->base + SS_CTL_REG);
333 mutex_unlock(&ss->mlock);
334 wait_for_completion_interruptible_timeout(&ss->flows[flow].complete,
336 if (ss->flows[flow].status == 0) {
337 dev_err(ss->dev, "DMA timeout for %s\n", name);
400 struct sun8i_ss_dev *ss;
408 ss = algt->ss;
410 e = sun8i_ss_get_engine_number(ss);
412 engine = ss->flows[e].engine;
486 struct sun8i_ss_dev *ss;
504 ss = algt->ss;
510 result = ss->flows[rctx->flow].result;
511 pad = ss->flows[rctx->flow].pad;
523 rctx->method = ss->variant->alg_hash[algt->ss_algo_id];
525 nr_sgs = dma_map_sg(ss->dev, areq->src, sg_nents(areq->src), DMA_TO_DEVICE);
527 dev_err(ss->dev, "Invalid sg number %d\n", nr_sgs);
532 addr_res = dma_map_single(ss->dev, result, digestsize, DMA_FROM_DEVICE);
533 if (dma_mapping_error(ss->dev, addr_res)) {
534 dev_err(ss->dev, "DMA map dest\n");
565 dev_err(ss->dev, "remaining len %d\n", len);
584 addr_xpad = dma_map_single(ss->dev, tfmctx->ipad, bs, DMA_TO_DEVICE);
585 err = dma_mapping_error(ss->dev, addr_xpad);
587 dev_err(ss->dev, "Fail to create DMA mapping of ipad\n");
605 addr_res = dma_map_single(ss->dev, result, digestsize, DMA_FROM_DEVICE);
606 if (dma_mapping_error(ss->dev, addr_res)) {
607 dev_err(ss->dev, "Fail to create DMA mapping of result\n");
611 addr_xpad = dma_map_single(ss->dev, tfmctx->opad, bs, DMA_TO_DEVICE);
612 err = dma_mapping_error(ss->dev, addr_xpad);
614 dev_err(ss->dev, "Fail to create DMA mapping of opad\n");
644 addr_pad = dma_map_single(ss->dev, pad, j * 4, DMA_TO_DEVICE);
645 if (dma_mapping_error(ss->dev, addr_pad)) {
646 dev_err(ss->dev, "DMA error on padding SG\n");
655 err = sun8i_ss_run_hash_task(ss, rctx, crypto_tfm_alg_name(areq->base.tfm));
682 dma_unmap_single(ss->dev, addr_pad, j * 4, DMA_TO_DEVICE);
686 dma_unmap_single(ss->dev, addr_xpad, bs, DMA_TO_DEVICE);
688 dma_unmap_single(ss->dev, addr_res, digestsize, DMA_FROM_DEVICE);
691 dma_unmap_sg(ss->dev, areq->src, sg_nents(areq->src),