Searched hist:d523a328fb0271e1a763e985a21f2488fd816e7e (Results 1 – 1 of 1) sorted by relevance
/openbmc/linux/net/ipv4/ |
H A D | inet_diag.c | diff 8cf8e5a67fb07f583aac94482ba51a7930dab493 Mon Jan 28 22:52:12 CST 2008 Arnaldo Carvalho de Melo <acme@redhat.com> [INET_DIAG]: Fix inet_diag_lock_handler error path.
Fixes: http://bugzilla.kernel.org/show_bug.cgi?id=9825
The inet_diag_lock_handler function uses ERR_PTR to encode errors but its callers were testing against NULL.
This only happens when the only inet_diag modular user, DCCP, is not built into the kernel or available as a module.
Also there was a problem with not dropping the mutex lock when a handler was not found, also fixed in this patch.
This caused an OOPS and ss would then hang on subsequent calls, as &inet_diag_table_mutex was being left locked.
Thanks to spike at ml.yaroslavl.ru for report it after trying 'ss -d' on a kernel that doesn't have DCCP available.
This bug was introduced in cset d523a328fb0271e1a763e985a21f2488fd816e7e ("Fix inet_diag dead-lock regression"), after 2.6.24-rc3, so just 2.6.24 seems to be affected.
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Acked-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net> diff d523a328fb0271e1a763e985a21f2488fd816e7e Sun Dec 02 22:51:25 CST 2007 Herbert Xu <herbert@gondor.apana.org.au> [INET]: Fix inet_diag dead-lock regression
The inet_diag register fix broke inet_diag module loading because the loaded module had to take the same mutex that's already held by the loader in order to register the new handler.
This patch fixes it by introducing a separate mutex to protect the handling of handlers.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
|