namespace.c: Don't reinvent the wheel but use existing llist API
authorByungchul Park <byungchul.park@lge.com>
Mon, 7 Aug 2017 08:44:45 +0000 (17:44 +0900)
committerAl Viro <viro@zeniv.linux.org.uk>
Mon, 28 Aug 2017 04:50:22 +0000 (00:50 -0400)
Although llist provides proper APIs, they are not used. Make them used.

Signed-off-by: Byungchul Park <byungchul.park@lge.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/namespace.c

index f8893dc6a989dc6c9b0f4e8daba2e985a64976e6..ce82a5b2da12e6982c41f5da8b08b9f29aa99708 100644 (file)
@@ -1124,12 +1124,10 @@ static LLIST_HEAD(delayed_mntput_list);
 static void delayed_mntput(struct work_struct *unused)
 {
        struct llist_node *node = llist_del_all(&delayed_mntput_list);
-       struct llist_node *next;
+       struct mount *m, *t;
 
-       for (; node; node = next) {
-               next = llist_next(node);
-               cleanup_mnt(llist_entry(node, struct mount, mnt_llist));
-       }
+       llist_for_each_entry_safe(m, t, node, mnt_llist)
+               cleanup_mnt(m);
 }
 static DECLARE_DELAYED_WORK(delayed_mntput_work, delayed_mntput);