/*
  * Timer values
  */
-#define SSIF_MSG_USEC          60000   /* 60ms between message tries. */
+#define SSIF_MSG_USEC          60000   /* 60ms between message tries (T3). */
+#define SSIF_REQ_RETRY_USEC    60000   /* 60ms between send retries (T6). */
 #define SSIF_MSG_PART_USEC     5000    /* 5ms for a message part */
 
 /* How many times to we retry sending/receiving the message. */
 #define        SSIF_RECV_RETRIES       250
 
 #define SSIF_MSG_MSEC          (SSIF_MSG_USEC / 1000)
+#define SSIF_REQ_RETRY_MSEC    (SSIF_REQ_RETRY_USEC / 1000)
 #define SSIF_MSG_JIFFIES       ((SSIF_MSG_USEC * 1000) / TICK_NSEC)
+#define SSIF_REQ_RETRY_JIFFIES ((SSIF_REQ_RETRY_USEC * 1000) / TICK_NSEC)
 #define SSIF_MSG_PART_JIFFIES  ((SSIF_MSG_PART_USEC * 1000) / TICK_NSEC)
 
 /*
        bool                got_alert;
        bool                waiting_alert;
 
+       /* Used to inform the timeout that it should do a resend. */
+       bool                do_resend;
+
        /*
         * If set to true, this will request events the next time the
         * state machine is idle.
                  ssif_info->recv, I2C_SMBUS_BLOCK_DATA);
 }
 
+static void start_resend(struct ssif_info *ssif_info);
+
 static void retry_timeout(struct timer_list *t)
 {
        struct ssif_info *ssif_info = from_timer(ssif_info, t, retry_timer);
        unsigned long oflags, *flags;
-       bool waiting;
+       bool waiting, resend;
 
        if (ssif_info->stopping)
                return;
 
        flags = ipmi_ssif_lock_cond(ssif_info, &oflags);
+       resend = ssif_info->do_resend;
+       ssif_info->do_resend = false;
        waiting = ssif_info->waiting_alert;
        ssif_info->waiting_alert = false;
        ipmi_ssif_unlock_cond(ssif_info, flags);
 
        if (waiting)
                start_get(ssif_info);
+       if (resend)
+               start_resend(ssif_info);
 }
 
 static void watch_timeout(struct timer_list *t)
                start_get(ssif_info);
 }
 
-static void start_resend(struct ssif_info *ssif_info);
-
 static void msg_done_handler(struct ssif_info *ssif_info, int result,
                             unsigned char *data, unsigned int len)
 {
        if (result < 0) {
                ssif_info->retries_left--;
                if (ssif_info->retries_left > 0) {
-                       start_resend(ssif_info);
+                       /*
+                        * Wait the retry timeout time per the spec,
+                        * then redo the send.
+                        */
+                       ssif_info->do_resend = true;
+                       mod_timer(&ssif_info->retry_timer,
+                                 jiffies + SSIF_REQ_RETRY_JIFFIES);
                        return;
                }
 
        ret = i2c_smbus_write_block_data(client, SSIF_IPMI_REQUEST, len, msg);
        if (ret) {
                retry_cnt--;
-               if (retry_cnt > 0)
+               if (retry_cnt > 0) {
+                       msleep(SSIF_REQ_RETRY_MSEC);
                        goto retry1;
+               }
                return -ENODEV;
        }
 
                                         32, msg);
        if (ret) {
                retry_cnt--;
-               if (retry_cnt > 0)
+               if (retry_cnt > 0) {
+                       msleep(SSIF_REQ_RETRY_MSEC);
                        goto retry_write;
+               }
                dev_err(&client->dev, "Could not write multi-part start, though the BMC said it could handle it.  Just limit sends to one part.\n");
                return ret;
        }