int ret;
 
        ret = sg_copy_from_buffer(dst, sg_nents(dst), head, head_size);
-       if (ret != head_size) {
+       if (unlikely(ret != head_size)) {
                pr_err("the head size of buffer is wrong (%d)!\n", ret);
                return -ENOMEM;
        }
 
 static int get_comp_head_size(struct acomp_req *acomp_req, u8 req_type)
 {
-       if (!acomp_req->src || !acomp_req->slen)
+       if (unlikely(!acomp_req->src || !acomp_req->slen))
                return -EINVAL;
 
-       if (req_type == HZIP_ALG_TYPE_GZIP &&
-           acomp_req->slen < GZIP_HEAD_FEXTRA_SHIFT)
+       if (unlikely(req_type == HZIP_ALG_TYPE_GZIP &&
+                    acomp_req->slen < GZIP_HEAD_FEXTRA_SHIFT))
                return -EINVAL;
 
        switch (req_type) {
        }
        set_bit(req_id, req_q->req_bitmap);
 
+       write_unlock(&req_q->req_lock);
+
        req_cache = q + req_id;
        req_cache->req_id = req_id;
        req_cache->req = req;
                req_cache->dskip = 0;
        }
 
-       write_unlock(&req_q->req_lock);
-
        return req_cache;
 }
 
 
        write_lock(&req_q->req_lock);
        clear_bit(req->req_id, req_q->req_bitmap);
-       memset(req, 0, sizeof(struct hisi_zip_req));
        write_unlock(&req_q->req_lock);
 }
 
        struct hisi_zip_sqe zip_sqe;
        int ret;
 
-       if (!a_req->src || !a_req->slen || !a_req->dst || !a_req->dlen)
+       if (unlikely(!a_req->src || !a_req->slen || !a_req->dst || !a_req->dlen))
                return -EINVAL;
 
        req->hw_src = hisi_acc_sg_buf_map_to_hw_sgl(dev, a_req->src, pool,
        /* send command to start a task */
        atomic64_inc(&dfx->send_cnt);
        ret = hisi_qp_send(qp, &zip_sqe);
-       if (ret < 0) {
+       if (unlikely(ret < 0)) {
                atomic64_inc(&dfx->send_busy_cnt);
                ret = -EAGAIN;
                dev_dbg_ratelimited(dev, "failed to send request!\n");
 
        atomic64_inc(&dfx->recv_cnt);
        status = ops->get_status(sqe);
-       if (status != 0 && status != HZIP_NC_ERR) {
+       if (unlikely(status != 0 && status != HZIP_NC_ERR)) {
                dev_err(dev, "%scompress fail in qp%u: %u, output: %u\n",
                        (qp->alg_type == 0) ? "" : "de", qp->qp_id, status,
                        sqe->produced);
 
        /* let's output compression head now */
        head_size = add_comp_head(acomp_req->dst, qp_ctx->qp->req_type);
-       if (head_size < 0) {
+       if (unlikely(head_size < 0)) {
                dev_err_ratelimited(dev, "failed to add comp head (%d)!\n",
                                    head_size);
                return head_size;
                return PTR_ERR(req);
 
        ret = hisi_zip_do_work(req, qp_ctx);
-       if (ret != -EINPROGRESS) {
+       if (unlikely(ret != -EINPROGRESS)) {
                dev_info_ratelimited(dev, "failed to do compress (%d)!\n", ret);
                hisi_zip_remove_req(qp_ctx, req);
        }
        int head_size, ret;
 
        head_size = get_comp_head_size(acomp_req, qp_ctx->qp->req_type);
-       if (head_size < 0) {
+       if (unlikely(head_size < 0)) {
                dev_err_ratelimited(dev, "failed to get comp head size (%d)!\n",
                                    head_size);
                return head_size;
                return PTR_ERR(req);
 
        ret = hisi_zip_do_work(req, qp_ctx);
-       if (ret != -EINPROGRESS) {
+       if (unlikely(ret != -EINPROGRESS)) {
                dev_info_ratelimited(dev, "failed to do decompress (%d)!\n",
                                     ret);
                hisi_zip_remove_req(qp_ctx, req);