]> git.baikalelectronics.ru Git - kernel.git/commitdiff
afs: Fix unpinned address list during probing
authorDavid Howells <dhowells@redhat.com>
Thu, 26 Mar 2020 15:24:07 +0000 (15:24 +0000)
committerLinus Torvalds <torvalds@linux-foundation.org>
Thu, 26 Mar 2020 23:04:29 +0000 (16:04 -0700)
When it's probing all of a fileserver's interfaces to find which one is
best to use, afs_do_probe_fileserver() takes a lock on the server record
and notes the pointer to the address list.

It doesn't, however, pin the address list, so as soon as it drops the
lock, there's nothing to stop the address list from being freed under
us.

Fix this by taking a ref on the address list inside the locked section
and dropping it at the end of the function.

Fixes: cacf55ead0eb ("afs: Probe multiple fileservers simultaneously")
Signed-off-by: David Howells <dhowells@redhat.com>
Reviewed-by: Marc Dionne <marc.dionne@auristor.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/afs/fs_probe.c

index cfe62b154f68dde9d528ed0806b08cc8d64b235a..e1b9ed679045de54dfbfb857a9bb17d24c28f301 100644 (file)
@@ -145,6 +145,7 @@ static int afs_do_probe_fileserver(struct afs_net *net,
        read_lock(&server->fs_lock);
        ac.alist = rcu_dereference_protected(server->addresses,
                                             lockdep_is_held(&server->fs_lock));
+       afs_get_addrlist(ac.alist);
        read_unlock(&server->fs_lock);
 
        atomic_set(&server->probe_outstanding, ac.alist->nr_addrs);
@@ -163,6 +164,7 @@ static int afs_do_probe_fileserver(struct afs_net *net,
 
        if (!in_progress)
                afs_fs_probe_done(server);
+       afs_put_addrlist(ac.alist);
        return in_progress;
 }