]> git.droids-corp.org - dpdk.git/commitdiff
net/mlx5: use mask for meter register setting
authorShun Hao <shunh@nvidia.com>
Tue, 20 Apr 2021 10:55:12 +0000 (13:55 +0300)
committerRaslan Darawsheh <rasland@nvidia.com>
Wed, 21 Apr 2021 06:27:52 +0000 (08:27 +0200)
ASO (Advanced Steering Operation) meter feature may require
to locate the flow context tag action after the ASO action.
When color register is shared by meter_id/flow_id, it's like:
Bits[0-7] A meter color value set by the HW.
Bits[8-31] A flow id and meter id set by SW.

Currently the tag action for meter writes all the bits
of the meter register, so it will potentially overwrite
meter color when ASO meter action is before the tag action.

Set only 24-MSB-bits of meter register in the meter tag action.

Signed-off-by: Shun Hao <shunh@nvidia.com>
Acked-by: Matan Azrad <matan@nvidia.com>
drivers/net/mlx5/mlx5_flow.c
drivers/net/mlx5/mlx5_flow.h
drivers/net/mlx5/mlx5_flow_dv.c

index 3bb04d58c905980e6ec1293616766d8ac82b09e6..1afddf73610953eac3461d85648af40b446b037d 100644 (file)
@@ -4258,9 +4258,11 @@ flow_hairpin_split(struct rte_eth_dev *dev,
        rte_memcpy(actions_rx, actions, sizeof(struct rte_flow_action));
        actions_rx++;
        set_tag = (void *)actions_rx;
-       set_tag->id = mlx5_flow_get_reg_id(dev, MLX5_HAIRPIN_RX, 0, NULL);
+       *set_tag = (struct mlx5_rte_flow_action_set_tag) {
+               .id = mlx5_flow_get_reg_id(dev, MLX5_HAIRPIN_RX, 0, NULL),
+               .data = flow_id,
+       };
        MLX5_ASSERT(set_tag->id > REG_NON);
-       set_tag->data = flow_id;
        tag_action->conf = set_tag;
        /* Create Tx item list. */
        rte_memcpy(actions_tx, actions, sizeof(struct rte_flow_action));
@@ -4496,6 +4498,14 @@ flow_meter_split_prep(struct rte_eth_dev *dev,
        set_tag = (struct mlx5_rte_flow_action_set_tag *)actions_pre;
        tag_item_spec = (struct mlx5_rte_flow_item_tag *)sfx_items;
        tag_item_mask = tag_item_spec + 1;
+       /* Both flow_id and meter_id share the same register. */
+       *set_tag = (struct mlx5_rte_flow_action_set_tag) {
+               .id = (enum modify_reg)mlx5_flow_get_reg_id(dev, MLX5_MTR_ID,
+                                                           0, error),
+               .offset = mtr_id_offset,
+               .length = mtr_reg_bits,
+               .data = fm->idx,
+       };
        /*
         * The color Reg bits used by flow_id are growing from
         * msb to lsb, so must do bit reverse for flow_id val in RegC.
@@ -4503,13 +4513,9 @@ flow_meter_split_prep(struct rte_eth_dev *dev,
        for (shift = 0; shift < flow_id_bits; shift++)
                flow_id_reversed = (flow_id_reversed << 1) |
                              ((flow_id >> shift) & 0x1);
-       /* Both flow_id and meter_id share the same register. */
-       set_tag->id = mlx5_flow_get_reg_id(dev, MLX5_MTR_ID, 0, error);
-       set_tag->data =
-               (fm->idx | (flow_id_reversed << (mtr_reg_bits - flow_id_bits)))
-               << mtr_id_offset;
+       set_tag->data |= flow_id_reversed << (mtr_reg_bits - flow_id_bits);
        tag_item_spec->id = set_tag->id;
-       tag_item_spec->data = set_tag->data;
+       tag_item_spec->data = set_tag->data << mtr_id_offset;
        tag_item_mask->data = UINT32_MAX << mtr_id_offset;
        tag_action->type = (enum rte_flow_action_type)
                                MLX5_RTE_FLOW_ACTION_TYPE_TAG;
@@ -4904,10 +4910,12 @@ flow_sample_split_prep(struct rte_eth_dev *dev,
                ret = mlx5_flow_get_reg_id(dev, MLX5_APP_TAG, 0, error);
                if (ret < 0)
                        return ret;
-               set_tag->id = ret;
                mlx5_ipool_malloc(priv->sh->ipool
                                  [MLX5_IPOOL_RSS_EXPANTION_FLOW_ID], &tag_id);
-               set_tag->data = tag_id;
+               *set_tag = (struct mlx5_rte_flow_action_set_tag) {
+                       .id = ret,
+                       .data = tag_id,
+               };
                /* Prepare the suffix subflow items. */
                tag_spec = (void *)(sfx_items + SAMPLE_SUFFIX_ITEM);
                tag_spec->data = tag_id;
index 3145f8f5acd4875cc8f5087ac95657bbb6a8cdb7..0806407b0a1e2229d6345d6bdf8e949468ebdf1b 100644 (file)
@@ -54,6 +54,8 @@ struct mlx5_rte_flow_item_tag {
 /* Modify selected register. */
 struct mlx5_rte_flow_action_set_tag {
        enum modify_reg id;
+       uint8_t offset;
+       uint8_t length;
        uint32_t data;
 };
 
index d4d4c1b22355c7e8ff3c6b087ed58bdd50196d7b..4b6b62c48dc74f05715210a8bb4c18d2f491e29a 100644 (file)
@@ -965,6 +965,8 @@ flow_dv_convert_action_set_reg
        actions[i] = (struct mlx5_modification_cmd) {
                .action_type = MLX5_MODIFICATION_TYPE_SET,
                .field = reg_to_field[conf->id],
+               .offset = conf->offset,
+               .length = conf->length,
        };
        actions[i].data0 = rte_cpu_to_be_32(actions[i].data0);
        actions[i].data1 = rte_cpu_to_be_32(conf->data);