From: NeilBrown Date: Mon, 30 Oct 2017 04:59:27 +0000 (+1100) Subject: staging: lustre: simplfy lov_finish_set() X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=dff162689a4061ff30d3a05f9d790e375c06ab8f;p=openwrt%2Fstaging%2Fblogic.git staging: lustre: simplfy lov_finish_set() When deleting everything from a list, a while loop is cleaner than list_for_each_safe(). Signed-off-by: NeilBrown Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/lustre/lustre/lov/lov_request.c b/drivers/staging/lustre/lustre/lov/lov_request.c index 3bdf48e4edb4..cfa1d7f92b0f 100644 --- a/drivers/staging/lustre/lustre/lov/lov_request.c +++ b/drivers/staging/lustre/lustre/lov/lov_request.c @@ -49,15 +49,13 @@ static void lov_init_set(struct lov_request_set *set) static void lov_finish_set(struct lov_request_set *set) { - struct list_head *pos, *n; + struct lov_request *req; LASSERT(set); - list_for_each_safe(pos, n, &set->set_list) { - struct lov_request *req = list_entry(pos, - struct lov_request, - rq_link); + while ((req = list_first_entry_or_null(&set->set_list, + struct lov_request, + rq_link)) != NULL) { list_del_init(&req->rq_link); - kfree(req->rq_oi.oi_osfs); kfree(req); }