All of lore.kernel.org
 help / color / mirror / Atom feed
From: yhu2 <yadi.hu@windriver.com>
To: Yadi Hu <yadi.hu@windriver.com>, <linux-rt-users@vger.kernel.org>
Subject: Re: [PATCH 3.14.x-rt] ARM: enable irq in translation/section permission fault handlers
Date: Tue, 16 Dec 2014 10:33:53 +0800	[thread overview]
Message-ID: <548F9A11.9000802@windriver.com> (raw)
In-Reply-To: <1418178729-2279-2-git-send-email-yadi.hu@windriver.com>

Any comments would be appreciated!@

On 12/10/2014 10:32 AM, Yadi Hu wrote:
> From: Yadi.hu <yadi.hu@windriver.com>
>
> Probably happens on all ARM, with
> CONFIG_PREEMPT_RT_FULL
> CONFIG_DEBUG_ATOMIC_SLEEP
>
> This simple program....
>
> int main() {
>     *((char*)0xc0001000) = 0;
> };
>
> [ 512.742724] BUG: sleeping function called from invalid context at kernel/rtmutex.c:658
> [ 512.743000] in_atomic(): 0, irqs_disabled(): 128, pid: 994, name: a
> [ 512.743217] INFO: lockdep is turned off.
> [ 512.743360] irq event stamp: 0
> [ 512.743482] hardirqs last enabled at (0): [< (null)>] (null)
> [ 512.743714] hardirqs last disabled at (0): [<c0426370>] copy_process+0x3b0/0x11c0
> [ 512.744013] softirqs last enabled at (0): [<c0426370>] copy_process+0x3b0/0x11c0
> [ 512.744303] softirqs last disabled at (0): [< (null)>] (null)
> [ 512.744631] [<c041872c>] (unwind_backtrace+0x0/0x104)
> [ 512.745001] [<c09af0c4>] (dump_stack+0x20/0x24)
> [ 512.745355] [<c0462490>] (__might_sleep+0x1dc/0x1e0)
> [ 512.745717] [<c09b6770>] (rt_spin_lock+0x34/0x6c)
> [ 512.746073] [<c0441bf0>] (do_force_sig_info+0x34/0xf0)
> [ 512.746457] [<c0442668>] (force_sig_info+0x18/0x1c)
> [ 512.746829] [<c041d880>] (__do_user_fault+0x9c/0xd8)
> [ 512.747185] [<c041d938>] (do_bad_area+0x7c/0x94)
> [ 512.747536] [<c041d990>] (do_sect_fault+0x40/0x48)
> [ 512.747898] [<c040841c>] (do_DataAbort+0x40/0xa0)
> [ 512.748181] Exception stack(0xecaa1fb0 to 0xecaa1ff8)
>
> Oxc0000000 belongs to kernel address space, user task can not be
> allowed to access it. For above condition, correct result is that
> test case should receive a “segment fault” and exits but not stacks.
>
> the root cause is commit 02fe2845d6a8 ("avoid enabling interrupts in
> prefetch/data abort handlers"),it deletes irq enable block in Data
> abort assemble code and move them into page/breakpiont/alignment fault
> handlers instead. But author does not enable irq in translation/section
> permission fault handlers. ARM disables irq when it enters exception/
> interrupt mode, if kernel doesn't enable irq, it would be still disabled
> during translation/section permission fault.
>
> We see the above splat because do_force_sig_info is still called with
> IRQs off, and that code eventually does a:
>
>          spin_lock_irqsave(&t->sighand->siglock, flags);
>
> As this is architecture independent code, and we've not seen any other
> need for other arch to have the siglock converted to raw lock, we can
> conclude that we should enable irq for ARM translation/section
> permission exception.
>
> Signed-off-by: Yadi.hu <yadi.hu@windriver.com>
> ---
>   arch/arm/mm/fault.c |    6 ++++++
>   1 files changed, 6 insertions(+), 0 deletions(-)
>
> diff --git a/arch/arm/mm/fault.c b/arch/arm/mm/fault.c
> index 5dbf13f..272519f 100644
> --- a/arch/arm/mm/fault.c
> +++ b/arch/arm/mm/fault.c
> @@ -428,6 +428,9 @@ do_translation_fault(unsigned long addr, unsigned int fsr,
>   	if (addr < TASK_SIZE)
>   		return do_page_fault(addr, fsr, regs);
>   
> +	if (interrupts_enabled(regs))
> +		local_irq_enable();
> +
>   	if (user_mode(regs))
>   		goto bad_area;
>   
> @@ -494,6 +497,9 @@ do_translation_fault(unsigned long addr, unsigned int fsr,
>   static int
>   do_sect_fault(unsigned long addr, unsigned int fsr, struct pt_regs *regs)
>   {
> +	if (interrupts_enabled(regs))
> +		local_irq_enable();
> +
>   	do_bad_area(addr, fsr, regs);
>   	return 0;
>   }

--
To unsubscribe from this list: send the line "unsubscribe linux-rt-users" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

  reply	other threads:[~2014-12-16  2:35 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-12-10  2:32 [PATCH 3.14.x-rt] ARM: enable irq in translation/section permission fault handlers Yadi Hu
2014-12-10  2:32 ` Yadi Hu
2014-12-16  2:33   ` yhu2 [this message]
2015-02-17 17:10   ` Sebastian Andrzej Siewior

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=548F9A11.9000802@windriver.com \
    --to=yadi.hu@windriver.com \
    --cc=linux-rt-users@vger.kernel.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.