Salman Qazi
30d697fa3a
x86: fix performance regression in write() syscall
...
While the introduction of __copy_from_user_nocache (see commit:
0812a579c92fefa57506821fa08e90f47cb6dbdd) may have been an improvement
for sufficiently large writes, there is evidence to show that it is
deterimental for small writes. Unixbench's fstime test gives the
following results for 256 byte writes with MAX_BLOCK of 2000:
2.6.29-rc6 ( 5 samples, each in KB/sec ):
283750, 295200, 294500, 293000, 293300
2.6.29-rc6 + this patch (5 samples, each in KB/sec):
313050, 3106750, 293350, 306300, 307900
2.6.18
395700, 342000, 399100, 366050, 359850
See w_test() in src/fstime.c in unixbench version 4.1.0. Basically, the above test
consists of counting how much we can write in this manner:
alarm(10);
while (!sigalarm) {
for (f_blocks = 0; f_blocks < 2000; ++f_blocks) {
write(f, buf, 256);
}
lseek(f, 0L, 0);
}
Note, there are other components to the write syscall regression
that are not addressed here.
Signed-off-by: Salman Qazi <sqazi@google.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
2009-02-24 17:16:36 +01:00
..
2008-10-22 22:55:20 -07:00
2009-02-11 17:17:29 -08:00
2008-10-23 00:01:39 -07:00
2009-02-16 08:55:50 +01: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
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-01-03 14:11:58 +01:00
2008-10-22 22:55:23 -07:00
2009-02-11 11:27:39 +01:00
2009-01-11 19:13:45 +01: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
2008-10-22 22:55:23 -07:00
2009-01-06 15:59:10 -08: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
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -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
2008-10-22 22:55:23 -07: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-01-29 14:17:01 +01:00
2009-02-09 11:15:15 +01:00
2009-01-27 12:56:47 +09:00
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
2008-12-23 22:37:28 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-29 18:19:29 -08: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
2008-12-20 09:15:46 +01:00
2008-11-23 13:20:52 +01:00
2009-01-31 00:16:22 +05:30
2008-10-22 22:55:23 -07:00
2008-12-29 18:17:32 +01:00
2009-02-10 00:42:00 +01:00
2008-11-11 16:19:48 -08:00
2009-01-29 14:17:00 +01: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-02-09 13:33:51 +01:00
2009-02-09 13:33:51 +01:00
2008-10-31 10:12:38 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:20 -07:00
2008-12-17 00:26:38 +01:00
2008-10-22 22:55:23 -07:00
2008-11-28 13:06:27 +01:00
2009-01-29 14:16:49 +01:00
2008-10-22 22:55:23 -07:00
2008-10-23 00:20:33 -07:00
2009-01-23 11:03:32 +09:00
2008-10-31 10:12:38 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-02-09 14:04:56 -08:00
2008-10-22 22:55:23 -07:00
2008-11-01 18:57:08 -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-12-18 15:01:25 -08:00
2008-12-12 11:58:36 +01:00
2008-10-22 22:55:23 -07:00
2009-02-13 09:46:36 +01:00
2009-02-13 09:46:36 +01:00
2009-02-09 14:04:31 -08:00
2009-02-13 21:02:02 +01:00
2008-10-22 22:55:20 -07:00
2008-10-22 22:55:23 -07:00
2008-11-09 10:07:58 -08:00
2008-12-30 16:10:19 -08:00
2008-10-22 22:55:23 -07:00
2009-02-05 22:27:56 +01:00
2009-01-21 17:26:06 +09:00
2008-10-23 00:20:33 -07:00
2009-01-31 04:21:26 +01:00
2009-02-09 12:16:05 +01: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-14 19:56:50 -08:00
2008-10-22 22:55:23 -07:00
2009-02-03 18:29:18 -08: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-01-03 14:11:07 +01:00
2008-10-22 22:55:23 -07:00
2008-12-31 16:55:42 +02:00
2009-01-31 00:16:44 +05:30
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-03 19:00:55 +01:00
2009-02-19 17:12:59 +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-01-31 00:17:13 +05:30
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-02-10 00:42:00 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-11-12 23:28:51 +01: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-01-08 15:37:37 +01:00
2009-02-09 14:04:26 -08:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-21 15:13:53 -08:00
2008-12-28 12:21:10 -08: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
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-02-05 22:30:14 +01:00
2008-10-22 22:55:23 -07:00
2009-02-11 14:54:10 -08:00
2009-02-13 13:36:47 +01:00
2009-02-11 14:54:10 -08:00
2009-02-11 14:54:09 -08:00
2009-02-13 13:09:00 +01:00
2009-02-13 13:23:02 +01:00
2008-10-22 22:55:23 -07:00
2009-02-13 13:09:00 +01:00
2008-10-22 22:55:23 -07:00
2009-01-23 18:07:45 -08:00
2008-10-22 22:55:23 -07:00
2008-12-17 18:58:19 +01: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
2008-12-31 23:05:57 +10:30
2009-02-09 10:30:30 +01:00
2009-01-23 18:42:06 +01:00
2009-02-11 14:54:09 -08:00
2009-02-11 14:54:09 -08:00
2009-02-11 14:54:10 -08:00
2009-02-13 09:46:36 +01:00
2009-02-13 13:24:19 +01:00
2009-02-11 14:54:10 -08:00
2009-02-06 12:26:08 -08:00
2009-02-11 14:54:10 -08:00
2009-02-06 12:31:51 -08:00
2009-02-13 13:15:55 +01: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-02-13 13:09:00 +01:00
2009-01-29 14:17:03 +01:00
2009-01-31 00:18:03 +05:30
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-01-18 19:39:18 +01:00
2008-10-22 22:55:23 -07:00
2008-11-12 18:55:46 +01: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
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
2008-10-22 22:55:20 -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-02-13 21:05:03 +01: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-01-31 00:18:30 +05:30
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-01-29 14:16:42 +01:00
2009-01-29 14:16:51 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2008-12-16 19:31:52 +01:00
2008-10-22 22:55:23 -07:00
2009-02-13 09:44:22 +01: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
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-12-31 16:52:28 +02: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
2008-12-29 13:18:40 +01:00
2008-10-23 12:38:39 -07:00
2009-02-13 21:05:03 +01:00
2008-10-22 22:55:23 -07:00
2009-02-13 09:45:09 +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
2009-02-10 00:40:48 +01:00
2008-10-22 22:55:23 -07:00
2008-10-22 22:55:23 -07:00
2009-01-25 16:57:47 +01:00
2008-10-22 22:55:23 -07:00
2009-01-19 00:38:57 +09:00
2009-01-27 12:56:47 +09:00
2009-01-16 14:19:26 +01:00
2009-02-11 12:40:44 +01:00
2008-11-09 21:05:43 +01:00
2008-10-22 22:55:23 -07:00
2008-10-28 16:54:49 +01:00
2009-02-24 17:16:36 +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
2008-10-22 22:55:23 -07:00
2008-11-19 18:49:57 -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
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
2008-10-22 22:55:20 -07:00
2008-12-31 16:52:30 +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
2008-12-31 16:52:28 +02:00
2009-01-31 04:21:21 +01: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:20 -07:00