Re: [BISECTED] EEE PC hangs when booting off battery

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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.
> 
> >>>>> 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@xxxxxx>
> >> 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@xxxxxx>
> >>     CC: Zhang Rui <rui.zhang@xxxxxxxxx>
> >>     CC: Zhao Yakui <yakui.zhao@xxxxxxxxx>
> >>     CC: Venki Pallipadi <venkatesh.pallipadi@xxxxxxxxx>
> >>     CC: Anil S Keshavamurthy <anil.s.keshavamurthy@xxxxxxxxx>
> >>     Signed-off-by: Len Brown <len.brown@xxxxxxxxx>
> >>
> >> 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.

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.

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

[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux