KAMEZAWA Hiroyuki
1ac101a5d6
procfs: add num_to_str() to speed up /proc/stat
...
== stat_check.py
num = 0
with open("/proc/stat") as f:
while num < 1000 :
data = f.read()
f.seek(0, 0)
num = num + 1
==
perf shows
20.39% stat_check.py [kernel.kallsyms] [k] format_decode
13.41% stat_check.py [kernel.kallsyms] [k] number
12.61% stat_check.py [kernel.kallsyms] [k] vsnprintf
10.85% stat_check.py [kernel.kallsyms] [k] memcpy
4.85% stat_check.py [kernel.kallsyms] [k] radix_tree_lookup
4.43% stat_check.py [kernel.kallsyms] [k] seq_printf
This patch removes most of calls to vsnprintf() by adding num_to_str()
and seq_print_decimal_ull(), which prints decimal numbers without rich
functions provided by printf().
On my 8cpu box.
== Before patch ==
[root@bluextal test]# time ./stat_check.py
real 0m0.150s
user 0m0.026s
sys 0m0.121s
== After patch ==
[root@bluextal test]# time ./stat_check.py
real 0m0.055s
user 0m0.022s
sys 0m0.030s
[akpm@linux-foundation.org: remove incorrect comment, use less statck in num_to_str(), move comment from .h to .c, simplify seq_put_decimal_ull()]
[andrea@betterlinux.com: avoid breaking the ABI in /proc/stat]
Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Signed-off-by: Andrea Righi <andrea@betterlinux.com>
Cc: Eric Dumazet <eric.dumazet@gmail.com>
Cc: Glauber Costa <glommer@parallels.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Paul Turner <pjt@google.com>
Cc: Russell King <rmk@arm.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2012-03-23 16:58:42 -07:00
..
2012-03-21 10:32:00 -07:00
2012-03-06 15:16:18 -05:00
2012-02-03 01:21:25 +01:00
2011-11-11 09:50:19 -08:00
2012-01-04 17:30:20 -02:00
2012-03-22 13:08:22 -07:00
2012-03-17 12:20:44 -07:00
2012-02-15 00:19:48 -05:00
2012-03-22 20:20:18 -07:00
2012-03-21 10:33:42 -07:00
2012-03-23 16:58:31 -07:00
2012-02-04 07:17:47 -08:00
2012-03-07 17:41:28 +01:00
2012-02-21 13:29:06 +01:00
2012-03-07 17:40:56 +01:00
2012-03-07 17:40:49 +01:00
2012-03-12 22:49:02 +01:00
2012-03-22 20:20:18 -07:00
2012-01-06 05:22:21 +04:00
2012-03-13 11:21:23 +11:00
2012-03-18 21:39:19 +00:00
2012-03-15 03:41:01 -06:00
2012-03-05 15:20:49 -05:00
2012-03-21 09:31:31 -04:00
2012-03-15 12:42:07 -07:00
2011-10-31 19:32:32 -04:00
2011-12-13 15:07:49 +00:00
2012-01-17 04:35:20 -05:00
2012-01-18 15:51:48 -08:00
2012-01-08 19:14:59 -05:00
2011-11-02 16:07:03 -07:00
2012-02-09 09:04:23 -08:00
2011-12-15 11:15:39 +01:00
2011-12-13 18:46:56 -05:00
2011-11-26 16:40:30 -05:00
2012-03-07 17:06:08 +11:00
2012-03-20 21:29:40 -04:00
2011-10-31 00:33:36 +08:00
2012-03-20 21:29:46 -04:00
2012-03-20 21:48:21 +08:00
2012-03-23 16:58:34 -07:00
2012-02-07 07:51:30 +01:00
2011-10-31 17:30:54 -07:00
2012-01-14 18:36:33 -08:00
2012-02-08 20:03:14 +01:00
2011-11-22 15:22:23 -05:00
2012-03-21 17:55:01 -07:00
2012-01-23 16:06:37 -05:00
2011-12-28 21:25:35 +08:00
2012-02-01 18:37:39 -08:00
2012-03-21 17:54:56 -07:00
2012-02-26 09:44:55 -08:00
2012-01-10 16:30:42 -08:00
2012-03-23 16:58:36 -07:00
2012-02-28 16:02:54 +01:00
2012-01-03 22:54:57 -05:00
2012-02-02 15:30:47 -08:00
2012-01-13 09:32:20 +10:30
2011-10-29 21:20:22 +02:00
2012-01-26 16:49:08 -08:00
2012-01-18 15:51:48 -08:00
2012-03-21 17:54:59 -07:00
2012-01-12 20:13:11 -08:00
2012-03-23 16:58:38 -07:00
2012-01-05 18:52:59 -05:00
2012-01-26 13:35:49 +11:00
2011-12-13 09:26:45 +00:00
2012-03-20 21:29:37 -04:00
2012-03-03 09:02:52 -07:00
2012-03-20 21:29:53 -04:00
2011-11-23 18:49:22 +01:00
2012-03-17 21:51:34 +01:00
2011-10-31 19:32:26 -04:00
2011-10-31 20:19:04 +00:00
2012-03-21 18:55:10 -07:00
2012-02-20 19:46:36 +11:00
2012-01-04 08:56:31 -06:00
2011-10-31 20:19:04 +00:00
2011-10-31 20:18:58 +00:00
2011-10-31 20:21:24 +00:00
2011-12-16 08:49:57 -08:00
2012-01-06 10:20:21 +00:00
2011-11-06 17:12:03 -08:00
2011-12-23 21:33:15 +05:30
2011-10-31 17:30:44 -07:00
2012-01-24 12:48:54 -08:00
2011-11-29 12:46:19 -05:00
2011-12-14 15:21:07 -08:00
2011-11-26 14:59:39 -05:00
2012-02-23 18:54:51 -08:00
2012-02-08 09:19:42 +01:00
2011-12-12 13:54:36 +00:00
2012-03-08 11:53:13 -08:00
2011-12-11 18:25:16 -05:00
2012-02-13 00:46:41 -05:00
2012-03-01 16:41:26 -05:00
2012-01-12 20:13:04 -08:00
2011-10-31 09:20:11 -04:00
2012-01-03 22:54:58 -05:00
2012-03-15 13:35:22 +00:00
2012-03-20 21:29:32 -04:00
2012-03-18 22:15:39 +01:00
2012-03-18 22:15:39 +01:00
2011-10-31 19:32:32 -04:00
2012-01-29 20:35:52 +01:00
2012-03-20 21:29:41 -04:00
2011-10-31 17:30:54 -07:00
2012-02-21 11:08:29 -05:00
2012-02-21 11:08:30 -05:00
2011-12-13 11:58:49 +01:00
2011-11-06 19:44:47 -08:00
2011-12-03 09:35:08 -08:00
2012-03-02 10:38:33 +01:00
2012-01-10 16:30:43 -08:00
2012-02-28 17:10:21 +00:00
2012-02-01 09:13:11 -08:00
2011-11-15 19:08:27 +08:00
2011-12-11 10:31:24 -08:00
2012-01-09 11:24:59 +01:00
2012-03-20 21:48:30 +08:00
2012-03-21 17:55:02 -07:00
2012-03-21 17:54:59 -07:00
2011-11-08 09:28:27 +02:00
2012-03-16 13:36:04 -07:00
2012-02-29 20:47:42 +01:00
2011-10-29 09:37:09 +01:00
2012-01-06 11:42:52 -08:00
2012-01-03 22:54:56 -05:00
2011-12-13 15:30:40 -05:00
2011-12-05 18:27:56 -05:00
2012-02-21 16:56:45 -05:00
2012-03-04 20:41:38 -05:00
2012-01-24 15:51:00 -05:00
2012-03-19 16:53:08 -04:00
2012-02-24 01:37:35 -08:00
2012-02-08 15:52:45 -05:00
2012-02-08 15:52:45 -05:00
2012-01-11 12:56:06 -08:00
2012-03-16 23:00:20 -07:00
2012-03-21 17:54:59 -07:00
2012-01-13 09:32:18 +10:30
2012-03-09 10:56:35 -08:00
2012-02-03 09:48:19 -05:00
2012-02-15 09:45:53 +01:00
2012-01-09 13:06:28 +01:00
2012-01-03 22:55:17 -05:00
2011-10-31 19:32:32 -04:00
2011-10-31 19:32:32 -04:00
2012-02-13 00:46:41 -05:00
2011-10-31 19:32:35 -04:00
2011-10-31 19:32:35 -04:00
2012-02-26 16:48:06 -07:00
2012-01-03 22:54:55 -05:00
2011-12-13 09:26:45 +00:00
2012-03-04 20:41:38 -05:00
2011-12-28 17:46:46 -05:00
2012-01-09 13:52:09 +01:00
2012-02-28 20:01:08 +01:00
2011-10-31 17:30:54 -07:00
2012-03-08 10:50:35 -08:00
2012-03-04 20:41:38 -05:00
2011-10-31 17:30:54 -07:00
2011-12-06 09:06:38 +01:00
2012-03-21 17:54:57 -07:00
2012-03-23 16:58:42 -07:00
2012-01-23 08:38:48 -08:00
2011-11-17 09:35:32 +11:00
2012-03-23 08:53:47 -07:00
2012-03-08 10:50:35 -08:00
2011-12-02 16:12:42 +00:00
2012-03-23 16:58:41 -07:00
2012-03-05 15:49:42 -08:00
2011-12-21 15:13:54 -08:00
2012-01-17 15:40:51 -08:00
2011-11-21 12:32:23 -08:00
2011-12-27 11:24:29 +02:00
2011-12-27 11:26:41 +02:00
2011-12-26 13:27:44 +02:00
2011-11-17 12:20:19 +01:00
2012-03-23 16:58:35 -07:00
2012-03-23 16:58:34 -07:00
2012-01-10 16:30:49 -08:00
2011-12-22 02:02:20 -05:00
2012-02-29 15:35:41 -06:00
2012-01-12 20:13:03 -08:00
2011-10-31 17:30:52 -07:00
2011-10-31 17:30:57 -07:00
2011-11-14 13:35:16 +01:00
2011-12-12 22:06:55 -08:00
2011-11-04 17:22:14 -07:00
2012-03-23 16:58:33 -07:00
2012-02-02 15:43:40 -08:00
2012-03-23 16:58:31 -07:00
2012-03-15 21:41:34 +01:00
2011-12-13 18:46:55 -05:00
2011-11-15 16:56:17 -05:00
2011-11-15 16:56:17 -05:00
2012-03-03 15:04:45 -05:00
2011-12-08 10:22:09 -08:00
2012-03-21 17:55:02 -07:00
2011-12-21 14:48:43 -08:00
2012-01-10 16:30:45 -08:00
2012-01-23 08:38:47 -08:00
2012-03-21 17:54:57 -07:00
2011-11-21 15:27:19 -05:00
2012-01-13 10:12:23 -08:00
2012-01-12 20:13:10 -08:00
2012-01-12 20:13:03 -08:00
2012-03-23 16:58:42 -07:00
2011-10-31 17:30:54 -07:00
2012-03-21 17:54:56 -07:00
2012-01-03 22:57:13 -05:00
2012-02-02 11:24:44 -08:00
2012-01-13 09:32:14 +10:30
2012-01-13 09:32:28 +10:30
2012-01-03 22:57:12 -05:00
2012-02-02 00:23:14 +11:00
2011-12-13 15:07:49 +00:00
2012-01-06 12:10:25 -08:00
2011-11-02 12:53:42 +01:00
2011-11-14 00:47:54 -05:00
2012-02-21 15:03:48 -05:00
2012-02-24 01:42:07 -08:00
2012-03-20 21:04:47 -07:00
2012-02-24 10:05:59 +01:00
2012-02-26 14:10:44 -05:00
2012-03-06 15:16:19 -05:00
2012-03-06 10:32:47 -05:00
2012-01-31 18:20:28 -05:00
2012-03-02 17:18:10 -05:00
2012-03-21 09:31:44 -04:00
2012-03-05 15:26:47 -05:00
2012-02-16 14:55:27 -05:00
2012-03-17 11:09:33 -04:00
2012-03-21 09:31:46 -04:00
2012-01-31 18:20:25 -05:00
2012-03-12 14:19:34 -04:00
2011-11-18 10:51:01 -08:00
2012-03-23 16:58:31 -07:00
2011-12-21 14:48:43 -08:00
2011-11-04 16:24:23 -04:00
2012-02-16 06:11:23 -07:00
2012-02-01 14:26:30 -07:00
2011-12-27 10:57:13 -06:00
2011-12-12 13:40:16 -07:00
2012-02-26 16:48:06 -07:00
2012-03-05 08:09:09 -07:00
2012-03-21 18:55:10 -07:00
2012-02-23 09:39:23 +02:00
2012-03-21 17:54:58 -07:00
2011-12-03 09:35:17 -08:00
2011-11-04 22:28:13 +01:00
2012-03-14 17:25:56 +08:00
2012-03-21 17:55:01 -07:00
2012-01-10 16:30:42 -08:00
2012-03-21 17:54:58 -07:00
2012-01-12 20:13:10 -08:00
2011-12-13 15:07:49 +00:00
2011-10-31 19:32:32 -04:00
2012-03-04 20:54:01 -05:00
2012-01-11 18:50:26 -08:00
2012-01-06 12:10:26 -08:00
2011-10-31 10:23:57 -07:00
2012-03-22 20:16:14 -07:00
2012-03-04 09:34:15 -08:00
2012-03-09 08:26:05 +01:00
2011-11-18 14:37:40 -05:00
2012-01-12 15:23:04 -08:00
2012-01-10 16:30:54 -08:00
2012-03-23 16:58:31 -07:00
2012-02-07 12:54:56 -05:00
2012-01-08 13:10:57 -08:00
2012-03-16 21:44:59 +01:00
2012-03-13 22:37:14 +01:00
2011-12-01 21:46:42 +01:00
2012-03-04 23:08:46 +01:00
2012-03-16 21:49:24 +01:00
2011-12-13 09:26:45 +00:00
2011-12-08 10:22:07 -08:00
2012-03-23 16:58:38 -07:00
2012-01-04 09:09:35 +04:00
2012-03-04 20:41:38 -05:00
2012-03-04 20:41:38 -05:00
2012-03-04 20:41:38 -05:00
2011-11-02 16:07:02 -07:00
2012-03-23 16:58:32 -07:00
2012-03-01 10:28:04 +01:00
2012-03-20 11:16:20 -07:00
2012-01-10 16:30:54 -08:00
2012-02-01 16:53:46 +08:00
2011-11-17 13:13:29 -08:00
2012-03-23 16:58:41 -07:00
2012-03-20 21:29:38 -04:00
2012-01-12 13:09:09 +01:00
2011-10-31 17:30:54 -07:00
2012-01-12 20:13:12 -08:00
2012-01-03 22:55:07 -05:00
2012-03-23 16:58:31 -07:00
2012-02-21 09:03:41 -08:00
2012-02-21 09:06:08 -08:00
2012-03-14 13:15:48 +00:00
2012-03-02 11:38:15 -08:00
2012-03-20 21:29:43 -04:00
2012-03-20 21:29:42 -04:00
2012-01-03 22:54:56 -05:00
2012-01-22 15:08:46 -05:00
2011-11-02 16:07:01 -07:00
2012-03-21 17:54:57 -07:00
2012-02-21 16:56:45 -05:00
2012-01-06 06:13:35 +04:00
2012-03-23 16:58:32 -07:00
2012-03-21 13:25:04 -07:00
2011-11-02 16:07:01 -07:00
2012-03-23 16:58:42 -07:00
2011-12-09 19:14:13 -08:00
2012-03-09 12:47:56 -08:00
2011-12-02 20:09:48 +09:00
2012-03-08 11:38:50 -08:00
2011-10-31 19:32:32 -04:00
2011-12-09 18:01:05 +09:00
2012-02-01 22:23:53 +05:30
2012-02-16 17:08:09 -05:00
2011-12-25 23:39:11 +01:00
2012-01-09 09:33:57 +09:00
2012-01-23 08:38:48 -08:00
2011-12-09 07:50:27 -08:00
2012-01-10 16:30:54 -08:00
2012-02-24 11:42:50 -08:00
2011-11-18 12:25:22 +05:30
2012-03-19 17:37:35 -04:00
2012-01-09 14:19:33 -08:00
2012-01-03 20:23:18 -05:00
2012-03-19 16:53:08 -04:00
2011-12-30 16:42:19 -05:00
2012-03-11 19:11:22 -07:00
2011-12-13 09:26:45 +00:00
2011-12-13 15:07:49 +00:00
2012-02-21 09:06:09 -08:00
2012-02-24 10:05:59 +01:00
2011-10-31 19:32:28 -04:00
2011-10-31 17:30:47 -07:00
2012-02-10 10:44:35 -08:00
2012-02-17 23:36:23 +01:00
2012-03-21 17:54:58 -07:00
2011-12-06 10:38:03 +00:00
2012-02-10 11:42:25 -08:00
2012-02-21 17:24:20 -08:00
2012-01-03 22:55:12 -05:00
2012-01-03 22:54:56 -05:00
2012-03-01 17:57:40 -05:00
2011-10-31 19:32:32 -04:00
2012-01-23 03:15:25 -05:00
2011-12-11 10:31:57 -08:00
2012-01-26 19:44:23 -08:00
2012-03-20 21:29:40 -04:00
2012-03-23 16:58:40 -07:00
2012-02-24 10:05:59 +01:00
2012-03-08 11:38:51 -08:00
2012-02-02 14:55:45 -08:00
2012-01-08 13:21:22 -08:00
2012-01-04 22:19:55 -08:00
2011-10-31 19:32:32 -04:00
2011-12-30 16:46:02 -05:00
2012-03-13 14:24:07 -07:00
2011-11-02 16:07:02 -07:00
2011-10-31 19:32:31 -04:00
2011-10-31 19:32:23 -04:00
2012-01-15 12:49:56 -08:00
2011-12-02 13:49:21 -05:00
2012-02-19 09:50:20 -06:00
2011-11-24 13:04:47 +10:30
2012-01-12 15:44:42 +10:30
2012-02-19 09:50:20 -06:00
2012-01-12 15:44:44 +10:30
2011-10-31 19:32:32 -04:00
2011-12-05 23:27:59 +00:00
2012-03-08 10:50:35 -08:00
2012-03-01 10:28:04 +01:00
2011-12-02 14:57:31 +01:00
2012-01-06 15:22:04 +01:00
2012-03-02 10:51:00 +01:00
2012-03-07 16:08:46 +01:00
2011-11-11 16:55:54 +00:00