[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4A1C7EF9.2030000@gmail.com>
Date: Tue, 26 May 2009 17:44:57 -0600
From: Robert Hancock <hancockrwd@...il.com>
To: Alan Cox <alan@...rguk.ukuu.org.uk>
CC: Tejun Heo <tj@...nel.org>, linux-pci@...r.kernel.org,
Greg KH <greg@...ah.com>,
Linux Kernel <linux-kernel@...r.kernel.org>, towerlexa@....de
Subject: Re: Who's responsible for configuring CLS on a cardbus device?
Alan Cox wrote:
> On Tue, 26 May 2009 22:05:08 +0900
> Tejun Heo <tj@...nel.org> wrote:
>
>> Hello,
>>
>> This is regarding bko#13257.
>>
>> http://bugzilla.kernel.org/show_bug.cgi?id=13257
>>
>> towerlexa@....de was experiencing very slow transfer rate when using a
>> cardbus sata_sil SATA controller which is known to be sensitive to
>> cache line size setting. The reset default is zero and no one
>> configured it causing poor performance.
>>
>> This is solvable by simply setting CLS to the correct value but who's
>> job is it? For non-hotplug devices, this is configured by the BIOS
>> (at least on PC), so for hotplug devices I think falls on the lap of
>> the PCI code but I'm not sure. If this is something which the
>> sata_sil driver should be responsible for, is there an established way
>> to determine the proper CLS value?
>
> Currently its handled by pci_set_mwi() but there isn't actually a more
> direct way to do this.
Yeah, I guess the assumption is that unless the device is using MWI it
doesn't care about cache line size. However, in the case of the sata_sil
controllers (and possibly other devices), the device cares about it for
other purposes (I think it's FIFO handling in this case).
Maybe we should just be setting the cache line size somewhere more
basic, like pci_set_master or something?
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists