Date: Mon, 22 Dec 2003 17:31:34 -0500 From: Jesse Guardiani <jesse@wingnet.net> To: freebsd-current@freebsd.org Subject: Re: Tracking down ata0 reset hang Message-ID: <bs7rc7$bar$1@sea.gmane.org> References: <brav17$jpb$1@sea.gmane.org> <200312120730.hBC7UG44048085@spider.deepcore.dk> <brcjv8$bej$1@sea.gmane.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Jesse Guardiani wrote: > Soren Schmidt wrote: > >> It seems Jesse Guardiani wrote: >>> Nate Lawson wrote: >>> >>> > I have a laptop that suspends and resumes fine. Soeren's patch to >>> > properly reset the hardware after the ATAng import fixed the problem >>> > where resuming would hang in ata0 reset with the hard drive light on. >>> > >>> > Sometime in the last month or two, the ATA reset phase of resume has >>> > begun hanging again with the drive light on and I can't break to the >>> > debugger. The interesting data point is that if I suspend/resume in >>> > single user >>> > mode, it works fine, including the reset. But in multi-user mode, it >>> > hangs. I'm trying to disable various services to see if any of them >>> > triggers the hang. >>> > >>> > Has anyone else seen this regression? >> >> I cant suspend/resume at all on my ASUS, it locks up somwhere long before >> it gets to ATA. However it worked on my old Dell until about a month ago >> when it ended its lifetime. > > Have you tried detaching any and all peripheral drives before suspending? > In 5.1-RELEASE I had to issue an `atacontrol detach 1` before suspending > or else it would lock up on resume. > > Have you tried loading 5.1-RELEASE on the ASUS and seeing if it works > then? > > > [...] > >> I dont think this is an ATA issue, I think the new acpi/interrupt code is >> not setting up things as they should on resume. > > Is this code active even with acpi disabled? Like I said, it happens when > using APM or ACPI. > > >> That said I'm interested >> in getting this to work as well, but so far I dont even make it to ATA >> during resume... > > I'd ship you my laptop, but I need it for work. :) Hi Soren (I'd spell the 'o' correctly, but I don't know the keystroke combo for it...) and the rest of you kernel gurus, I found something interesting out today. If I boot with 'boot -v -D' then I can successfully suspend and resume with APM. If I boot with either 'boot -v' or 'boot -D' alone, I cannot! Here's the verbose suspend/resume cycle: Lock GEOM topology not exclusively locked @ ../../. ./geom/geom_subr.c:261 acd0: WARNING - removed from configuration pcib2: device pccard0 requested decoded I/O range 0x3e8-0x3ef sio4: detached pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 0:29 INTA BIOS irq 9 pci_cfgintr_valid: BIOS irq 11 is valid pci_cfgintr: 0:29 INTB BIOS irq 11 pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 0:29 INTC BIOS irq 9 pci_cfgintr_valid: BIOS irq 5 is valid pci_cfgintr: 0:31 INTB BIOS irq 5 pci_cfgintr_valid: BIOS irq 5 is valid pci_cfgintr: 0:31 INTB BIOS irq 5 pci_cfgintr_valid: BIOS irq 5 is valid pci_cfgintr: 0:31 INTB BIOS irq 5 pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 1:0 INTA BIOS irq 9 pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 2:0 INTA BIOS irq 9 pci_cfgintr_valid: BIOS irq 5 is valid pci_cfgintr: 2:0 INTB BIOS irq 5 pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 2:0 INTC BIOS irq 9 pci_cfgintr_valid: BIOS irq 9 is valid pci_cfgintr: 2:2 INTA BIOS irq 9 pci_cfgintr_valid: BIOS irq 10 is valid pci_cfgintr: 2:8 INTA BIOS irq 10 atkbd: the current kbd controller command byte 0047 atkbd: keyboard ID 0x54ab (2) ata0: resetting devices .. ata0: reset tp1 mask=03 ostat0=50 ostat1=00 ad0: stat=0x50 err=0x01 lsb=0x00 msb=0x00 ata0-slave: stat=0x00 err=0x01 lsb=0x00 msb=0x00 ata0: reset tp2 mask=03 stat0=50 stat1=00 devices=0x1<ATA_MASTER> ad0: pio=0x0c wdma=0x22 udma=0x45 cable=80pin ad0: setting PIO4 on Intel ICH3 chip <hangs here normally> ad0: setting UDMA100 on Intel ICH3 chip ad0: setting UDMA100 on Intel ICH3 chip done start (88000000) < sc->membase (c0200000) end (ffffffff) > sc->memlimit (cfffffff) start (88000000) < sc->pmembase (e8000000) end (ffffffff) > sc->pmemlimit (cfffffff) pcib2: device pccard0 requested decoded memory range 0x88000000-0xffffffff pccard0: CIS version PC Card Standard 5.0 pccard0: CIS info: 3Com Megahertz, 3CXM756/3CCM756 pccard0: Manufacturer code 0x101, product 0x3f pccard0: function 0: serial port, ccr addr 300 mask 17 pccard0: function 0, config table entry 32: I/O card; irq mask ffff; iomask a, i ospace 3f8-3ff; rdybsy_active io8 irqlevel powerdown audio pccard0: function 0, config table entry 33: I/O card; irq mask ffff; iomask a, i ospace 2f8-2ff; rdybsy_active io8 irqlevel powerdown audio pccard0: function 0, config table entry 34: I/O card; irq mask ffff; iomask a, i ospace 3e8-3ef; rdybsy_active io8 irqlevel powerdown audio pccard0: function 0, config table entry 35: I/O card; irq mask ffff; iomask a, i ospace 2e8-2ef; rdybsy_active io8 irqlevel powerdown audio pcib2: device pccard0 requested decoded I/O range 0x3f8-0x3ff pccard0: Allocation failed for cfe 32 pcib2: device pccard0 requested decoded I/O range 0x2f8-0x2ff pccard0: Allocation failed for cfe 33 pcib2: device pccard0 requested decoded I/O range 0x3e8-0x3ef start (88000000) < sc->membase (c0200000) end (ffffffff) > sc->memlimit (cfffffff) start (88000000) < sc->pmembase (e8000000) end (ffffffff) > sc->pmemlimit (cfffffff) pcib2: device pccard0 requested decoded memory range 0x88000000-0xffffffff sio4: <3Com Megahertz 3CXM756/3CCM756> at port 0x3e8-0x3ef irq 9 function 0 conf ig 34 on pccard0 pcib2: device sio4 requested decoded I/O range 0x3e8-0x3ef pcib2: device pccard0 requested decoded I/O range 0x3e8-0x3ef pcib2: device sio4 requested decoded I/O range 0x3e8-0x3ef sio4: type 16550A sio4: unable to activate interrupt in fast mode - using normal mode ata1: reset tp1 mask=03 ostat0=50 ostat1=00 ata1-master: stat=0x00 err=0x01 lsb=0x14 msb=0xeb ata1-slave: stat=0x00 err=0x01 lsb=0x14 msb=0xeb ata1: reset tp2 mask=03 stat0=00 stat1=00 devices=0xc<ATAPI_SLAVE,ATAPI_MASTER> ata1: [MPSAFE] Dec 22 13:59:25 trevarthan kernel: wakeup from sleeping state (slept 00:00:13) Dec 22 13:59:25 trevarthan kernel: kbdc: RESET_KBD return code:00fa Dec 22 13:59:25 trevarthan kernel: kbdc: RESET_KBD status:00aa Dec 22 13:59:25 trevarthan kernel: stray irq15 ata1-master: pio=0x0c wdma=0x22 udma=0x42 cable=40pin ata1-master: setting PIO4 on Intel ICH3 chip ata1-master: setting UDMA33 on Intel ICH3 chip acd0: <HL-DT-STDVD-ROM GDR8081N/0011> DVDROM drive at ata1 as master acd0: read 1722KB/s (4134KB/s), 512KB buffer, UDMA33 acd0: Reads: CDR, CDRW, CDDA stream, DVDROM, DVDR, DVDRAM, packet acd0: Writes: acd0: Audio: play, 256 volume levels acd0: Mechanism: ejectable tray, unlocked acd0: Medium: 120mm data disc Pretty darn wierd. Anyone have any ideas as to why it works when the serial console AND verbose boot is enabled? -- Jesse Guardiani, Systems Administrator WingNET Internet Services, P.O. Box 2605 // Cleveland, TN 37320-2605 423-559-LINK (v) 423-559-5145 (f) http://www.wingnet.net
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?bs7rc7$bar$1>