#define atomic_dec_not_zero(v) atomic_add_unless((v), -1, 0)
 
-#define IPA_REPLENISH_BATCH    16
+/* Hardware is told about receive buffers once a "batch" has been queued */
+#define IPA_REPLENISH_BATCH    16              /* Must be non-zero */
 
 /* The amount of RX buffer space consumed by standard skb overhead */
 #define IPA_RX_BUFFER_OVERHEAD (PAGE_SIZE - SKB_MAX_ORDER(NET_SKB_PAD, 0))
                return;
 
        while ((trans = ipa_endpoint_trans_alloc(endpoint, 1))) {
+               bool doorbell;
+
                if (ipa_endpoint_replenish_one(endpoint, trans))
                        goto try_again_later;
 
-               if (++endpoint->replenish_ready == IPA_REPLENISH_BATCH)
-                       endpoint->replenish_ready = 0;
 
                /* Ring the doorbell if we've got a full batch */
-               gsi_trans_commit(trans, !endpoint->replenish_ready);
+               doorbell = !(++endpoint->replenish_count % IPA_REPLENISH_BATCH);
+               gsi_trans_commit(trans, doorbell);
        }
 
        clear_bit(IPA_REPLENISH_ACTIVE, endpoint->replenish_flags);
        enum ipa_endpoint_name name;
        u32 filter_map;
 
+       BUILD_BUG_ON(!IPA_REPLENISH_BATCH);
+
        if (!ipa_endpoint_data_valid(ipa, count, data))
                return 0;       /* Error */
 
 
  * @evt_ring_id:       GSI event ring used by the endpoint
  * @netdev:            Network device pointer, if endpoint uses one
  * @replenish_flags:   Replenishing state flags
- * @replenish_ready:   Number of replenish transactions without doorbell
+ * @replenish_count:   Total number of replenish transactions committed
  * @replenish_work:    Work item used for repeated replenish failures
  */
 struct ipa_endpoint {
 
        /* Receive buffer replenishing for RX endpoints */
        DECLARE_BITMAP(replenish_flags, IPA_REPLENISH_COUNT);
-       u32 replenish_ready;
+       u64 replenish_count;
        struct delayed_work replenish_work;             /* global wq */
 };