lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20080305154942.a8dae04d.akpm@linux-foundation.org>
Date:	Wed, 5 Mar 2008 15:49:42 -0800
From:	Andrew Morton <akpm@...ux-foundation.org>
To:	Valdis.Kletnieks@...edu
Cc:	andi@...stfloor.org, linux-kernel@...r.kernel.org
Subject: Re: 2.6.25-rc3-mm1 - PROFILE_LIKELY redux..

On Wed, 05 Mar 2008 17:26:25 -0500
Valdis.Kletnieks@...edu wrote:

> On Wed, 05 Mar 2008 10:02:21 PST, Andrew Morton said:
> 
> > at the top, so it'll be something else.  Perhaps a `likely' snuck in via an
> > inline in a header file.  It would be better to add a #define DONT_DO_THAT
> > at the top of arch/x86/kernel/vsyscall_64.c and
> > arch/x86/vdso/vclock_gettime.c, then use that to defeat likely-profiling.
> > 
> >  arch/x86/kernel/vsyscall_64.c  |   11 ++---------
> >  arch/x86/vdso/vclock_gettime.c |   11 ++---------
> >  include/linux/compiler.h       |    3 ++-
> >  3 files changed, 6 insertions(+), 19 deletions(-)
> 
> Confirming that this patch works and my system goes multi-user cleanly.

Thanks.

> Actual numbers after about 10 minutes of uptime:
> 
> % wc -l /proc/likely_prof 
> 2635 /proc/likely_prof
> % grep '^[^ ]' /proc/likely_prof 
> Likely Profiling Results
> [+- ] Type | # True | # False | Function:Filename@...e
> +unlikely |        1|        0  in_dev_get()@:include/linux/inetdevice.h@185
> +unlikely |      513|        0  dst_input()@:include/net/dst.h@254
> -likely   |        0|      148  ip6_mc_input()@:net/ipv6/ip6_input.c@271
> -likely   |        0|        1  sock_error()@:include/net/sock.h@...1
> -likely   |      851|     1219  tcp_transmit_skb()@:net/ipv4/tcp_output.c@493
> +unlikely |        1|        0  signal_pending()@:include/linux/sched.h@...7
> -likely   |        0|  1172946  audit_syscall_entry()@:kernel/auditsc.c@...2
> +unlikely |  1172716|        0  syscall_trace_enter()@:arch/x86/kernel/ptrace.c@...6
> -likely   |        0|  1173020  audit_syscall_exit()@:kernel/auditsc.c@...1
> +unlikely |  1172831|        0  syscall_trace_leave()@:arch/x86/kernel/ptrace.c@...3
> -likely   |        0|     1272  audit_alloc()@:kernel/auditsc.c@841
> +unlikely |        3|        0  icmp_unreach()@:net/ipv4/icmp.c@773
> +unlikely |        2|        1  nf_ct_attach()@:net/netfilter/core.c@230
> -likely   |        0|        2  dst_gc_task()@:net/core/dst.c@82
> +unlikely |      143|       61  fput_light()@:include/linux/file.h@77
> +unlikely |      892|      424  _read_unlock_irqrestore()@:kernel/spinlock.c@375
> +unlikely |       28|        0  sched_move_task()@:kernel/sched.c@...5
> +unlikely |       28|        0  sched_move_task()@:kernel/sched.c@...8
> +unlikely |      108|        0  verify_export_symbols()@:kernel/module.c@...1
> +unlikely |      313|        0  verify_export_symbols()@:kernel/module.c@...3
> +unlikely |       14|        0  ll_front_merge_fn()@:block/blk-merge.c@347
> -likely   |       17|     1150  audit_free()@:kernel/auditsc.c@...8
> -likely   |       17|  1174290  audit_get_context()@:kernel/auditsc.c@711
> +unlikely |       33|        0  inotify_find_update_watch()@:fs/inotify.c@591
> +unlikely |     4360|      775  kill_pid_info()@:kernel/signal.c@...5
> +unlikely |     7239|     2767  next_pidmap()@:kernel/pid.c@194
> +unlikely |    42009|    33683  copy_pte_range()@:mm/memory.c@510
> -likely   |        0|        1  qh_completions()@:drivers/usb/host/ehci-q.c@368
> +unlikely |    19934|        0  ll_back_merge_fn()@:block/blk-merge.c@309
> -likely   |      927|     2323  load_elf_binary()@:fs/binfmt_elf.c@896
> +unlikely |     2435|      875  pmd_alloc()@:include/linux/mm.h@862
> +unlikely |       13|       12  psmouse_interrupt()@:drivers/input/mouse/psmouse-base.c@296
> +unlikely |       70|       25  psmouse_interrupt()@:drivers/input/mouse/psmouse-base.c@292
> -likely   |       20|       80  qh_completions()@:drivers/usb/host/ehci-q.c@415
> -likely   |        0|       30  qh_completions()@:drivers/usb/host/ehci-q.c@319
> -likely   |        5|       14  submit_async()@:drivers/usb/host/ehci-q.c@975
> +unlikely |       19|        2  qh_append_tds()@:drivers/usb/host/ehci-q.c@876
> -likely   |        6|       15  atapi_drain_needed()@:drivers/ata/libata-scsi.c@846
> +unlikely |    27395|    18153  add_timer_randomness()@:drivers/char/random.c@628
> +unlikely |    34665|    19948  bio_phys_segments()@:fs/bio.c@226
> -likely   |      347|      678  clocksource_adjust()@:kernel/time/timekeeping.c@418
> -likely   |        1|        4  __ata_qc_from_tag()@:include/linux/libata.h@...9
> -likely   |        0|       15  __cancel_work_timer()@:kernel/workqueue.c@490
> +unlikely |    15638|     1127  queue_delayed_work_on()@:kernel/workqueue.c@233
> +unlikely |        2|        0  srcu_notifier_chain_register()@:kernel/notifier.c@419
> +unlikely |     6502|     2429  queue_work()@:kernel/workqueue.c@171
> +unlikely |        9|        2  blocking_notifier_chain_register()@:kernel/notifier.c@212
> +unlikely |    13631|        0  pre_schedule_rt()@:kernel/sched_rt.c@961
> +unlikely |   591400|   443725  __update_curr()@:kernel/sched_fair.c@313
> +unlikely |   233625|   205658  __switch_to()@:arch/x86/kernel/process_64.c@656
> +unlikely |   313057|   126225  __switch_to()@:arch/x86/kernel/process_64.c@641
> +unlikely |   313053|   126225  __switch_to()@:arch/x86/kernel/process_64.c@637
> +unlikely |   467383|        0  sched_info_switch()@:kernel/sched_stats.h@230
> +unlikely |   188448|    13628  pick_next_task_rt()@:kernel/sched_rt.c@522
> +unlikely |   240619|        0  sched_info_queued()@:kernel/sched_stats.h@188
> -likely   |       61|      644  ifind()@:fs/inode.c@798
> +unlikely |   258562|    61703  scheduler_tick()@:kernel/sched.c@...6
> -likely   |    61220|   241529  acct_update_integrals()@:kernel/tsacct.c@120
> +unlikely |  1189922|   902477  kfree()@:mm/slab.c@...5
> +unlikely |       23|        0  __rmqueue_fallback()@:mm/page_alloc.c@812
> +unlikely |    14376|     9655  rt_policy()@:kernel/sched.c@140

These are all the ones which we got wrong on your setup, yes?

I wonder if assuming that current->audit_context is NULL is realistic
nowadays.

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ