kernel-testers.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Alan Jenkins <alan-jenkins@tuffmail.co.uk>
To: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: linux-acpi@vger.kernel.org,
	linux-kernel <linux-kernel@vger.kernel.org>,
	Kernel Testers List <kernel-testers@vger.kernel.org>,
	Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>,
	Arjan van de Ven <arjan@infradead.org>
Subject: Re: [BISECTED] EEE PC hangs when booting off battery
Date: Tue, 14 Apr 2009 10:26:13 +0100	[thread overview]
Message-ID: <49E456B5.6030006@tuffmail.co.uk> (raw)
In-Reply-To: <49E44415.1040500@tuffmail.co.uk>

Alan Jenkins wrote:
> Bjorn Helgaas wrote:
>   
>> On Monday 13 April 2009 01:57:00 pm Alan Jenkins wrote:
>>   
>>     
>>> Bjorn Helgaas wrote:
>>>     
>>>       
>>>> On Sunday 12 April 2009 07:11:57 am Alan Jenkins wrote:
>>>>   
>>>> You mention that this occurs when booting off battery.  So I
>>>> assume everything works fine when the EEE is plugged in to the
>>>> wall socket?
>>>>       
>>>>         
>>> When I tested it before, that was what I found.
>>>
>>> However, I now find that's not quite right.  It only works (i.e. doesn't
>>> hang) if I remove the battery as well as plugging it into the wall.  If
>>> I have the battery in, it hangs.
>>>     
>>>       
>
> ... and right now, I can only reproduce it by booting with it plugged
> into the wall and the battery present.  If I unplug it from the wall, it
> boots fine.
>
> It must be affected by something else as well, maybe battery level or
> charging / discharging status.
>
>   
>>>>>>>> Magic SysRQ keys work though.  ...
>>>>>>>>           
>>>>>>>>               
>>>>>>>>                 
>>>>>> I was able to run SysRq-P, and found the following backtrace -
>>>>>>
>>>>>> Pid: 0
>>>>>> EIP is at acpi_idle_enter_bm+0x1df/0x208 [processor]
>>>>>>           
>>>>>>             
>>>> Can you figure out where this is in acpi_idle_enter_bm() or
>>>> maybe just email me your processor.ko module?
>>>>
>>>> Does it always happen at the same point?
>>>>       
>>>>         
>>> Yes, it always happens at the same point.
>>>
>>> It turns out I can read the runes, but I don't understand what they're
>>> saying :-).
>>>     
>>>       
>> I'm not much good with x86 assembly either :-)
>>
>> I think that in both cases below, you're right after enabling
>> interrupts and about to exit the idle routine.  My guess is the
>> system is not really hung; it just doesn't think it has anything
>> to do and is spending all its time in the idle loop.
>>
>>   
>>     
>>> 00001bd0 <acpi_idle_enter_bm>:
>>>
>>> ...
>>> 00001bd0 + 0x1df = 00001daf
>>> ...
>>>     1d70:       b8 03 00 00 00          mov    $0x3,%eax
>>>     1d75:       e8 90 f3 ff ff          call   110a <tsc_halts_in_c>
>>>     1d7a:       85 c0                   test   %eax,%eax
>>>     1d7c:       74 0a                   je     1d88 <acpi_idle_enter_bm+0x1b8>
>>>     1d7e:       b8 0e 09 00 00          mov    $0x90e,%eax
>>>                         1d7f: R_386_32  .rodata.str1.1
>>>     1d83:       e8 fc ff ff ff          call   1d84 <acpi_idle_enter_bm+0x1b4>
>>>                         1d84: R_386_PC32        mark_tsc_unstable
>>>     1d88:       8b 45 e8                mov    -0x18(%ebp),%eax
>>>     1d8b:       8b 55 ec                mov    -0x14(%ebp),%edx
>>>     1d8e:       e8 ab fd ff ff          call   1b3e <us_to_pm_timer_ticks>
>>>     1d93:       89 c3                   mov    %eax,%ebx
>>>     1d95:       b8 17 01 00 00          mov    $0x117,%eax
>>>     1d9a:       69 ca 17 01 00 00       imul   $0x117,%edx,%ecx
>>>     1da0:       89 d6                   mov    %edx,%esi
>>>     1da2:       f7 e3                   mul    %ebx
>>>     1da4:       8d 14 11                lea    (%ecx,%edx,1),%edx
>>>     1da7:       e8 fc ff ff ff          call   1da8 <acpi_idle_enter_bm+0x1d8>
>>>                         1da8: R_386_PC32        sched_clock_idle_wakeup_event
>>>     1dac:       fb                      sti
>>>     1dad:       89 e0                   mov    %esp,%eax
>>> ->  1daf:       31 c9                   xor    %ecx,%ecx              <---------
>>>     1db1:       25 00 e0 ff ff          and    $0xffffe000,%eax
>>>     1db6:       89 fa                   mov    %edi,%edx
>>>     1db8:       83 48 0c 04             orl    $0x4,0xc(%eax)
>>>     1dbc:       ff 47 18                incl   0x18(%edi)
>>>     1dbf:       8b 45 e4                mov    -0x1c(%ebp),%eax
>>>     1dc2:       e8 a4 f5 ff ff          call   136b <acpi_state_timer_broadcast>
>>>     1dc7:       01 5f 1c                add    %ebx,0x1c(%edi)
>>>     1dca:       11 77 20                adc    %esi,0x20(%edi)
>>>     1dcd:       8b 45 e8                mov    -0x18(%ebp),%eax
>>>     1dd0:       83 c4 10                add    $0x10,%esp
>>>     1dd3:       5b                      pop    %ebx
>>>     1dd4:       5e                      pop    %esi
>>>     1dd5:       5f                      pop    %edi
>>>     1dd6:       5d                      pop    %ebp
>>>     1dd7:       c3                      ret
>>>
>>>     
>>>       
>>>> If you blacklist or rename the processor module to prevent it
>>>> from loading, does that keep the hang from occurring?
>>>>       
>>>>         
>>> No.  In that case I get the hang in default_idle+0x59/0x95
>>>
>>> 0000007a <default_idle>:
>>>   7a:   55                      push   %ebp
>>>   7b:   89 e5                   mov    %esp,%ebp
>>>   7d:   56                      push   %esi
>>>   7e:   53                      push   %ebx
>>>   7f:   83 ec 18                sub    $0x18,%esp
>>>   82:   83 3d 18 00 00 00 00    cmpl   $0x0,0x18
>>>                         84: R_386_32    .bss
>>>   89:   75 7a                   jne    105 <default_idle+0x8b>
>>>   8b:   80 3d 05 00 00 00 00    cmpb   $0x0,0x5
>>>                         8d: R_386_32    boot_cpu_data
>>>   92:   74 71                   je     105 <default_idle+0x8b>
>>>   94:   83 3d 04 00 00 00 00    cmpl   $0x0,0x4
>>>                         96: R_386_32    __tracepoint_power_start
>>>   9b:   74 23                   je     c0 <default_idle+0x46>
>>>   9d:   8b 1d 08 00 00 00       mov    0x8,%ebx
>>>                         9f: R_386_32    __tracepoint_power_start
>>>   a3:   85 db                   test   %ebx,%ebx
>>>   a5:   74 19                   je     c0 <default_idle+0x46>
>>>   a7:   8d 75 e0                lea    -0x20(%ebp),%esi
>>>   aa:   b9 01 00 00 00          mov    $0x1,%ecx
>>>   af:   ba 01 00 00 00          mov    $0x1,%edx
>>>   b4:   89 f0                   mov    %esi,%eax
>>>   b6:   ff 13                   call   *(%ebx)
>>>   b8:   83 c3 04                add    $0x4,%ebx
>>>   bb:   83 3b 00                cmpl   $0x0,(%ebx)
>>>   be:   75 ea                   jne    aa <default_idle+0x30>
>>>   c0:   89 e0                   mov    %esp,%eax
>>>   c2:   25 00 e0 ff ff          and    $0xffffe000,%eax
>>>   c7:   83 60 0c fb             andl   $0xfffffffb,0xc(%eax)
>>>   cb:   f6 40 08 08             testb  $0x8,0x8(%eax)
>>>   cf:   75 04                   jne    d5 <default_idle+0x5b>
>>>   d1:   fb                      sti
>>>   d2:   f4                      hlt
>>> -->  d3:   eb 01                   jmp    d6 <default_idle+0x5c>    <--------
>>>   d5:   fb                      sti
>>>   d6:   89 e0                   mov    %esp,%eax
>>>   d8:   25 00 e0 ff ff          and    $0xffffe000,%eax
>>>   dd:   83 48 0c 04             orl    $0x4,0xc(%eax)
>>>   e1:   83 3d 04 00 00 00 00    cmpl   $0x0,0x4
>>>                         e3: R_386_32    __tracepoint_power_end
>>>   e8:   74 1e                   je     108 <default_idle+0x8e>
>>>
>>>
>>>     
>>>       
>>>>> 7ec0a7290797f57b780f792d12f4bcc19c83aa4f is first bad commit
>>>>> commit 7ec0a7290797f57b780f792d12f4bcc19c83aa4f
>>>>> Author: Bjorn Helgaas <bjorn.helgaas@hp.com>
>>>>> Date:   Mon Mar 30 17:48:24 2009 +0000
>>>>>         
>>>>>           
>>>> Ouch, sorry about that.  Thanks for doing all the bisection work.
>>>>   
>>>>       
>>>>         
>>>>>     ACPI: processor: use .notify method instead of installing handler
>>>>> directly
>>>>>
>>>>>     This patch adds a .notify() method.  The presence of .notify() causes
>>>>>     Linux/ACPI to manage event handlers and notify handlers on our behalf,
>>>>>     so we don't have to install and remove them ourselves.
>>>>>
>>>>>     Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com>
>>>>>     CC: Zhang Rui <rui.zhang@intel.com>
>>>>>     CC: Zhao Yakui <yakui.zhao@intel.com>
>>>>>     CC: Venki Pallipadi <venkatesh.pallipadi@intel.com>
>>>>>     CC: Anil S Keshavamurthy <anil.s.keshavamurthy@intel.com>
>>>>>     Signed-off-by: Len Brown <len.brown@intel.com>
>>>>>
>>>>> However, reverting this commit from v2.6.30-rc1 doesn't solve the hang.
>>>>>         
>>>>>           
>>>> I don't see the problem in that commit yet, and if there is a problem
>>>> with it, I would think that reverting it from 2.6.30-rc1 would solve
>>>> it.  But maybe it'd be useful to revert the whole .notify series to
>>>> make sure.  From 2.6.30-rc1, you should be able to revert these:
>>>>
>>>>   7ec0a7290797f57b780f792d12f4bcc19c83aa4f processor
>>>>   373cfc360ec773be2f7615e59a19f3313255db7c button
>>>>   46ec8598fde74ba59703575c22a6fb0b6b151bb6 Linux/ACPI infrastructure
>>>>
>>>> What happens with those commits reverted?
>>>>       
>>>>         
>>> I'll find out tomorrow.
>>>     
>>>       
>> The fact that it still hangs even when you don't load the processor
>> driver at all suggests that the 7ec0a729079 commit identified by the
>> bisection is not the real problem.  That commit only touches
>> drivers/acpi/processor_core.c.
>>   
>>     
>
> Yah.
>
>   
>> I think it's more likely some kind of race or missed wakeup.
>>
>> Since it seems to be sensitive to whether the battery is present,
>> I guess you could try blacklisting the battery.ko driver.  There
>> have been a few changes to it since 2.6.29-rc8.  If things work
>> without battery.ko, we can look through those changes.
>>   
>>     
>
> Good guess :-).  I tried a couple of times either way, and blacklisting
> "battery" definitely avoids the hang.
>   

Ok, I tried reverting

0f66af530116e9f4dd97f328d91718b56a6fc5a4 "ACPI: battery: asynchronous init"

and that fixed it.

Thanks for your help so far, Bjorn.

Alan

  reply	other threads:[~2009-04-14  9:26 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-04-11  9:41 Regression: EEE PC hangs when booting off battery Alan Jenkins
     [not found] ` <49E065CF.6040408-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-11 18:07   ` Tzy-Jye Daniel Lin
     [not found]     ` <66dc75180904111107q645fbb77i3cf927ffab7a7ef0-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2009-04-12  9:00       ` Alan Jenkins
     [not found]         ` <49E1ADAE.2030103-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-12 13:11           ` [BISECTED] " Alan Jenkins
     [not found]             ` <49E1E89D.7040502-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-13 19:15               ` Bjorn Helgaas
     [not found]                 ` <200904131315.55519.bjorn.helgaas-VXdhtT5mjnY@public.gmane.org>
2009-04-13 19:57                   ` Alan Jenkins
2009-04-13 22:28                     ` Bjorn Helgaas
2009-04-14  8:06                       ` Alan Jenkins
2009-04-14  9:26                         ` Alan Jenkins [this message]
2009-04-14 14:59                           ` Bjorn Helgaas
2009-04-14 15:17                             ` Arjan van de Ven
2009-04-14 15:37                               ` Alan Jenkins
     [not found]                               ` <20090414081728.10de978a-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org>
2009-04-14 15:48                                 ` Bjorn Helgaas
     [not found]                                   ` <200904140948.37633.bjorn.helgaas-VXdhtT5mjnY@public.gmane.org>
2009-04-14 15:55                                     ` Moore, Robert
     [not found]                                       ` <4911F71203A09E4D9981D27F9D8308581D3722EB-osO9UTpF0URQxe9IK+vIArfspsVTdybXVpNB7YpNyf8@public.gmane.org>
2009-04-14 16:56                                         ` Bjorn Helgaas
2009-04-14 17:22                                           ` Moore, Robert
     [not found]                                             ` <4911F71203A09E4D9981D27F9D8308581D372489-osO9UTpF0URQxe9IK+vIArfspsVTdybXVpNB7YpNyf8@public.gmane.org>
2009-04-14 17:28                                               ` Alan Jenkins
     [not found]                                           ` <200904141056.14159.bjorn.helgaas-VXdhtT5mjnY@public.gmane.org>
2009-04-15 15:38                                             ` Len Brown
2009-04-15 14:32                                     ` [FIXED] " Alan Jenkins
2009-04-22 12:17                                       ` Alan Jenkins
2009-04-26 11:34                                         ` Alan Jenkins
     [not found]                                           ` <49F446AE.6070607-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-28  9:19                                             ` [PATCH] [RFC] " Alan Jenkins
     [not found]                                               ` <49F6CA0E.5040101-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-28  9:58                                                 ` Johannes Berg
     [not found]                                                   ` <1240912688.28835.10.camel-YfaajirXv2244ywRPIzf9A@public.gmane.org>
2009-04-28 10:27                                                     ` Alan Jenkins
     [not found]                                                       ` <49F6DA14.7030608-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-28 10:35                                                         ` Johannes Berg
2009-04-29 11:14                                                         ` Alan Jenkins
     [not found]                                                           ` <49F83699.3000307-cCz0Lq7MMjm9FHfhHBbuYA@public.gmane.org>
2009-04-29 11:20                                                             ` Johannes Berg
2009-05-15 21:48                                                             ` Rafael J. Wysocki
     [not found]                                                               ` <200905152348.56449.rjw-KKrjLPT3xs0@public.gmane.org>
2009-05-16  8:39                                                                 ` Alan Jenkins
2009-04-11 19:40 ` Regression: " Kristoffer Ericson
     [not found]   ` <20090411214045.7bdd497f.kristoffer.ericson-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2009-04-12  9:22     ` Alan Jenkins
2009-04-15 15:49       ` archlinux 2.6.28 ac oops (was Re: Regression: EEE PC hangs when booting off battery) Len Brown

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=49E456B5.6030006@tuffmail.co.uk \
    --to=alan-jenkins@tuffmail.co.uk \
    --cc=arjan@infradead.org \
    --cc=bjorn.helgaas@hp.com \
    --cc=kernel-testers@vger.kernel.org \
    --cc=linux-acpi@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=venkatesh.pallipadi@intel.com \
    /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;
as well as URLs for NNTP newsgroup(s).