Claude Buisson wrote: > Here it is: > > root_at_zaza# camcontrol identify cd0 -v > pass1: Raw identify data: > 0: 85c4 0000 0000 0000 0000 0000 0000 0000 Attached patch should fix the issue. -- Alexander Motin --- sys/ata.h.prev 2010-02-03 19:41:43.000000000 +0200 +++ sys/ata.h 2010-02-26 11:59:24.000000000 +0200 _at__at_ -51,7 +51,7 _at__at_ struct ata_params { #define ATA_RESP_INCOMPLETE 0x0004 /*001*/ u_int16_t cylinders; /* # of cylinders */ - u_int16_t reserved2; +/*002*/ u_int16_t specconf; /* specific configuration */ /*003*/ u_int16_t heads; /* # heads */ u_int16_t obsolete4; u_int16_t obsolete5; --- cam/ata/ata_xpt.c.prev 2010-02-26 12:06:33.000000000 +0200 +++ cam/ata/ata_xpt.c 2010-02-26 12:17:39.000000000 +0200 _at__at_ -788,11 +788,10 _at__at_ noerror: ata_btrim(ident_buf->serial, sizeof(ident_buf->serial)); ata_bpack(ident_buf->serial, ident_buf->serial, sizeof(ident_buf->serial)); /* Device may need spin-up before IDENTIFY become valid. */ - if ((ident_buf->config & ATA_RESP_INCOMPLETE) || - ((ident_buf->support.command2 & ATA_SUPPORT_STANDBY) && - (ident_buf->enabled.command2 & ATA_SUPPORT_STANDBY) && - (ident_buf->support.command2 & ATA_SUPPORT_SPINUP) && - softc->spinup == 0)) { + if ((ident_buf->specconf == 0x37c8 || + ident_buf->specconf == 0x738c) && + ((ident_buf->config & ATA_RESP_INCOMPLETE) || + softc->spinup == 0)) { PROBE_SET_ACTION(softc, PROBE_SPINUP); xpt_release_ccb(done_ccb); xpt_schedule(periph, priority);Received on Fri Feb 26 2010 - 09:40:42 UTC
This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:40:01 UTC