[SCSI] aic79xx: fixup DT setting
authorHannes Reinecke <hare@suse.de>
Thu, 4 Aug 2005 07:16:59 +0000 (09:16 +0200)
committerJames Bottomley <jejb@mulgrave.(none)>
Thu, 4 Aug 2005 22:39:55 +0000 (17:39 -0500)
this patch is just a cross-port of the fixup for aic7xxx DT settings.
As the same restrictions apply for aic79xx also (DT requires wide
transfers) the dt setting routine should be modified equivalently.
And an invalid period setting will be caught by ahd_find_syncrate()
anyway.

Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
drivers/scsi/aic7xxx/aic79xx_osm.c

index 982a74a145f7a5565970ff1e9b9a732e22002ed0..40f32bb239723a4132ace21a777838fd0a8b1130 100644 (file)
@@ -2440,6 +2440,7 @@ static void ahd_linux_set_dt(struct scsi_target *starget, int dt)
        unsigned int ppr_options = tinfo->goal.ppr_options
                & ~MSG_EXT_PPR_DT_REQ;
        unsigned int period = tinfo->goal.period;
+       unsigned int width = tinfo->goal.width;
        unsigned long flags;
 
 #ifdef AHD_DEBUG
@@ -2449,8 +2450,8 @@ static void ahd_linux_set_dt(struct scsi_target *starget, int dt)
 #endif
        if (dt) {
                ppr_options |= MSG_EXT_PPR_DT_REQ;
-               if (period > 9)
-                       period = 9; /* at least 12.5ns for DT */
+               if (!width)
+                       ahd_linux_set_width(starget, 1);
        } else {
                if (period <= 9)
                        period = 10; /* If resetting DT, period must be >= 25ns */