E1000_STAT("uncorr_ecc_errors", uncorr_errors),
        E1000_STAT("corr_ecc_errors", corr_errors),
        E1000_STAT("tx_hwtstamp_timeouts", tx_hwtstamp_timeouts),
+       E1000_STAT("tx_hwtstamp_skipped", tx_hwtstamp_skipped),
 };
 
 #define E1000_GLOBAL_STATS_LEN ARRAY_SIZE(e1000_gstrings_stats)
 
                             nr_frags);
        if (count) {
                if (unlikely(skb_shinfo(skb)->tx_flags & SKBTX_HW_TSTAMP) &&
-                   (adapter->flags & FLAG_HAS_HW_TIMESTAMP) &&
-                   !adapter->tx_hwtstamp_skb) {
-                       skb_shinfo(skb)->tx_flags |= SKBTX_IN_PROGRESS;
-                       tx_flags |= E1000_TX_FLAGS_HWTSTAMP;
-                       adapter->tx_hwtstamp_skb = skb_get(skb);
-                       adapter->tx_hwtstamp_start = jiffies;
-                       schedule_work(&adapter->tx_hwtstamp_work);
+                   (adapter->flags & FLAG_HAS_HW_TIMESTAMP)) {
+                       if (!adapter->tx_hwtstamp_skb) {
+                               skb_shinfo(skb)->tx_flags |= SKBTX_IN_PROGRESS;
+                               tx_flags |= E1000_TX_FLAGS_HWTSTAMP;
+                               adapter->tx_hwtstamp_skb = skb_get(skb);
+                               adapter->tx_hwtstamp_start = jiffies;
+                               schedule_work(&adapter->tx_hwtstamp_work);
+                       } else {
+                               adapter->tx_hwtstamp_skipped++;
+                       }
                }
 
                skb_tx_timestamp(skb);