root/drivers/net/ethernet/mellanox/mlx5/core/steering/sws/dr_ste_v2.h
/* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
/* Copyright (c) 2024, NVIDIA CORPORATION & AFFILIATES. All rights reserved. */

#ifndef _DR_STE_V2_
#define _DR_STE_V2_

enum {
        DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_0              = 0x00,
        DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_1              = 0x01,
        DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_2              = 0x02,
        DR_STE_V2_ACTION_MDFY_FLD_SRC_L2_OUT_0          = 0x08,
        DR_STE_V2_ACTION_MDFY_FLD_SRC_L2_OUT_1          = 0x09,
        DR_STE_V2_ACTION_MDFY_FLD_L3_OUT_0              = 0x0e,
        DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_0              = 0x18,
        DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_1              = 0x19,
        DR_STE_V2_ACTION_MDFY_FLD_IPV4_OUT_0            = 0x40,
        DR_STE_V2_ACTION_MDFY_FLD_IPV4_OUT_1            = 0x41,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_0        = 0x44,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_1        = 0x45,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_2        = 0x46,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_3        = 0x47,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_0        = 0x4c,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_1        = 0x4d,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_2        = 0x4e,
        DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_3        = 0x4f,
        DR_STE_V2_ACTION_MDFY_FLD_TCP_MISC_0            = 0x5e,
        DR_STE_V2_ACTION_MDFY_FLD_TCP_MISC_1            = 0x5f,
        DR_STE_V2_ACTION_MDFY_FLD_CFG_HDR_0_0           = 0x6f,
        DR_STE_V2_ACTION_MDFY_FLD_CFG_HDR_0_1           = 0x70,
        DR_STE_V2_ACTION_MDFY_FLD_METADATA_2_CQE        = 0x7b,
        DR_STE_V2_ACTION_MDFY_FLD_GNRL_PURPOSE          = 0x7c,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_2_0          = 0x90,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_2_1          = 0x91,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_1_0          = 0x92,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_1_1          = 0x93,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_0_0          = 0x94,
        DR_STE_V2_ACTION_MDFY_FLD_REGISTER_0_1          = 0x95,
};

static const struct mlx5dr_ste_action_modify_field dr_ste_v2_action_modify_field_arr[] = {
        [MLX5_ACTION_IN_FIELD_OUT_SMAC_47_16] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_SRC_L2_OUT_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SMAC_15_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_SRC_L2_OUT_1, .start = 16, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_ETHERTYPE] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_1, .start = 0, .end = 15,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DMAC_47_16] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DMAC_15_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_1, .start = 16, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_IP_DSCP] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L3_OUT_0, .start = 18, .end = 23,
        },
        [MLX5_ACTION_IN_FIELD_OUT_TCP_FLAGS] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_1, .start = 16, .end = 24,
                .l4_type = DR_STE_ACTION_MDFY_TYPE_L4_TCP,
        },
        [MLX5_ACTION_IN_FIELD_OUT_TCP_SPORT] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_0, .start = 16, .end = 31,
                .l4_type = DR_STE_ACTION_MDFY_TYPE_L4_TCP,
        },
        [MLX5_ACTION_IN_FIELD_OUT_TCP_DPORT] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_0, .start = 0, .end = 15,
                .l4_type = DR_STE_ACTION_MDFY_TYPE_L4_TCP,
        },
        [MLX5_ACTION_IN_FIELD_OUT_IP_TTL] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L3_OUT_0, .start = 8, .end = 15,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV4,
        },
        [MLX5_ACTION_IN_FIELD_OUT_IPV6_HOPLIMIT] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L3_OUT_0, .start = 8, .end = 15,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_UDP_SPORT] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_0, .start = 16, .end = 31,
                .l4_type = DR_STE_ACTION_MDFY_TYPE_L4_UDP,
        },
        [MLX5_ACTION_IN_FIELD_OUT_UDP_DPORT] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L4_OUT_0, .start = 0, .end = 15,
                .l4_type = DR_STE_ACTION_MDFY_TYPE_L4_UDP,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SIPV6_127_96] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_0, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SIPV6_95_64] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_1, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SIPV6_63_32] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_2, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SIPV6_31_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_SRC_OUT_3, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DIPV6_127_96] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_0, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DIPV6_95_64] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_1, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DIPV6_63_32] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_2, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DIPV6_31_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV6_DST_OUT_3, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV6,
        },
        [MLX5_ACTION_IN_FIELD_OUT_SIPV4] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV4_OUT_0, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV4,
        },
        [MLX5_ACTION_IN_FIELD_OUT_DIPV4] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_IPV4_OUT_1, .start = 0, .end = 31,
                .l3_type = DR_STE_ACTION_MDFY_TYPE_L3_IPV4,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_A] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_GNRL_PURPOSE, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_B] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_METADATA_2_CQE, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_0_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_1] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_0_1, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_2] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_1_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_3] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_1_1, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_4] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_2_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_METADATA_REG_C_5] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_REGISTER_2_1, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_TCP_SEQ_NUM] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_TCP_MISC_0, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_TCP_ACK_NUM] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_TCP_MISC_1, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_FIRST_VID] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_L2_OUT_2, .start = 0, .end = 15,
        },
        [MLX5_ACTION_IN_FIELD_OUT_EMD_31_0] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_CFG_HDR_0_1, .start = 0, .end = 31,
        },
        [MLX5_ACTION_IN_FIELD_OUT_EMD_47_32] = {
                .hw_field = DR_STE_V2_ACTION_MDFY_FLD_CFG_HDR_0_0, .start = 0, .end = 15,
        },
};

#endif  /* _DR_STE_V2_ */