afs: Fix use of BUG()
authorDavid Howells <dhowells@redhat.com>
Tue, 9 Jun 2020 15:15:45 +0000 (16:15 +0100)
committerDavid Howells <dhowells@redhat.com>
Tue, 9 Jun 2020 16:21:03 +0000 (17:21 +0100)
Fix afs_compare_addrs() to use WARN_ON(1) instead of BUG() and return 1
(ie. srx_a > srx_b).

There's no point trying to put actual error handling in as this should not
occur unless a new transport address type is allowed by AFS.  And even if
it does, in this particular case, it'll just never match unknown types of
addresses.  This BUG() was more of a 'you need to add a case here'
indicator.

Reported-by: Kees Cook <keescook@chromium.org>
Signed-off-by: David Howells <dhowells@redhat.com>
Reviewed-by: Kees Cook <keescook@chromium.org>
fs/afs/vl_alias.c

index 093895c49c2198c9e5118bf0a59a466d6ebbeac1..136fc6164e0092236d38140eef7e3de34991ef8a 100644 (file)
@@ -73,7 +73,8 @@ static int afs_compare_addrs(const struct sockaddr_rxrpc *srx_a,
        }
 
        default:
-               BUG();
+               WARN_ON(1);
+               diff = 1;
        }
 
 out: