Indan Zupancic wrote:
> Using sata_sil (SiI 3512) with a ST3120827AS disk here.
>
> For me the COMRESET happens after resume (s2ram):
>
> [ 2.174342] sd 0:0:0:0: [sda] Starting disk
> [ 2.476407] ata1: device not ready (errno=-19), forcing hardreset
> [ 2.476429] ata2: SATA link down (SStatus 0 SControl 310)
> [ 2.931793] ata1: COMRESET failed (errno=-19)
> [ 2.931797] ata1: reset failed (errno=-19), retrying in 10 secs
> [ 12.918421] ata1: SATA link up 1.5 Gbps (SStatus 113 SControl 310)
> [ 12.921957] ata1.00: ata_hpa_resize 1: sectors = 234441648, hpa_sectors = 234441648
> [ 12.925908] ata1.00: ata_hpa_resize 1: sectors = 234441648, hpa_sectors = 234441648
>
> With your patch applied the output is:
>
> [ 2.173369] sd 0:0:0:0: [sda] Starting disk
> [ 2.475431] ata1: device not ready (errno=-19), forcing hardreset
> [ 2.475453] ata2: SATA link down (SStatus 0 SControl 310)
> [ 3.592930] ata1: COMRESET failed (errno=-19)
> [ 3.592934] ata1: reset failed (errno=-19), retrying in 9 secs
> [ 12.917446] ata1: SATA link up 1.5 Gbps (SStatus 113 SControl 310)
> [ 12.920969] ata1.00: ata_hpa_resize 1: sectors = 234441648, hpa_sectors = 234441648
> [ 12.924945] ata1.00: ata_hpa_resize 1: sectors = 234441648, hpa_sectors = 234441648
>
> Resume takes now ten seconds or more, while it used to take only a few seconds,
> what changed? A few kernel versions ago (2.6.21-rc or so?) it retried in 5 seconds
> instead of 10, but even that is too long.
There are two different things at play here...
1. We dropped libata specific suspend/resume implementation in favor of
sd driven one. Unfortunately, the new implementation currently can't do
background spinup, so that's probably why you can feel the delay. We
need to figure out how to do background spinup with the new implementation.
2. To make reset finish in defined time, each reset try now has defined
deadlines. I was trying to be conservative so I chose 10sec for the
first try. It's driven by timing table near the top of libata-eh.c, so
adjusting the table is easy and maybe we can be a bit more aggressive
with the first two tries. But if we solve #1, this shouldn't matter too
much.
So, it's the unfortunate combination of the above two.
> Maybe a silly question, but why do we wait for the harddisk to show up? Maybe that
> makes a little bit of sense at bootup, but for resume from ram, where nothing is
> supposed to have changed, it seems a bit strange. Why not wait when something tries
> to access the harddisk or something?
I hope it's explained now.
> I wonder if sil_pci_device_resume() and sd_resume() know about each other...
> I'll disable sd_resume() and see how that goes.
Yeap, that should work. In most configurations, devices spin up
immediately after power is restored. sd_resume() just waits for the
device to be revalidated in such cases.
--
tejun
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]