RE: [PATCH] ocfs2: fix check if list iterator did find an element

From: David Laight
Date: Mon Mar 21 2022 - 12:00:21 EST


From: Dan Carpenter
> Sent: 21 March 2022 13:55
> On Mon, Mar 21, 2022 at 02:34:34PM +0100, Jakob Koschel wrote:
> > >> @@ -556,11 +556,11 @@ static void *lockres_seq_start(struct seq_file *m, loff_t *pos)
> > >> }
> > >> }
> > >>
> > >> - list_for_each_entry(res, track_list, tracking) {
> > >> - if (&res->tracking == &dlm->tracking_list)
> > >> - res = NULL;
> > >> - else
> > >> - dlm_lockres_get(res);
> > >> + list_for_each_entry(iter, track_list, tracking) {
> > >> + if (&iter->tracking != &dlm->tracking_list) {
>
> This is an open coded version of:
>
> if (!list_entry_is_head(iter, &dlm->tracking_list, tracking)) {

Doesn't list_for_each_entry() terminate before that happens?
So this code is probably still horribly broken.

My worry about bugs with these lists isn't really the code
that uses list_for_each_entry() - they are fairly easy to
locate, read and fix.
The problem is all the other code that is scanning these
list in other more obscure ways.

It really isn't a list structure that is easy to use at all.
It's only slight advantage is that you can unlink an item
without knowing the list head.
(Which can stop buggy code generating cross-linked lists.)

Unless you actually need to traverse backwards the 'back
pointer points to forwards pointer' list is much better.
Even if you have to maintain a 'pointer to last' to get
FIFO operation.

The other option is to double-link the items into a loop and
have a 'head' that points to the first item.

Both these loops have 'pointer to items' to don't need
container_of() and get better type checking from the compiler.

David

>
> Ideally someone would come through with enough confidence to just delete
> it but the second best option is to just make it readable...
>
> regards,
> dan carpenter
>
> > >> + dlm_lockres_get(iter);
> > >> + res = iter;
> > >> + }
> > >> break;
> > >> }

-
Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK
Registration No: 1397386 (Wales)