Re: [PATCH] libata-sff: fix 32-bit PIO regression

From: Sergei Shtylyov
Date: Sun Feb 08 2009 - 19:03:39 EST


Hello

Mikael Pettersson wrote:
Sergei Shtylyov writes:
> Hello.
> > Hugh Dickins wrote:
> > >> Commit 871af1210f13966ab911ed2166e4ab2ce775b99d (libata: Add 32bit PIO support)
> >> caused all kind of errors on the ATAPI devices, so it's been empirically proven
> >> that one shouldn't read/write an extra data word when a device isn't expecting
> >> it already. "Don't do it then"; however still taking a chance to use 32-bit I/O
> >> one last time when there are exactly 3 trailing bytes. Oh, and stop pointless
> >> swapping bytes to and fro as well by using io*_rep() which shouldn't byte-swap.
> >>
> >> This should fix the kernel.org bug #12609.
> >>
> >> ---
> >> This is hopefully better replacement for Hugh Dickins most recent patch
> >> (http://marc.info/?l=linux-ide&m=123352294619281)...
> >> > >
> > Yes, looks nice, and works for me. My only criticism would be,
> > minor issue unchanged by your patch, that actually "slop" isn't
> > unlikely enough to deserve an "unlikely" - slop of 1 or 3 is
> > unlikely, but slop of 2 is quite common.
> > > > I guess that's the case only for the ATAPI devices, so I'm going to > keep it.

I really don't think it's a good idea to play micro-optimisation
unlikely() tricks when the likelihood depends on what kind of device
the driver is talking to. In this case unlikely() is clearly wrong.

Clearly?! :-O
Do you really think that the transfers having lengths non-divisible by 4 make any *significant* percentage even on the ATAPI devices? I think it's you who is really wrong.

MBR, Sergei


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/