Rusty Russell
a32a8813d0
lguest: improve interrupt handling, speed up stream networking
...
lguest never checked for pending interrupts when enabling interrupts, and
things still worked. However, it makes a significant difference to TCP
performance, so it's time we fixed it by introducing a pending_irq flag
and checking it on irq_restore and irq_enable.
These two routines are now too big to patch into the 8/10 bytes
patch space, so we drop that code.
Note: The high latency on interrupt delivery had a very curious
effect: once everything else was optimized, networking without GSO was
faster than networking with GSO, since more interrupts were sent and
hence a greater chance of one getting through to the Guest!
Note2: (Almost) Closing the same loophole for iret doesn't have any
measurable effect, so I'm leaving that patch for the moment.
Before:
1GB tcpblast Guest->Host: 30.7 seconds
1GB tcpblast Guest->Host (no GSO): 76.0 seconds
After:
1GB tcpblast Guest->Host: 6.8 seconds
1GB tcpblast Guest->Host (no GSO): 27.8 seconds
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2009-06-12 22:27:03 +09:30
..
2009-06-08 18:57:47 +02:00
2008-10-23 00:01:39 -07:00
2009-04-08 11:51:46 -07:00
2009-02-10 00:41:58 +01:00
2008-10-22 22:55:23 -07:00
2009-02-09 13:33:51 +01:00
2009-02-18 16:48:05 +08:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-04-28 17:42:08 +02:00
2009-05-28 18:23:56 +02:00
2009-05-28 18:10:43 +02:00
2009-06-10 16:15:14 -07:00
2009-05-11 14:37:36 +02:00
2009-01-11 19:13:38 +01:00
2009-01-29 14:16:51 +01:00
2008-10-22 22:55:23 -07:00
2009-04-07 12:02:41 +02:00
2009-01-06 15:59:10 -08:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-13 18:56:30 +01:00
2009-05-11 17:44:39 -07:00
2009-05-11 17:45:06 -07:00
2008-12-16 18:40:32 +01:00
2008-10-22 22:55:23 -07:00
2009-01-14 19:56:50 -08:00
2008-10-22 22:55:23 -07:00
2009-04-02 00:49:02 +02:00
2008-10-22 22:55:23 -07:00
2009-02-03 19:48:18 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2009-06-07 12:22:56 +02:00
2009-01-29 14:17:01 +01:00
2009-06-11 10:03:30 -07:00
2009-03-13 14:49:54 +10:30
2008-10-22 22:55:20 -07:00
2009-01-19 00:38:58 +09:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-04-21 19:39:59 -07:00
2009-01-06 14:06:57 +01:00
2008-10-22 22:55:23 -07:00
2009-04-07 08:31:12 -07:00
2008-10-22 22:55:23 -07:00
2009-03-23 17:20:50 +01:00
2009-01-29 14:16:51 +01:00
2009-04-07 13:36:36 +02:00
2008-11-23 13:20:52 +01:00
2009-03-23 15:02:05 +05:30
2008-10-22 22:55:23 -07:00
2009-03-04 19:20:16 +01:00
2009-02-10 00:42:00 +01:00
2008-11-11 16:19:48 -08:00
2009-06-03 09:53:34 +02:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-04-10 20:27:13 +02:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-03-13 16:57:42 +01:00
2008-10-22 22:55:23 -07:00
2008-11-28 13:06:27 +01:00
2009-02-17 17:52:43 +01:00
2008-10-22 22:55:23 -07:00
2008-10-23 00:20:33 -07:00
2009-04-29 14:47:05 +02:00
2009-03-11 15:47:46 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-06-11 17:55:42 +02:00
2008-10-22 22:55:23 -07:00
2008-11-01 18:57:08 -07:00
2009-06-10 16:15:14 -07:00
2008-10-22 22:55:23 -07:00
2009-04-10 14:35:53 +02:00
2008-10-22 22:55:23 -07:00
2009-03-27 14:43:57 -04:00
2008-12-12 11:58:36 +01:00
2009-03-05 14:17:18 +01:00
2009-02-13 09:46:36 +01:00
2009-02-13 09:46:36 +01:00
2009-05-18 08:38:55 +02:00
2009-04-10 20:27:13 +02:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2009-04-30 19:26:11 +02:00
2009-01-06 14:06:57 +01:00
2008-10-22 22:55:23 -07:00
2009-02-17 17:52:44 +01:00
2009-01-21 17:26:06 +09:00
2009-04-21 09:08:25 +02:00
2009-06-11 17:55:42 +02:00
2009-03-04 20:25:37 +01:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2009-04-15 12:12:36 +02:00
2009-01-14 19:56:50 -08:00
2008-10-22 22:55:23 -07:00
2009-03-10 18:13:25 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-06-10 11:49:00 +03:00
2008-10-22 22:55:23 -07:00
2009-06-10 11:48:54 +03:00
2009-06-10 11:48:23 +03:00
2008-10-22 22:55:23 -07:00
2009-06-12 22:27:03 +09:30
2009-01-03 19:00:55 +01:00
2009-03-11 12:39:28 +01:00
2008-10-22 22:55:23 -07:00
2009-01-29 14:16:51 +01:00
2009-01-29 14:16:51 +01:00
2009-02-10 00:39:14 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-04-22 13:56:25 -07:00
2009-05-12 10:36:44 +02:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-02-10 00:42:00 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-03-01 16:06:56 +09:00
2009-02-18 15:37:55 -08:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2009-01-08 15:37:37 +01:00
2009-05-28 01:59:05 +02:00
2008-10-22 22:55:23 -07:00
2009-03-17 15:38:59 -07:00
2009-05-08 10:43:24 -07:00
2009-06-10 12:18:43 +02:00
2009-01-31 00:17:39 +05:30
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-06-07 16:22:02 +02:00
2008-10-22 22:55:23 -07:00
2009-03-03 13:13:15 +01:00
2009-05-18 09:21:04 +02:00
2008-10-22 22:55:20 -07:00
2009-02-05 22:30:14 +01:00
2008-10-22 22:55:23 -07:00
2009-04-14 11:44:45 +02:00
2009-02-13 13:36:47 +01:00
2009-06-10 16:13:20 -07:00
2009-02-11 14:54:09 -08:00
2009-04-14 11:44:45 +02:00
2009-02-13 13:23:02 +01:00
2008-10-22 22:55:23 -07:00
2009-06-10 16:16:27 -07:00
2008-10-22 22:55:23 -07:00
2009-04-10 13:55:48 +02:00
2009-04-03 13:13:45 +02:00
2008-12-29 18:17:36 +01:00
2008-10-22 22:55:23 -07:00
2009-01-29 14:16:51 +01:00
2009-04-05 10:33:07 -07:00
2009-05-11 08:54:33 -07:00
2009-05-29 09:04:58 +02:00
2009-01-23 18:42:06 +01:00
2009-03-05 14:53:10 +01:00
2009-03-14 17:23:47 -07:00
2009-05-05 19:10:18 -07:00
2009-04-12 15:20:16 +02:00
2009-04-21 10:48:08 +02:00
2009-02-13 11:35:01 -08:00
2009-03-19 14:04:19 +01:00
2009-02-13 11:35:01 -08:00
2009-03-19 14:04:19 +01:00
2009-06-10 16:16:27 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-02-02 23:27:09 +05:30
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2009-06-10 19:53:40 -07:00
2009-01-29 14:17:03 +01:00
2009-02-24 18:23:35 +01:00
2009-06-10 19:53:40 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-18 19:39:18 +01:00
2008-10-22 22:55:23 -07:00
2008-11-12 18:55:46 +01:00
2009-04-08 11:51:46 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-03-02 15:41:30 -08:00
2009-03-02 15:41:30 -08:00
2008-10-22 22:55:20 -07:00
2009-03-14 15:37:14 -07:00
2009-02-10 00:42:01 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-29 14:16:51 +01:00
2009-04-10 14:35:53 +02:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-31 00:18:58 +05:30
2009-04-12 13:08:56 +02:00
2008-12-18 15:01:22 -08:00
2008-10-22 22:55:23 -07:00
2008-12-16 21:10:28 +01:00
2009-05-12 12:22:06 +02:00
2009-01-29 14:16:51 +01:00
2009-02-15 22:43:33 -08:00
2008-10-22 22:55:23 -07:00
2009-05-05 19:10:18 -07:00
2008-10-22 22:55:23 -07:00
2009-05-15 20:07:42 +02:00
2008-10-22 22:55:23 -07:00
2009-02-11 11:33:49 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-04-01 08:59:16 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-06-10 11:48:38 +03:00
2009-01-31 00:19:32 +05:30
2008-12-28 10:04:00 +01:00
2008-10-22 22:55:23 -07:00
2009-03-27 14:43:57 -04:00
2008-10-23 12:38:39 -07:00
2009-04-12 15:20:16 +02:00
2008-10-22 22:55:23 -07:00
2009-03-02 12:07:49 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-06-11 08:50:59 -07:00
2008-10-22 22:55:23 -07:00
2009-04-07 13:34:16 -07:00
2008-10-22 22:55:23 -07:00
2009-03-30 10:10:49 -07:00
2009-01-25 16:57:47 +01:00
2008-10-22 22:55:23 -07:00
2009-05-07 11:17:34 +02:00
2009-05-11 23:57:56 +02:00
2009-01-16 14:19:26 +01:00
2009-06-10 16:16:27 -07:00
2008-11-09 21:05:43 +01:00
2008-10-22 22:55:23 -07:00
2009-03-02 11:06:49 +01:00
2009-03-02 11:06:49 +01:00
2009-02-04 17:28:21 -08:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-04-30 21:16:49 +02:00
2009-04-30 21:16:49 +02:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-03-24 11:02:46 +02:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-12-14 16:24:38 -08:00
2008-11-01 18:58:01 -07:00
2009-06-10 12:27:08 +03:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2009-04-12 13:08:56 +02:00