f-stack/dpdk/drivers/net/dpaa2/dpaa2_sparser.h

207 lines
6.1 KiB
C

/* * SPDX-License-Identifier: BSD-3-Clause
* Copyright 2018-2019 NXP
*/
/**
* @file dpaa2_sparser.h
*
* @brief Soft parser related macros & functions support for DPAA2 device
* framework based applications.
*
*/
#ifndef _DPAA2_SPARSER_H
#define _DPAA2_SPARSER_H
#ifdef __cplusplus
extern "C" {
#endif
#define WRIOP_SS_INITIALIZER(priv) \
do { \
/* Base offset of parse profile memory in WRIOP */ \
(priv)->ss_offset = 0x20; \
(priv)->ss_iova = (size_t)NULL; \
(priv)->ss_param_iova = (size_t)NULL; \
} while (0)
/**************************************************************************/
/*
* @enum parser_starting_hxs_code
* @Description PARSER Starting HXS code
*/
/***************************************************************************/
enum parser_starting_hxs_code {
/** Ethernet Starting HXS coding */
PARSER_ETH_STARTING_HXS = 0x0000,
/** LLC+SNAP Starting HXS coding */
PARSER_LLC_SNAP_STARTING_HXS = 0x0001,
/** VLAN Starting HXS coding */
PARSER_VLAN_STARTING_HXS = 0x0002,
/** PPPoE+PPP Starting HXS coding */
PARSER_PPPOE_PPP_STARTING_HXS = 0x0003,
/** MPLS Starting HXS coding */
PARSER_MPLS_STARTING_HXS = 0x0004,
/** ARP Starting HXS coding */
PARSER_ARP_STARTING_HXS = 0x0005,
/** IP Starting HXS coding */
PARSER_IP_STARTING_HXS = 0x0006,
/** IPv4 Starting HXS coding */
PARSER_IPV4_STARTING_HXS = 0x0007,
/** IPv6 Starting HXS coding */
PARSER_IPV6_STARTING_HXS = 0x0008,
/** GRE Starting HXS coding */
PARSER_GRE_STARTING_HXS = 0x0009,
/** MinEncap Starting HXS coding */
PARSER_MINENCAP_STARTING_HXS = 0x000A,
/** Other L3 Shell Starting HXS coding */
PARSER_OTHER_L3_SHELL_STARTING_HXS = 0x000B,
/** TCP Starting HXS coding */
PARSER_TCP_STARTING_HXS = 0x000C,
/** UDP Starting HXS coding */
PARSER_UDP_STARTING_HXS = 0x000D,
/** IPSec Starting HXS coding */
PARSER_IPSEC_STARTING_HXS = 0x000E,
/** SCTP Starting HXS coding */
PARSER_SCTP_STARTING_HXS = 0x000F,
/** DCCP Starting HXS coding */
PARSER_DCCP_STARTING_HXS = 0x0010,
/** Other L4 Shell Starting HXS coding */
PARSER_OTHER_L4_SHELL_STARTING_HXS = 0x0011,
/** GTP Starting HXS coding */
PARSER_GTP_STARTING_HXS = 0x0012,
/** ESP Starting HXS coding */
PARSER_ESP_STARTING_HXS = 0x0013,
/** VXLAN Starting HXS coding */
PARSER_VXLAN_STARTING_HXS = 0x0014,
/** L5 (and above) Shell Starting HXS coding */
PARSER_L5_SHELL_STARTING_HXS = 0x001E,
/** Final Shell Starting HXS coding */
PARSER_FINAL_SHELL_STARTING_HXS = 0x001F
};
/**************************************************************************/
/*
* @Description struct dpni_drv_sparser_param - Structure representing the
* information needed to activate(enable) a Soft Parser.
*/
/***************************************************************************/
struct dpni_drv_sparser_param {
/* The "custom_header_first" must be set if the custom header to parse
* is the first header in the packet, otherwise "custom_header_first"
* must be cleared.
*/
uint8_t custom_header_first;
/* Hard HXS on which a soft parser is activated. This must be
* configured.
* if the header to parse is not the first header in the packet.
*/
enum parser_starting_hxs_code link_to_hard_hxs;
/* Soft Sequence Start PC */
uint16_t start_pc;
/* Soft Sequence byte-code */
uint8_t *byte_code;
/* Soft Sequence size */
uint16_t size;
/* Pointer to the Parameters Array of the SP */
uint8_t *param_array;
/* Parameters offset */
uint8_t param_offset;
/* Parameters size */
uint8_t param_size;
};
struct sp_parse_result {
/* Next header */
uint16_t nxt_hdr;
/* Frame Attribute Flags Extension */
uint16_t frame_attribute_flags_extension;
/* Frame Attribute Flags (part 1) */
uint32_t frame_attribute_flags_1;
/* Frame Attribute Flags (part 2) */
uint32_t frame_attribute_flags_2;
/* Frame Attribute Flags (part 3) */
uint32_t frame_attribute_flags_3;
/* Shim Offset 1 */
uint8_t shim_offset_1;
/* Shim Offset 2 */
uint8_t shim_offset_2;
/* Outer IP protocol field offset */
uint8_t ip_1_pid_offset;
/* Ethernet offset */
uint8_t eth_offset;
/* LLC+SNAP offset */
uint8_t llc_snap_offset;
/* First VLAN's TCI field offset*/
uint8_t vlan_tci1_offset;
/* Last VLAN's TCI field offset*/
uint8_t vlan_tcin_offset;
/* Last Ethertype offset*/
uint8_t last_etype_offset;
/* PPPoE offset */
uint8_t pppoe_offset;
/* First MPLS offset */
uint8_t mpls_offset_1;
/* Last MPLS offset */
uint8_t mpls_offset_n;
/* Layer 3 (Outer IP, ARP, FCoE or FIP) offset */
uint8_t l3_offset;
/* Inner IP or MinEncap offset*/
uint8_t ipn_or_minencap_offset;
/* GRE offset */
uint8_t gre_offset;
/* Layer 4 offset*/
uint8_t l4_offset;
/* Layer 5 offset */
uint8_t l5_offset;
/* Routing header offset of 1st IPv6 header */
uint8_t routing_hdr_offset1;
/* Routing header offset of 2nd IPv6 header */
uint8_t routing_hdr_offset2;
/* Next header offset */
uint8_t nxt_hdr_offset;
/* IPv6 fragmentable part offset */
uint8_t ipv6_frag_offset;
/* Frame's untouched running sum, input to parser */
uint16_t gross_running_sum;
/* Running Sum */
uint16_t running_sum;
/* Parse Error code */
uint8_t parse_error_code;
/* Offset to the next header field before IPv6 fragment extension */
uint8_t nxt_hdr_before_ipv6_frag_ext;
/* Inner IP Protocol field offset */
uint8_t ip_n_pid_offset;
/* Reserved for Soft parsing context*/
uint8_t soft_parsing_context[21];
};
struct frame_attr {
const char *fld_name;
uint8_t faf_offset;
uint32_t fld_mask;
};
struct frame_attr_ext {
const char *fld_name;
uint8_t faf_ext_offset;
uint16_t fld_mask;
};
struct parse_err {
uint16_t code;
const char *err_name;
};
/* Macro definitions */
#define IS_ONE_BIT_FIELD(_mask) \
(!((_mask) & ((_mask) - 1)) || (_mask == 1))
int dpaa2_eth_load_wriop_soft_parser(struct dpaa2_dev_priv *priv,
enum dpni_soft_sequence_dest dest);
int dpaa2_eth_enable_wriop_soft_parser(struct dpaa2_dev_priv *priv,
enum dpni_soft_sequence_dest dest);
#endif /* _DPAA2_SPARSER_H_ */