Files
kernel_xiaomi_raphael/include/linux
Andrei Vagin 5665ad36ee proc: add seq_put_decimal_ull_width to speed up /proc/pid/smaps
seq_put_decimal_ull_w(m, str, val, width) prints a decimal number with a
specified minimal field width.

It is equivalent of seq_printf(m, "%s%*d", str, width, val), but it
works much faster.

== test_smaps.py
  num = 0
  with open("/proc/1/smaps") as f:
          for x in xrange(10000):
                  data = f.read()
                  f.seek(0, 0)
==

== Before patch ==
  $ time python test_smaps.py
  real    0m4.593s
  user    0m0.398s
  sys     0m4.158s

== After patch ==
  $ time python test_smaps.py
  real    0m3.828s
  user    0m0.413s
  sys     0m3.408s

$ perf -g record python test_smaps.py
== Before patch ==
-   79.01%     3.36%  python   [kernel.kallsyms]    [k] show_smap.isra.33
   - 75.65% show_smap.isra.33
      + 48.85% seq_printf
      + 15.75% __walk_page_range
      + 9.70% show_map_vma.isra.23
        0.61% seq_puts

== After patch ==
-   75.51%     4.62%  python   [kernel.kallsyms]    [k] show_smap.isra.33
   - 70.88% show_smap.isra.33
      + 24.82% seq_put_decimal_ull_w
      + 19.78% __walk_page_range
      + 12.74% seq_printf
      + 11.08% show_map_vma.isra.23
      + 1.68% seq_puts

[akpm@linux-foundation.org: fix drivers/of/unittest.c build]
Link: http://lkml.kernel.org/r/20180212074931.7227-1-avagin@openvz.org
Signed-off-by: Andrei Vagin <avagin@openvz.org>
Cc: Alexey Dobriyan <adobriyan@gmail.com>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: UtsavisGreat <utsavbalar1231@gmail.com>
2020-05-26 12:13:42 +05:30
..
2020-05-25 21:20:43 +05:30
2018-04-24 11:32:25 -07:00
2018-10-04 16:15:25 -07:00
2019-11-05 05:46:34 -08:00
2019-08-09 18:08:06 +02:00
2018-09-26 08:43:22 +02:00
2019-06-25 02:20:14 -07:00
2020-04-20 13:29:37 +05:30
2019-11-27 15:27:44 +05:30
2018-04-13 10:18:03 -07:00
2020-05-26 12:11:38 +05:30
2019-12-05 15:38:28 +01:00
2018-08-06 09:47:26 -07:00
2019-01-28 10:11:34 +02:00
2019-12-17 21:13:36 +01:00
2020-05-25 21:20:42 +05:30
2020-05-25 21:20:36 +05:30
2020-05-26 12:13:40 +05:30
2019-12-31 12:37:21 +01:00
2020-05-26 12:13:42 +05:30
2019-06-09 09:40:33 +02:00
2019-11-14 14:38:28 +08:00
2018-10-30 11:01:12 -07:00
2020-03-04 16:12:09 -05:00
2019-08-12 13:29:46 -04:00
2018-05-22 11:24:18 +05:30
2019-03-23 00:52:29 +00:00
2019-06-11 12:21:48 +02:00
2018-03-08 14:36:36 -08:00
2019-04-17 08:37:44 +02:00
2018-04-26 11:37:46 +02:00
2019-08-12 13:29:46 -04:00
2018-11-13 11:15:11 -08:00
2019-06-17 19:52:43 +02:00
2020-02-13 14:17:03 +05:30