aboutsummaryrefslogtreecommitdiffstats
path: root/net/atm/protocols.h
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2009-08-06 10:22:44 -0400
committerDavid S. Miller <davem@davemloft.net>2009-08-10 00:45:35 -0400
commit876bfd4d0f18cd1f698249870c7e7fb944de1c26 (patch)
tree62959754494fb97f48d7c4f811d913321b046554 /net/atm/protocols.h
parent9555b31e8c29d2000e1e1f569f6f242ebd596e47 (diff)
tun: Extend RTNL lock coverage over whole ioctl
As it is, parts of the ioctl runs under the RTNL and parts of it do not. The unlocked section is still protected by the BKL, but there can be subtle races. For example, Eric Biederman and Paul Moore observed that if two threads tried to create two tun devices on the same file descriptor, then unexpected results may occur. As there isn't anything in the ioctl that is expected to sleep indefinitely, we can prevent this from occurring by extending the RTNL lock coverage. This also allows to get rid of the BKL. Finally, I changed tun_get_iff to take a tun device in order to avoid calling tun_put which would dead-lock as it also tries to take the RTNL lock. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/atm/protocols.h')
0 files changed, 0 insertions, 0 deletions