From: Ingo Molnar <mingo@elte.hu>
To: Pekka Paalanen <pq@iki.fi>
Cc: Steven Rostedt <rostedt@goodmis.org>, linux-kernel@vger.kernel.org
Subject: Re: [BUG/PATCH] x86 mmiotrace: dynamically disable non-boot CPUs
Date: Mon, 14 Apr 2008 08:57:13 +0200 [thread overview]
Message-ID: <20080414065713.GB16163@elte.hu> (raw)
In-Reply-To: <20080413230552.33ca587a@daedalus.pq.iki.fi>
thanks Pekka, i've applied your patches.
i'm wondering about this though:
> Mmiotrace is not reliable with multiple CPUs and may miss events. Drop
> to single CPU when mmiotrace is activated.
we should fix this restriction ASAP. Forcibly dropping to UP will cause
mmiotrace to be much less useful for diagnostic purposes of Linux
drivers. We want to enable the mmiotrace-ing of specific devices via
some /sys flag. For example via:
cat /sys/devices/pci0000\:00/0000\:00\:1f.2/mmiotrace
this should start mmiotracing of that specific device - or something
like that. Hm?
> When I tested this patch on Intel Core 2 Duo, enter_uniprocessor()
> triggered the following kernel bug:
>
> Linux version 2.6.25-rc8-sched-devel.git-x86-latest.git (paalanen@ct200006)
> (gcc version 4.1.2 (Gentoo 4.1.2 p1.0.1)) #2 SMP PREEMPT Sun Apr 13
> 22:09:03 EEST 2008
> ...
> in mmio_trace_init
> mmiotrace: Disabling non-boot CPUs...
> CPU 1 is now offline
> lockdep: fixing up alternatives.
> SMP alternatives: switching to UP code
> BUG: sleeping function called from invalid context at mm/slab.c:3053
> in_atomic():1, irqs_disabled():0
> 5 locks held by bash/4423:
> #0: (trace_types_lock){--..}, at: [<ffffffff8026442f>] tracing_set_trace_write+0x93/0x11a
> #1: (mmiotrace_mutex){--..}, at: [<ffffffff802251e0>] enable_mmiotrace+0x17/0x142
> #2: (cpu_add_remove_lock){--..}, at: [<ffffffff802580e5>] cpu_maps_update_begin+0x12/0x14
> #3: (&cpu_hotplug.lock){--..}, at: [<ffffffff8025814f>] cpu_hotplug_begin+0x39/0x9f
> #4: (smp_alt){--..}, at: [<ffffffff80211bd9>] alternatives_smp_switch+0x66/0x1ab
> Pid: 4423, comm: bash Not tainted 2.6.25-rc8-sched-devel.git-x86-latest.git #2
>
> Call Trace:
> [<ffffffff802520c0>] ? __debug_show_held_locks+0x22/0x24
> [<ffffffff8022d292>] __might_sleep+0xd9/0xdb
> [<ffffffff80287326>] cache_alloc_debugcheck_before+0x23/0x32
> [<ffffffff80287a32>] __kmalloc+0x34/0xa5
> [<ffffffff80209393>] ? clear_ti_thread_flag+0x10/0x17
> [<ffffffff8027d7f6>] kmalloc_node+0x9/0xb
> [<ffffffff8027d8e0>] __get_vm_area_node+0xa2/0x1cb
> [<ffffffff80209393>] ? clear_ti_thread_flag+0x10/0x17
> [<ffffffff8027da41>] __get_vm_area+0x13/0x15
> [<ffffffff8027da60>] get_vm_area+0x1d/0x1f
> [<ffffffff8027e14c>] vmap+0x2a/0x5c
> [<ffffffff8021191b>] text_poke+0xaa/0x136
> [<ffffffff804cba2b>] ? _etext+0x0/0x5
> [<ffffffff802119f6>] alternatives_smp_unlock+0x4f/0x63
> [<ffffffff80211ce1>] alternatives_smp_switch+0x16e/0x1ab
> [<ffffffff8021b163>] __cpu_die+0x53/0x7d
> [<ffffffff802583e2>] _cpu_down+0x195/0x26c
> [<ffffffff802585ca>] cpu_down+0x26/0x36
> [<ffffffff80225270>] enable_mmiotrace+0xa7/0x142
> [<ffffffff80266b8d>] mmio_trace_init+0x3c/0x40
> [<ffffffff8026448e>] tracing_set_trace_write+0xf2/0x11a
> [<ffffffff80327fac>] ? security_file_permission+0x11/0x13
> [<ffffffff8028b047>] vfs_write+0xa7/0xe1
> [<ffffffff8028b13b>] sys_write+0x47/0x6d
> [<ffffffff8020b4db>] system_call_after_swapgs+0x7b/0x80
>
> mmiotrace: CPU1 is down.
> mmiotrace: enabled.
>
> Is this my fault, or is there a bug somewhere else? The kernel tree is
> sched-devel/latest git from 12th April, IIRC.
there's no known bug of sched-devel/latest of this kind (or any known
bug for that matter).
i suspect the bug is that you bring the CPU down from an atomic
(spinlocked or irq disabled) context.
Ingo
next prev parent reply other threads:[~2008-04-14 6:57 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20080413224207.4430a09c@daedalus.pq.iki.fi>
2008-04-13 19:48 ` [PATCH] mmiotrace: add user documentation Pekka Paalanen
2008-04-14 15:49 ` Steven Rostedt
2008-04-14 18:20 ` Pekka Paalanen
2008-04-13 20:05 ` [BUG/PATCH] x86 mmiotrace: dynamically disable non-boot CPUs Pekka Paalanen
2008-04-14 6:57 ` Ingo Molnar [this message]
2008-04-14 18:02 ` Pekka Paalanen
2008-04-16 11:46 ` Ingo Molnar
2008-04-16 17:59 ` Pekka Paalanen
2008-04-16 18:32 ` Ingo Molnar
2008-04-16 19:07 ` Steven Rostedt
2008-04-16 20:42 ` Pekka Paalanen
2008-04-16 20:47 ` Ingo Molnar
2008-07-24 15:34 ` [Nouveau] " Stephane Marchesin
2008-04-19 15:41 ` [BUG] kmalloc_node(GFP_KERNEL) while smp_alt spinlocked Pekka Paalanen
2008-04-19 16:19 ` [PATCH] Fix SMP alternatives : use mutex instead of spinlock, text_poke is sleepable Mathieu Desnoyers
2008-04-19 21:06 ` Pekka Paalanen
2008-04-19 21:52 ` [BUG] CPU hotplug reboots machine (Re: [PATCH] Fix SMP alternatives : use mutex instead of spinlock, text_poke is sleepable) Pekka Paalanen
2008-04-19 21:58 ` [PATCH] Check for breakpoint in text_poke to eliminate bug_on Mathieu Desnoyers
2008-04-19 22:42 ` Pekka Paalanen
2008-04-20 0:05 ` Mathieu Desnoyers
2008-04-20 7:14 ` Pekka Paalanen
2008-04-20 19:44 ` Mathieu Desnoyers
2008-04-20 20:18 ` Pekka Paalanen
2008-04-20 20:25 ` Mathieu Desnoyers
2008-04-21 18:48 ` [PATCH] x86_64: fix kernel rodata NX setting Pekka Paalanen
2008-04-21 18:57 ` Steven Rostedt
2008-04-21 19:03 ` Ingo Molnar
2008-04-22 18:42 ` [repost PATCH] Fix SMP alternatives : use mutex instead of spinlock, text_poke is sleepable Pekka Paalanen
2008-04-22 19:09 ` Ingo Molnar
2008-04-22 20:22 ` Mathieu Desnoyers
2008-04-24 19:39 ` [PATCH v2] x86 mmiotrace: dynamically disable non-boot CPUs Pekka Paalanen
2008-04-26 11:13 ` Ingo Molnar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080414065713.GB16163@elte.hu \
--to=mingo@elte.hu \
--cc=linux-kernel@vger.kernel.org \
--cc=pq@iki.fi \
--cc=rostedt@goodmis.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox