From mboxrd@z Thu Jan 1 00:00:00 1970 From: Robert Hancock Subject: Re: Kernel 2.6.30rc7 limits IDE to UDMA33 Date: Fri, 05 Jun 2009 19:07:47 -0600 Message-ID: <4A29C163.3080706@gmail.com> References: <4A25F688.9000407@gmail.com> <20090603131407.57c490ed@lxorguk.ukuu.org.uk> <20090603140140.491a8ea8@lxorguk.ukuu.org.uk> <20090605100505.41b3b818@lxorguk.ukuu.org.uk> <20090605114245.175499e1@lxorguk.ukuu.org.uk> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from yw-out-2324.google.com ([74.125.46.31]:8465 "EHLO yw-out-2324.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752979AbZFFBHt (ORCPT ); Fri, 5 Jun 2009 21:07:49 -0400 In-Reply-To: <20090605114245.175499e1@lxorguk.ukuu.org.uk> Sender: linux-ide-owner@vger.kernel.org List-Id: linux-ide@vger.kernel.org To: Alan Cox Cc: Grozdan , linux-kernel@vger.kernel.org, linux-ide@vger.kernel.org Alan Cox wrote: >> I've relayed your reply to the pata_amd user on the forum. As for my >> case with pata_via, until this is fixed, is there any way to force it >> to use a higher UDMA? Is there a flag that can be passed in, for > > In your case given the BIOS appears to be informing us you have a 40wire > cable there isn't much that can be fixed > >> example, in /sys somewhere? hdparm fails to set a higher UDMA and I >> looked at sdparm but don't see anything in it to increase UDMA... > > Tejun some time ago added stuff to override all of these things: > > See Documentation/kernel-parameters.txt > > libata.force= > > which will let you override all sorts of autodetection for quirky boards I wouldn't rule out the possibility of a bug. The code in pata_via looks a bit fishy, it reports a 40-wire cable if either the GTM data wasn't present or valid, or if it reports a mode of UDMA2 or less. In the former case it seems like ATA_CABLE_PATA_UNK would be the safer choice since we really don't know, and we should then use drive-side detection, rather than assuming a 40-wire cable by default..