struct netdev_queue *net_txq;
        struct mana_stats_tx *tx_stats;
        struct gdma_queue *gdma_sq;
+       int err, len, num_gso_seg;
        unsigned int csum_type;
        struct mana_txq *txq;
        struct mana_cq *cq;
-       int err, len;
 
        if (unlikely(!apc->port_is_up))
                goto tx_drop;
        skb_queue_tail(&txq->pending_skbs, skb);
 
        len = skb->len;
+       num_gso_seg = skb_is_gso(skb) ? skb_shinfo(skb)->gso_segs : 1;
        net_txq = netdev_get_tx_queue(ndev, txq_idx);
 
        err = mana_gd_post_work_request(gdma_sq, &pkg.wqe_req,
        /* skb may be freed after mana_gd_post_work_request. Do not use it. */
        skb = NULL;
 
+       /* Populated the packet and bytes counters based on post GSO packet
+        * calculations
+        */
        tx_stats = &txq->stats;
        u64_stats_update_begin(&tx_stats->syncp);
-       tx_stats->packets++;
-       tx_stats->bytes += len;
+       tx_stats->packets += num_gso_seg;
+       tx_stats->bytes += len + ((num_gso_seg - 1) * gso_hs);
        u64_stats_update_end(&tx_stats->syncp);
 
 tx_busy: