[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <87sksmmmx4.fsf@denkblock.local>
Date: Sat, 30 Aug 2008 19:29:27 +0200
From: Elias Oltmanns <eo@...ensachen.de>
To: Sergei Shtylyov <sshtylyov@...mvista.com>
Cc: Alan Cox <alan@...rguk.ukuu.org.uk>,
Andrew Morton <akpm@...ux-foundation.org>,
Bartlomiej Zolnierkiewicz <bzolnier@...il.com>,
Jeff Garzik <jeff@...zik.org>,
Randy Dunlap <randy.dunlap@...cle.com>,
Tejun Heo <htejun@...il.com>, linux-ide@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH 1/4] Introduce ata_id_has_unload()
Sergei Shtylyov <sshtylyov@...mvista.com> wrote:
> Hello.
>
> Elias Oltmanns wrote:
>
>> Add a function to check an ATA device's id for head unload support as
>> specified in ATA-7.
>>
>> Signed-off-by: Elias Oltmanns <eo@...ensachen.de>
>>
> [...]
>> diff --git a/include/linux/ata.h b/include/linux/ata.h
>> index 80364b6..d9a94bd 100644
>> --- a/include/linux/ata.h
>> +++ b/include/linux/ata.h
>> @@ -707,6 +707,23 @@ static inline int ata_id_has_dword_io(const u16 *id)
>> return 0;
>> }
>> +static inline int ata_id_has_unload(const u16 *id)
>> +{
>> + /*
>> + * ATA-7 specifies two places to indicate unload feature
>> + * support. Since I don't really understand the difference,
>> + * I'll just check both and only return zero if none of them
>> + * indicates otherwise.
>>
>
> If you read the comments to the words 82:84 and 85:87, they say that
> the former indicate the supported features, and the latter indicate
> the enabed features AND in case a feature can't be disabled, the
> latter words will have the corresponding bit set. So it should be
> sufficient to check only one word.
Yes, I tend to agree with you and, in fact, I have been leaning in this
direction myself. However, there is something that really bothers me.
Both entries describing bit 13 of word 87 and 84 are worded alike. In
particular, it says *supported* in both places, whereas in the case of the
other features it would say enabled in one and supported in the other
place.
Well, I'm willing to drop the check for word 87 since I don't like it
myself. Due to my lack of personal experience with inexplicable
implemenations of ATA standards in hardware though, I have to take your
word that this is safe.
>
>> + */
>> + if (ata_id_major_version(id) >= 7
>> + && (((id[ATA_ID_CFSSE] & 0xC000) == 0x4000
>> + && id[ATA_ID_CFSSE] & (1 << 13))
>> + || ((id[ATA_ID_CSF_DEFAULT] & 0xC000) == 0x4000
>> + && (id[ATA_ID_CSF_DEFAULT] & (1 << 13)))))
>>
>
>
> I think that it's preferrable to leave the operator on the same line
> with the first operand...
Not having too strong an opinion about it, I just thought that an
operator at the beginning of the line was another indication (apart from
indentation) that this still belongs to the condition. Still, I can
change it for the next series round.
Regards,
Elias
--
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