diff options
author | Tariq Saeed <tariq.x.saeed@oracle.com> | 2014-04-03 14:47:11 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-04-03 16:20:56 -0700 |
commit | da8ded405de74de4b189d1128f4c102d06328c29 (patch) | |
tree | f89ec00e4c725703aeba00e741f9e5203b9b7594 /fs/ramfs/inode.c | |
parent | db66c71577d525c0cd65e66ff675747565783ba4 (diff) | |
download | op-kernel-dev-da8ded405de74de4b189d1128f4c102d06328c29.zip op-kernel-dev-da8ded405de74de4b189d1128f4c102d06328c29.tar.gz |
ocfs2/o2net: o2net_listen_data_ready should do nothing if socket state is not TCP_LISTEN
Orabug: 17330860
When accepting an incomming connection o2net_accept_one clones a child
data socket from the parent listening socket. It then proceeds to setup
the child with callback o2net_data_ready() and sk_user_data to NULL. If
data arrives in this window, o2net_listen_data_ready will be called with
some non-deterministic value in sk_user_data (not inherited). We panic
when we page fault on sk_user_data -- in parent it is
sock_def_readable().
The fix is to recognize that this is a data socket being set up by
looking at the socket state and do nothing.
Signed-off-by: Tariq Saseed <tariq.x.saeed@oracle.com>
Signed-off-by: Srinivas Eeda <srinivas.eeda@oracle.com>
Reviewed-by: Mark Fasheh <mfasheh@suse.com>
Cc: Joel Becker <jlbec@evilplan.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/ramfs/inode.c')
0 files changed, 0 insertions, 0 deletions