diff options
author | Jan Glauber <jang@linux.vnet.ibm.com> | 2011-01-05 12:47:59 +0100 |
---|---|---|
committer | Martin Schwidefsky <sky@mschwide.boeblingen.de.ibm.com> | 2011-01-05 12:47:29 +0100 |
commit | aa3a41d009d433dd9775b356b2d70551816f1f3c (patch) | |
tree | b1ea7f491edfef628ccd663e1a762f42119114b2 /drivers/s390/net | |
parent | 4bc4e965d3e86897e4c7c487a477ccdf13db5b82 (diff) | |
download | kernel_samsung_smdk4412-aa3a41d009d433dd9775b356b2d70551816f1f3c.zip kernel_samsung_smdk4412-aa3a41d009d433dd9775b356b2d70551816f1f3c.tar.gz kernel_samsung_smdk4412-aa3a41d009d433dd9775b356b2d70551816f1f3c.tar.bz2 |
[S390] qeth: buffer count imbalance
The used buffers counter is not incremented in case of an error so
the counter can become negative. Increment the used buffers counter
before checking for errors.
Signed-off-by: Jan Glauber <jang@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390/net')
-rw-r--r-- | drivers/s390/net/qeth_core_main.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/s390/net/qeth_core_main.c b/drivers/s390/net/qeth_core_main.c index f65320b..29f848b 100644 --- a/drivers/s390/net/qeth_core_main.c +++ b/drivers/s390/net/qeth_core_main.c @@ -2840,6 +2840,7 @@ static void qeth_flush_buffers(struct qeth_qdio_out_q *queue, int index, queue->card->perf_stats.outbound_do_qdio_time += qeth_get_micros() - queue->card->perf_stats.outbound_do_qdio_start_time; + atomic_add(count, &queue->used_buffers); if (rc) { queue->card->stats.tx_errors += count; /* ignore temporary SIGA errors without busy condition */ @@ -2853,7 +2854,6 @@ static void qeth_flush_buffers(struct qeth_qdio_out_q *queue, int index, qeth_schedule_recovery(queue->card); return; } - atomic_add(count, &queue->used_buffers); if (queue->card->options.performance_stats) queue->card->perf_stats.bufs_sent += count; } |