aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorTony Battersby <tonyb@cybernetics.com>2009-01-08 12:59:08 -0500
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2009-03-12 13:58:17 -0400
commit058bb82c5628c88af802c19e2b56ae43551552d5 (patch)
treedf80096b1e7a1bb58ffe27e95c059c2ea3701d0a /drivers
parentc2fd206e08cd55e7ee0d865affc172eb5af01c16 (diff)
[SCSI] sym53c8xx: don't flood syslog with negotiation messages
sym53c8xx prints a negotiation message after every check condition. This can add up to a lot of messages for removable-medium devices (CD-ROM, tape drives, etc.) that are being polled, since they return check condition when no medium is present. This patch suppresses the negotiation message if it would be the same as the last one printed. Signed-off-by: Tony Battersby <tonyb@cybernetics.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/sym53c8xx_2/sym_hipd.c29
-rw-r--r--drivers/scsi/sym53c8xx_2/sym_hipd.h3
2 files changed, 29 insertions, 3 deletions
diff --git a/drivers/scsi/sym53c8xx_2/sym_hipd.c b/drivers/scsi/sym53c8xx_2/sym_hipd.c
index fe6359d4e1ef..ccea7db59f49 100644
--- a/drivers/scsi/sym53c8xx_2/sym_hipd.c
+++ b/drivers/scsi/sym53c8xx_2/sym_hipd.c
@@ -2039,6 +2039,29 @@ static void sym_settrans(struct sym_hcb *np, int target, u_char opts, u_char ofs
2039 } 2039 }
2040} 2040}
2041 2041
2042static void sym_announce_transfer_rate(struct sym_tcb *tp)
2043{
2044 struct scsi_target *starget = tp->starget;
2045
2046 if (tp->tprint.period != spi_period(starget) ||
2047 tp->tprint.offset != spi_offset(starget) ||
2048 tp->tprint.width != spi_width(starget) ||
2049 tp->tprint.iu != spi_iu(starget) ||
2050 tp->tprint.dt != spi_dt(starget) ||
2051 tp->tprint.qas != spi_qas(starget) ||
2052 !tp->tprint.check_nego) {
2053 tp->tprint.period = spi_period(starget);
2054 tp->tprint.offset = spi_offset(starget);
2055 tp->tprint.width = spi_width(starget);
2056 tp->tprint.iu = spi_iu(starget);
2057 tp->tprint.dt = spi_dt(starget);
2058 tp->tprint.qas = spi_qas(starget);
2059 tp->tprint.check_nego = 1;
2060
2061 spi_display_xfer_agreement(starget);
2062 }
2063}
2064
2042/* 2065/*
2043 * We received a WDTR. 2066 * We received a WDTR.
2044 * Let everything be aware of the changes. 2067 * Let everything be aware of the changes.
@@ -2064,7 +2087,7 @@ static void sym_setwide(struct sym_hcb *np, int target, u_char wide)
2064 spi_qas(starget) = 0; 2087 spi_qas(starget) = 0;
2065 2088
2066 if (sym_verbose >= 3) 2089 if (sym_verbose >= 3)
2067 spi_display_xfer_agreement(starget); 2090 sym_announce_transfer_rate(tp);
2068} 2091}
2069 2092
2070/* 2093/*
@@ -2097,7 +2120,7 @@ sym_setsync(struct sym_hcb *np, int target,
2097 tp->tgoal.check_nego = 0; 2120 tp->tgoal.check_nego = 0;
2098 } 2121 }
2099 2122
2100 spi_display_xfer_agreement(starget); 2123 sym_announce_transfer_rate(tp);
2101} 2124}
2102 2125
2103/* 2126/*
@@ -2125,7 +2148,7 @@ sym_setpprot(struct sym_hcb *np, int target, u_char opts, u_char ofs,
2125 spi_qas(starget) = tp->tgoal.qas = !!(opts & PPR_OPT_QAS); 2148 spi_qas(starget) = tp->tgoal.qas = !!(opts & PPR_OPT_QAS);
2126 tp->tgoal.check_nego = 0; 2149 tp->tgoal.check_nego = 0;
2127 2150
2128 spi_display_xfer_agreement(starget); 2151 sym_announce_transfer_rate(tp);
2129} 2152}
2130 2153
2131/* 2154/*
diff --git a/drivers/scsi/sym53c8xx_2/sym_hipd.h b/drivers/scsi/sym53c8xx_2/sym_hipd.h
index 233a3d0b2cef..61d28fcfffbf 100644
--- a/drivers/scsi/sym53c8xx_2/sym_hipd.h
+++ b/drivers/scsi/sym53c8xx_2/sym_hipd.h
@@ -420,6 +420,9 @@ struct sym_tcb {
420 /* Transfer goal */ 420 /* Transfer goal */
421 struct sym_trans tgoal; 421 struct sym_trans tgoal;
422 422
423 /* Last printed transfer speed */
424 struct sym_trans tprint;
425
423 /* 426 /*
424 * Keep track of the CCB used for the negotiation in order 427 * Keep track of the CCB used for the negotiation in order
425 * to ensure that only 1 negotiation is queued at a time. 428 * to ensure that only 1 negotiation is queued at a time.