|
@@ -664,7 +664,7 @@ void af_alg_free_areq_sgls(struct af_alg_async_req *areq)
|
|
unsigned int i;
|
|
unsigned int i;
|
|
|
|
|
|
list_for_each_entry_safe(rsgl, tmp, &areq->rsgl_list, list) {
|
|
list_for_each_entry_safe(rsgl, tmp, &areq->rsgl_list, list) {
|
|
- ctx->rcvused -= rsgl->sg_num_bytes;
|
|
|
|
|
|
+ atomic_sub(rsgl->sg_num_bytes, &ctx->rcvused);
|
|
af_alg_free_sg(&rsgl->sgl);
|
|
af_alg_free_sg(&rsgl->sgl);
|
|
list_del(&rsgl->list);
|
|
list_del(&rsgl->list);
|
|
if (rsgl != &areq->first_rsgl)
|
|
if (rsgl != &areq->first_rsgl)
|
|
@@ -1162,7 +1162,7 @@ int af_alg_get_rsgl(struct sock *sk, struct msghdr *msg, int flags,
|
|
|
|
|
|
areq->last_rsgl = rsgl;
|
|
areq->last_rsgl = rsgl;
|
|
len += err;
|
|
len += err;
|
|
- ctx->rcvused += err;
|
|
|
|
|
|
+ atomic_add(err, &ctx->rcvused);
|
|
rsgl->sg_num_bytes = err;
|
|
rsgl->sg_num_bytes = err;
|
|
iov_iter_advance(&msg->msg_iter, err);
|
|
iov_iter_advance(&msg->msg_iter, err);
|
|
}
|
|
}
|