net/mlx5e: Remove rq references in mlx5e_rx_am
authorAndy Gospodarek <gospo@broadcom.com>
Tue, 9 Jan 2018 21:06:14 +0000 (16:06 -0500)
committerDavid S. Miller <davem@davemloft.net>
Wed, 10 Jan 2018 20:27:35 +0000 (15:27 -0500)
This makes mlx5e_am_sample more generic so that it can be called easily
from a driver that does not use the same data structure to store these
values in a single structure.

Signed-off-by: Andy Gospodarek <gospo@broadcom.com>
Acked-by: Tal Gilboa <talgi@mellanox.com>
Acked-by: Saeed Mahameed <saeedm@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlx5/core/en_dim.h
drivers/net/ethernet/mellanox/mlx5/core/en_rx_am.c
drivers/net/ethernet/mellanox/mlx5/core/en_txrx.c

index 2031a21bc4f298b53c2d644d2a1238c8689207a8..7d5499a3d738e7852e770eceddb17cd6be5b0436 100644 (file)
@@ -66,8 +66,10 @@ struct mlx5e_rx_am { /* Adaptive Moderation */
        u8                                      tired;
 };
 
-struct mlx5e_rq;
-void mlx5e_rx_am(struct mlx5e_rq *rq);
+void mlx5e_rx_am(struct mlx5e_rx_am *am,
+                u16 event_ctr,
+                u64 packets,
+                u64 bytes);
 void mlx5e_rx_am_work(struct work_struct *work);
 struct mlx5e_cq_moder mlx5e_am_get_def_profile(u8 rx_cq_period_mode);
 
index e401d9d245f33e4187c2468f4533df052cdea5ec..1630076844ef7a34965a9d6e4cd204cbc92ef365 100644 (file)
@@ -264,13 +264,15 @@ static bool mlx5e_am_decision(struct mlx5e_rx_am_stats *curr_stats,
        return am->profile_ix != prev_ix;
 }
 
-static void mlx5e_am_sample(struct mlx5e_rq *rq,
+static void mlx5e_am_sample(u16 event_ctr,
+                           u64 packets,
+                           u64 bytes,
                            struct mlx5e_rx_am_sample *s)
 {
        s->time      = ktime_get();
-       s->pkt_ctr   = rq->stats.packets;
-       s->byte_ctr  = rq->stats.bytes;
-       s->event_ctr = rq->cq.event_ctr;
+       s->pkt_ctr   = packets;
+       s->byte_ctr  = bytes;
+       s->event_ctr = event_ctr;
 }
 
 #define MLX5E_AM_NEVENTS 64
@@ -309,20 +311,22 @@ void mlx5e_rx_am_work(struct work_struct *work)
        am->state = MLX5E_AM_START_MEASURE;
 }
 
-void mlx5e_rx_am(struct mlx5e_rq *rq)
+void mlx5e_rx_am(struct mlx5e_rx_am *am,
+                u16 event_ctr,
+                u64 packets,
+                u64 bytes)
 {
-       struct mlx5e_rx_am *am = &rq->am;
        struct mlx5e_rx_am_sample end_sample;
        struct mlx5e_rx_am_stats curr_stats;
        u16 nevents;
 
        switch (am->state) {
        case MLX5E_AM_MEASURE_IN_PROGRESS:
-               nevents = BIT_GAP(BITS_PER_TYPE(u16), rq->cq.event_ctr,
+               nevents = BIT_GAP(BITS_PER_TYPE(u16), event_ctr,
                                  am->start_sample.event_ctr);
                if (nevents < MLX5E_AM_NEVENTS)
                        break;
-               mlx5e_am_sample(rq, &end_sample);
+               mlx5e_am_sample(event_ctr, packets, bytes, &end_sample);
                mlx5e_am_calc_stats(&am->start_sample, &end_sample,
                                    &curr_stats);
                if (mlx5e_am_decision(&curr_stats, am)) {
@@ -332,7 +336,7 @@ void mlx5e_rx_am(struct mlx5e_rq *rq)
                }
                /* fall through */
        case MLX5E_AM_START_MEASURE:
-               mlx5e_am_sample(rq, &am->start_sample);
+               mlx5e_am_sample(event_ctr, packets, bytes, &am->start_sample);
                am->state = MLX5E_AM_MEASURE_IN_PROGRESS;
                break;
        case MLX5E_AM_APPLY_NEW_PROFILE:
index ab92298eafc37b43b21a0f020d841ec82d6a03ab..18491693bf1480d40b78bd44bd7d9b9bd3cf4a39 100644 (file)
@@ -79,7 +79,10 @@ int mlx5e_napi_poll(struct napi_struct *napi, int budget)
                mlx5e_cq_arm(&c->sq[i].cq);
 
        if (MLX5E_TEST_BIT(c->rq.state, MLX5E_RQ_STATE_AM))
-               mlx5e_rx_am(&c->rq);
+               mlx5e_rx_am(&c->rq.am,
+                           c->rq.cq.event_ctr,
+                           c->rq.stats.packets,
+                           c->rq.stats.bytes);
 
        mlx5e_cq_arm(&c->rq.cq);
        mlx5e_cq_arm(&c->icosq.cq);