The 80c wire bit is bit 13, not 14. Bit 14 is always 1 if word93 is implemented. This increases the chance of incorrect wire detection especially because host side cable detection is often unreliable and we sometimes soley depend on drive side cable detection. Fix the test and add word93 validity check. Signed-off-by: Tejun Heo <htejun@xxxxxxxxx> --- Thanks for pointing out, fixed accordingly. diff --git a/include/linux/ata.h b/include/linux/ata.h index 1df9416..ea2d597 100644 --- a/include/linux/ata.h +++ b/include/linux/ata.h @@ -347,7 +347,7 @@ static inline int ata_drive_40wire(const u16 *dev_id) { if (ata_id_major_version(dev_id) >= 5 && ata_id_is_sata(dev_id)) return 0; /* SATA */ - if (dev_id[93] & 0x4000) + if ((dev_id[93] & 0xC000) == 0x4000 && (dev_id[93] & 0x2000)) return 0; /* 80 wire */ return 1; } - To unsubscribe from this list: send the line "unsubscribe linux-ide" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html