Michael S. Tsirkin
0110d6f22f
tun: orphan an skb on tx
...
The following situation was observed in the field:
tap1 sends packets, tap2 does not consume them, as a result
tap1 can not be closed. This happens because
tun/tap devices can hang on to skbs undefinitely.
As noted by Herbert, possible solutions include a timeout followed by a
copy/change of ownership of the skb, or always copying/changing
ownership if we're going into a hostile device.
This patch implements the second approach.
Note: one issue still remaining is that since skbs
keep reference to tun socket and tun socket has a
reference to tun device, we won't flush backlog,
instead simply waiting for all skbs to get transmitted.
At least this is not user-triggerable, and
this was not reported in practice, my assumption is
other devices besides tap complete an skb
within finite time after it has been queued.
A possible solution for the second issue
would not to have socket reference the device,
instead, implement dev->destructor for tun, and
wait for all skbs to complete there, but this
needs some thought, probably too risky for 2.6.34.
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Tested-by: Yan Vugenfirer <yvugenfi@redhat.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2010-04-14 04:52:03 -07:00
..
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-06 08:34:06 -07:00
2010-04-01 17:26:01 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-01 19:29:16 -07:00
2010-03-27 08:33:22 -07:00
2010-04-13 03:03:13 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-13 03:03:12 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-22 15:45:52 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-11 02:44:30 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-13 03:03:16 -07:00
2010-03-30 22:02:32 +09:00
2010-04-11 02:44:30 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-11 02:44:30 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-26 02:07:31 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-04-11 02:44:30 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-09-01 01:13:50 -07:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-18 14:47:48 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-09-01 01:14:07 -07:00
2009-09-01 01:14:07 -07:00
2009-09-01 01:14:07 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-03-27 00:46:54 -07:00
2010-03-30 22:02:32 +09:00
2009-09-01 01:14:07 -07:00
2010-03-30 22:02:32 +09:00
2010-02-22 15:45:51 -08:00
2010-03-30 22:02:32 +09:00
2009-12-04 15:39:55 +01:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-28 19:23:06 -08:00
2010-02-27 12:53:02 +01:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-06-15 03:02:23 -07:00
2010-03-30 22:02:32 +09:00
2009-09-17 20:07:53 +02:00
2010-02-22 15:45:51 -08:00
2010-03-30 22:02:32 +09:00
2009-04-04 16:51:14 -07:00
2010-03-23 23:19:56 -07:00
2010-02-16 15:19:03 -08:00
2009-08-12 23:03:00 -07:00
2010-02-17 13:35:44 -08:00
2009-04-27 03:27:43 -07:00
2010-02-17 13:35:44 -08:00
2010-02-17 13:35:44 -08:00
2009-08-12 23:02:59 -07:00
2010-02-17 17:45:20 -08:00
2009-11-05 20:00:29 -08:00
2010-03-15 15:47:01 -07:00
2009-12-09 19:43:33 -08:00
2010-02-17 17:45:20 -08:00
2010-03-03 01:04:39 -08:00
2010-02-26 02:10:14 -08:00
2010-02-26 02:10:14 -08:00
2010-04-07 20:53:54 -07:00
2010-02-26 02:10:14 -08:00
2010-03-07 15:25:53 -08:00
2010-03-30 22:02:32 +09:00
2010-03-15 16:23:54 -07:00
2009-07-05 19:16:04 -07:00
2010-02-12 11:38:58 -08:00
2010-02-17 13:27:12 -08:00
2010-02-17 13:27:12 -08:00
2010-02-18 14:47:47 -08:00
2010-02-17 13:27:12 -08:00
2010-01-07 23:54:26 -08:00
2010-03-30 22:02:32 +09:00
2009-11-11 19:22:21 -08:00
2009-09-01 01:14:07 -07:00
2009-09-01 01:13:40 -07:00
2010-03-15 15:23:30 -07:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-22 15:45:52 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-22 15:45:52 -08:00
2009-07-06 18:56:11 -07:00
2010-04-13 18:49:51 -07:00
2009-12-30 22:03:43 -08:00
2009-11-02 23:40:57 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 23:03:18 -07:00
2010-03-26 20:16:23 -07:00
2010-03-30 22:02:32 +09:00
2010-02-17 15:59:40 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-11-20 15:35:04 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-06-12 18:01:46 +02:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-18 21:14:00 -07:00
2010-04-01 19:29:17 -07:00
2010-02-26 02:07:30 -08:00
2009-10-13 11:48:18 -07:00
2010-03-30 22:02:32 +09:00
2010-03-18 21:08:48 -07:00
2009-10-20 19:11:06 -07:00
2010-03-30 22:02:32 +09:00
2010-02-12 11:38:58 -08:00
2010-03-30 22:02:32 +09:00
2010-02-26 02:07:30 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-04-27 02:53:52 -07:00
2010-02-16 23:05:38 -08:00
2010-02-26 02:07:30 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-26 02:07:30 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-03 20:20:33 -08:00
2010-03-30 22:02:32 +09:00
2010-04-01 19:29:17 -07:00
2009-10-12 23:59:08 -07:00
2010-01-28 06:01:35 -08:00
2009-09-03 20:02:11 -07:00
2009-11-18 23:29:17 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-26 02:07:30 -08:00
2010-03-30 22:02:32 +09:00
2010-01-07 23:54:26 -08:00
2009-05-01 15:21:55 -07:00
2010-03-16 14:15:42 -07:00
2010-03-30 22:02:32 +09:00
2009-11-18 23:29:17 -08:00
2010-03-30 22:02:32 +09:00
2010-02-12 11:38:58 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-06-12 18:01:45 +02:00
2010-03-30 22:02:32 +09:00
2009-10-12 13:26:39 -07:00
2010-03-30 22:02:32 +09:00
2009-04-27 02:53:49 -07:00
2010-02-26 02:07:30 -08:00
2010-02-26 02:07:30 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2010-03-16 14:15:44 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-12-02 00:52:31 -08:00
2010-03-30 22:02:32 +09:00
2009-11-09 09:40:57 +01:00
2010-01-18 00:29:19 -08:00
2010-04-11 02:44:30 -07:00
2010-04-01 19:33:04 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-09-01 01:14:07 -07:00
2009-04-29 17:32:34 -07:00
2010-03-30 22:02:32 +09:00
2009-08-30 22:35:11 -07:00
2009-12-03 13:18:01 -08:00
2010-03-30 22:02:32 +09:00
2010-02-18 14:47:49 -08:00
2010-02-18 14:47:49 -08:00
2010-03-30 22:02:32 +09:00
2010-04-06 08:34:06 -07:00
2010-03-30 22:02:32 +09:00
2009-10-13 03:44:05 -07:00
2010-03-30 22:02:32 +09:00
2010-02-18 14:47:49 -08:00
2010-03-30 22:02:32 +09:00
2009-10-01 15:14:54 -07:00
2010-03-30 22:02:32 +09:00
2010-02-12 16:21:01 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-10 07:37:06 -08:00
2010-03-30 22:02:32 +09:00
2010-02-15 09:27:02 -08:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2009-03-27 00:46:47 -07:00
2009-03-27 00:46:48 -07:00
2010-03-30 22:02:32 +09:00
2009-12-04 15:39:55 +01:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-02-18 14:47:49 -08:00
2010-03-30 22:02:32 +09:00
2010-02-26 02:07:31 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-12-03 13:18:01 -08:00
2010-02-18 14:47:49 -08:00
2010-03-30 22:02:32 +09:00
2010-02-18 14:47:49 -08:00
2010-02-18 14:47:49 -08:00
2010-02-26 02:08:42 -08:00
2010-03-08 16:55:37 +01:00
2010-03-30 22:02:32 +09:00
2010-03-13 12:22:16 -08:00
2010-02-17 17:27:40 -08:00
2010-02-26 02:07:31 -08:00
2010-01-13 20:37:01 -08:00
2010-03-30 22:02:32 +09:00
2010-04-14 04:52:03 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-08 16:55:37 +01:00
2010-01-06 20:32:38 -08:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-25 11:56:32 -07:00
2009-11-26 15:51:29 -08:00
2010-04-12 22:00:34 -07:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2010-03-30 22:02:32 +09:00
2009-08-09 21:46:53 -07:00