]> git.baikalelectronics.ru Git - kernel.git/commit
afs: Remote abort can cause BUG in rxrpc code
authorAnton Blanchard <anton@samba.org>
Fri, 16 Mar 2012 10:28:19 +0000 (10:28 +0000)
committerLinus Torvalds <torvalds@linux-foundation.org>
Sat, 17 Mar 2012 00:01:41 +0000 (17:01 -0700)
commit9a48b699d084f36a8a4473502e82270ea0a2e81c
tree6e63b069354fdf8c9a21f1560da8720d32149a80
parent01e6fabcc475fa0b4c16252b7588b4a7ec3f9ef3
afs: Remote abort can cause BUG in rxrpc code

When writing files to afs I sometimes hit a BUG:

kernel BUG at fs/afs/rxrpc.c:179!

With a backtrace of:

afs_free_call
afs_make_call
afs_fs_store_data
afs_vnode_store_data
afs_write_back_from_locked_page
afs_writepages_region
afs_writepages

The cause is:

ASSERT(skb_queue_empty(&call->rx_queue));

Looking at a tcpdump of the session the abort happens because we
are exceeding our disk quota:

rx abort fs reply store-data error diskquota exceeded (32)

So the abort error is valid. We hit the BUG because we haven't
freed all the resources for the call.

By freeing any skbs in call->rx_queue before calling afs_free_call
we avoid hitting leaking memory and avoid hitting the BUG.

Signed-off-by: Anton Blanchard <anton@samba.org>
Signed-off-by: David Howells <dhowells@redhat.com>
Cc: <stable@kernel.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/afs/rxrpc.c