media: cec: be smarter about detecting the number of attempts made
authorHans Verkuil <hans.verkuil@cisco.com>
Tue, 11 Jul 2017 11:20:18 +0000 (08:20 -0300)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Tue, 18 Jul 2017 15:58:56 +0000 (12:58 -0300)
Some hardware does more than one attempt. So when it calls
cec_transmit_done when an error occurred it will e.g. use an error count
of 2 instead of 1.

The framework always assumed a single attempt, but now it is smarter
and will sum the counters to detect how many attempts were made.

Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/cec/cec-adap.c

index b0bd466f75e2d8efcdf6164931c8f33d9211edd8..1a021828c8d4294ee72462b83b419f53374d159e 100644 (file)
@@ -517,8 +517,13 @@ void cec_transmit_done_ts(struct cec_adapter *adap, u8 status,
 {
        struct cec_data *data;
        struct cec_msg *msg;
+       unsigned int attempts_made = arb_lost_cnt + nack_cnt +
+                                    low_drive_cnt + error_cnt;
 
        dprintk(2, "%s: status %02x\n", __func__, status);
+       if (attempts_made < 1)
+               attempts_made = 1;
+
        mutex_lock(&adap->lock);
        data = adap->transmitting;
        if (!data) {
@@ -551,10 +556,10 @@ void cec_transmit_done_ts(struct cec_adapter *adap, u8 status,
         * the hardware didn't signal that it retried itself (by setting
         * CEC_TX_STATUS_MAX_RETRIES), then we will retry ourselves.
         */
-       if (data->attempts > 1 &&
+       if (data->attempts > attempts_made &&
            !(status & (CEC_TX_STATUS_MAX_RETRIES | CEC_TX_STATUS_OK))) {
                /* Retry this message */
-               data->attempts--;
+               data->attempts -= attempts_made;
                if (msg->timeout)
                        dprintk(2, "retransmit: %*ph (attempts: %d, wait for 0x%02x)\n",
                                msg->len, msg->msg, data->attempts, msg->reply);