Message ID | 20160831123911.3467676-2-arnd@arndb.de |
---|---|
State | New |
Headers | show |
Series | [1/2] NFSv4.1: work around -Wmaybe-uninitialized warning | expand |
diff --git a/net/rxrpc/call_object.c b/net/rxrpc/call_object.c index 104ee8b1de06..2daec1eaec6f 100644 --- a/net/rxrpc/call_object.c +++ b/net/rxrpc/call_object.c @@ -595,6 +595,8 @@ static void rxrpc_mark_call_released(struct rxrpc_call *call) sched = __rxrpc_abort_call(call, RX_CALL_DEAD, ECONNRESET); if (!test_and_set_bit(RXRPC_CALL_EV_RELEASE, &call->events)) sched = true; + } else { + sched = 0; } write_unlock(&call->state_lock); if (sched)
gcc -Wmaybe-initialized correctly points out a newly introduced bug through which we can end up calling rxrpc_queue_call() for a dead connection: net/rxrpc/call_object.c: In function 'rxrpc_mark_call_released': net/rxrpc/call_object.c:600:5: error: 'sched' may be used uninitialized in this function [-Werror=maybe-uninitialized] This sets the 'sched' variable to zero to restore the previous behavior. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Fixes: f5c17aaeb2ae ("rxrpc: Calls should only have one terminal state") --- net/rxrpc/call_object.c | 2 ++ 1 file changed, 2 insertions(+) -- 2.9.0