mirror of https://github.com/F-Stack/f-stack.git
5788 lines
199 KiB
C
5788 lines
199 KiB
C
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||
|
* Copyright 2008-2012 Freescale Semiconductor Inc.
|
||
|
* Copyright 2017-2020 NXP
|
||
|
*/
|
||
|
|
||
|
#ifndef __FM_PCD_EXT_H
|
||
|
#define __FM_PCD_EXT_H
|
||
|
|
||
|
#include "ncsw_ext.h"
|
||
|
#include "net_ext.h"
|
||
|
#include "fm_ext.h"
|
||
|
|
||
|
/*
|
||
|
* @Description FM PCD ...
|
||
|
* @Group lnx_ioctl_FM_grp Frame Manager Linux IOCTL API
|
||
|
* @Description Frame Manager Linux ioctls definitions and enums
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Group lnx_ioctl_FM_PCD_grp FM PCD
|
||
|
* @Description Frame Manager PCD API functions, definitions and enums
|
||
|
*
|
||
|
* The FM PCD module is responsible for the initialization of all
|
||
|
* global classifying FM modules. This includes the parser
|
||
|
* general and common registers, the key generator global and
|
||
|
* common registers, and the policer global and common registers.
|
||
|
* In addition, the FM PCD SW module will initialize all required
|
||
|
* key generator schemes, coarse classification flows, and
|
||
|
* policer profiles. When an FM module is configured to work with
|
||
|
* one of these entities, it will register to it using the FM
|
||
|
* PORT API. The PCD module will manage the PCD resources - i.e.
|
||
|
* resource management of KeyGen schemes, etc.
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Collection General PCD defines
|
||
|
*/
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_PRIVATE_HDRS 2
|
||
|
/**< Number of units/headers saved for user */
|
||
|
|
||
|
#define IOC_FM_PCD_PRS_NUM_OF_HDRS 16
|
||
|
/**< Number of headers supported by HW parser */
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_DISTINCTION_UNITS \
|
||
|
(32 - IOC_FM_PCD_MAX_NUM_OF_PRIVATE_HDRS)
|
||
|
/**< Number of distinction units is limited by register size (32 bits) minus
|
||
|
* reserved bits for private headers.
|
||
|
*/
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_INTERCHANGEABLE_HDRS 4
|
||
|
/**< Maximum number of interchangeable headers in a distinction unit */
|
||
|
#define IOC_FM_PCD_KG_NUM_OF_GENERIC_REGS 8
|
||
|
/**< Total number of generic KeyGen registers */
|
||
|
#define IOC_FM_PCD_KG_MAX_EXTRACTS_PER_KEY 35
|
||
|
/**< Max number allowed on any configuration; For HW implementation reasons,
|
||
|
* in most cases less than this will be allowed; The driver will return an
|
||
|
* initialization error if resource is unavailable.
|
||
|
*/
|
||
|
#define IOC_FM_PCD_KG_NUM_OF_EXTRACT_MASKS 4
|
||
|
/**< Total number of masks allowed on KeyGen extractions. */
|
||
|
#define IOC_FM_PCD_KG_NUM_OF_DEFAULT_GROUPS 16
|
||
|
/**< Number of default value logical groups */
|
||
|
#define IOC_FM_PCD_PRS_NUM_OF_LABELS 32
|
||
|
/**< Maximum number of SW parser labels */
|
||
|
#define IOC_FM_PCD_SW_PRS_SIZE 0x00000800
|
||
|
/**< Total size of SW parser area */
|
||
|
|
||
|
#define IOC_FM_PCD_MAX_MANIP_INSRT_TEMPLATE_SIZE 128
|
||
|
/**< Maximum size of insertion template for insert manipulation */
|
||
|
|
||
|
#define IOC_FM_PCD_FRM_REPLIC_MAX_NUM_OF_ENTRIES 64
|
||
|
/**< Maximum possible entries for frame replicator group */
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Group lnx_ioctl_FM_PCD_init_grp FM PCD Initialization Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Initialization Unit API
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Description PCD counters
|
||
|
* (must match enum ioc_fm_pcd_counters defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_counters {
|
||
|
e_IOC_FM_PCD_KG_COUNTERS_TOTAL, /**< KeyGen counter */
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_RED,
|
||
|
/**< Policer counter - counts the total number of RED packets that exit
|
||
|
* the Policer.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_YELLOW,
|
||
|
/**< Policer counter - counts the total number of YELLOW packets that
|
||
|
* exit the Policer.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_RECOLORED_TO_RED,
|
||
|
/**< Policer counter - counts the number of packets that changed color
|
||
|
* to RED by the Policer; This is a subset of
|
||
|
* e_IOC_FM_PCD_PLCR_COUNTERS_RED packet count, indicating active color
|
||
|
* changes.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_RECOLORED_TO_YELLOW,
|
||
|
/**< Policer counter - counts the number of packets that changed color
|
||
|
* to YELLOW by the Policer; This is a subset of
|
||
|
* e_IOC_FM_PCD_PLCR_COUNTERS_YELLOW packet count, indicating active
|
||
|
* color changes.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_TOTAL,
|
||
|
/**< Policer counter - counts the total number of packets passed in the
|
||
|
* Policer.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_COUNTERS_LENGTH_MISMATCH,
|
||
|
/**< Policer counter - counts the number of packets with length
|
||
|
* mismatch.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_PARSE_DISPATCH,
|
||
|
/**< Parser counter - counts the number of times the parser block is
|
||
|
* dispatched.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L2_PARSE_RESULT_RETURNED,
|
||
|
/**< Parser counter - counts the number of times L2 parse result is
|
||
|
* returned (including errors).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L3_PARSE_RESULT_RETURNED,
|
||
|
/**< Parser counter - counts the number of times L3 parse result is
|
||
|
* returned (including errors).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L4_PARSE_RESULT_RETURNED,
|
||
|
/**< Parser counter - counts the number of times L4 parse result is
|
||
|
* returned (including errors).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_SHIM_PARSE_RESULT_RETURNED,
|
||
|
/**< Parser counter - counts the number of times SHIM parse result is
|
||
|
* returned (including errors).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L2_PARSE_RESULT_RETURNED_WITH_ERR,
|
||
|
/**< Parser counter - counts the number of times L2 parse result is
|
||
|
* returned with errors.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L3_PARSE_RESULT_RETURNED_WITH_ERR,
|
||
|
/**< Parser counter - counts the number of times L3 parse result is
|
||
|
* returned with errors.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_L4_PARSE_RESULT_RETURNED_WITH_ERR,
|
||
|
/**< Parser counter - counts the number of times L4 parse result is
|
||
|
* returned with errors.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_SHIM_PARSE_RESULT_RETURNED_WITH_ERR,
|
||
|
/**< Parser counter - counts the number of times SHIM parse result is
|
||
|
* returned with errors.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_SOFT_PRS_CYCLES,
|
||
|
/**< Parser counter - counts the number of cycles spent executing soft
|
||
|
* parser instruction (including stall cycles).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_SOFT_PRS_STALL_CYCLES,
|
||
|
/**< Parser counter - counts the number of cycles stalled waiting for
|
||
|
* parser internal memory reads while executing soft parser instruction.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_HARD_PRS_CYCLE_INCL_STALL_CYCLES,
|
||
|
/**< Parser counter - counts the number of cycles spent executing hard
|
||
|
* parser (including stall cycles).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_MURAM_READ_CYCLES,
|
||
|
/**< MURAM counter - counts the number of cycles while performing FMan
|
||
|
* Memory read.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_MURAM_READ_STALL_CYCLES,
|
||
|
/**< MURAM counter - counts the number of cycles stalled while
|
||
|
* performing FMan Memory read.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_MURAM_WRITE_CYCLES,
|
||
|
/**< MURAM counter - counts the number of cycles while performing FMan
|
||
|
* Memory write.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_MURAM_WRITE_STALL_CYCLES,
|
||
|
/**< MURAM counter - counts the number of cycles stalled while
|
||
|
* performing FMan Memory write.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PRS_COUNTERS_FPM_COMMAND_STALL_CYCLES
|
||
|
/**< FPM counter - counts the number of cycles stalled while performing
|
||
|
* a FPM Command.
|
||
|
*/
|
||
|
} ioc_fm_pcd_counters;
|
||
|
|
||
|
/*
|
||
|
* @Description PCD interrupts
|
||
|
* (must match enum ioc_fm_pcd_exceptions defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_exceptions {
|
||
|
e_IOC_FM_PCD_KG_EXCEPTION_DOUBLE_ECC,
|
||
|
/**< KeyGen double-bit ECC error is detected on internal memory read
|
||
|
* access.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_KG_EXCEPTION_KEYSIZE_OVERFLOW,
|
||
|
/**< KeyGen scheme configuration error indicating a key size larger than
|
||
|
* 56 bytes.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_EXCEPTION_DOUBLE_ECC,
|
||
|
/**< Policer double-bit ECC error has been detected on PRAM read access.
|
||
|
*/
|
||
|
e_IOC_FM_PCD_PLCR_EXCEPTION_INIT_ENTRY_ERROR,
|
||
|
/**< Policer access to a non-initialized profile has been detected. */
|
||
|
e_IOC_FM_PCD_PLCR_EXCEPTION_PRAM_SELF_INIT_COMPLETE,
|
||
|
/**< Policer RAM self-initialization complete */
|
||
|
e_IOC_FM_PCD_PLCR_EXCEPTION_ATOMIC_ACTION_COMPLETE,
|
||
|
/**< Policer atomic action complete */
|
||
|
e_IOC_FM_PCD_PRS_EXCEPTION_DOUBLE_ECC,
|
||
|
/**< Parser double-bit ECC error */
|
||
|
e_IOC_FM_PCD_PRS_EXCEPTION_SINGLE_ECC
|
||
|
/**< Parser single-bit ECC error */
|
||
|
} ioc_fm_pcd_exceptions;
|
||
|
|
||
|
/** @} */ /* end of lnx_ioctl_FM_PCD_init_grp group */
|
||
|
|
||
|
/*
|
||
|
* @Group lnx_ioctl_FM_PCD_Runtime_grp FM PCD Runtime Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Runtime Unit
|
||
|
*
|
||
|
* The runtime control allows creation of PCD infrastructure
|
||
|
* modules such as Network Environment Characteristics,
|
||
|
* Classification Plan Groups and Coarse Classification Trees.
|
||
|
* It also allows on-the-fly initialization, modification and
|
||
|
* removal of PCD modules such as KeyGen schemes, coarse
|
||
|
* classification nodes and Policer profiles.
|
||
|
*
|
||
|
* In order to explain the programming model of the PCD driver
|
||
|
* interface a few terms should be explained, and will be used
|
||
|
* below.
|
||
|
* - Distinction Header - One of the 16 protocols supported by
|
||
|
* the FM parser, or one of the SHIM headers (1 or 2). May be a
|
||
|
* header with a special option (see below).
|
||
|
* - Interchangeable Headers Group - This is a group of Headers
|
||
|
* recognized by either one of them. For example, if in a
|
||
|
* specific context the user chooses to treat IPv4 and IPV6 in
|
||
|
* the same way, they may create an interchangeable Headers
|
||
|
* Unit consisting of these 2 headers.
|
||
|
* - A Distinction Unit - a Distinction Header or an
|
||
|
* Interchangeable Headers Group.
|
||
|
* - Header with special option - applies to Ethernet, MPLS,
|
||
|
* VLAN, IPv4 and IPv6, includes multicast, broadcast and other
|
||
|
* protocol specific options. In terms of hardware it relates
|
||
|
* to the options available in the classification plan.
|
||
|
* - Network Environment Characteristics - a set of Distinction
|
||
|
* Units that define the total recognizable header selection
|
||
|
* for a certain environment. This is NOT the list of all
|
||
|
* headers that will ever appear in a flow, but rather
|
||
|
* everything that needs distinction in a flow, where
|
||
|
* distinction is made by KeyGen schemes and coarse
|
||
|
* classification action descriptors.
|
||
|
*
|
||
|
* The PCD runtime modules initialization is done in stages. The
|
||
|
* first stage after initializing the PCD module itself is to
|
||
|
* establish a Network Flows Environment Definition. The
|
||
|
* application may choose to establish one or more such
|
||
|
* environments. Later, when needed, the application will have to
|
||
|
* state, for some of its modules, to which single environment it
|
||
|
* belongs.
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Description structure for FM counters
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_counters_params_t {
|
||
|
ioc_fm_pcd_counters cnt; /**< The requested counter */
|
||
|
uint32_t val;
|
||
|
/**< The requested value to get/set from/into the
|
||
|
* counter
|
||
|
*/
|
||
|
} ioc_fm_pcd_counters_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for FM exception definitios
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_exception_params_t {
|
||
|
ioc_fm_pcd_exceptions exception; /**< The requested exception */
|
||
|
bool enable;
|
||
|
/**< TRUE to enable interrupt, FALSE to mask it. */
|
||
|
} ioc_fm_pcd_exception_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for SW parser labels (must be identical to struct
|
||
|
* t_fm_pcd_prs_label_params defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_prs_label_params_t {
|
||
|
uint32_t instruction_offset;
|
||
|
/**< SW parser label instruction offset (2 bytes resolution),
|
||
|
* relative to Parser RAM
|
||
|
*/
|
||
|
ioc_net_header_type hdr;
|
||
|
/**< The existence of this header will invoke the SW parser
|
||
|
* code.
|
||
|
*/
|
||
|
uint8_t index_per_hdr;
|
||
|
/**< Normally 0, if more than one SW parser attachments for the
|
||
|
* same header, use this index to distinguish between them.
|
||
|
*/
|
||
|
} ioc_fm_pcd_prs_label_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for SW parser (Must match struct
|
||
|
* ioc_fm_pcd_prs_sw_params_t defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_prs_sw_params_t {
|
||
|
bool override;
|
||
|
/**< FALSE to invoke a check that nothing else was
|
||
|
* loaded to this address, including internal patches.
|
||
|
* TRUE to override any existing code.
|
||
|
*/
|
||
|
uint32_t size; /**< SW parser code size */
|
||
|
uint16_t base;
|
||
|
/**< SW parser base (in instruction counts! must be
|
||
|
* larger than 0x20)
|
||
|
*/
|
||
|
uint8_t *p_code; /**< SW parser code */
|
||
|
uint32_t sw_prs_data_params[IOC_FM_PCD_PRS_NUM_OF_HDRS];
|
||
|
/**< SW parser data (parameters) */
|
||
|
uint8_t num_of_labels; /**< Number of labels for SW parser. */
|
||
|
ioc_fm_pcd_prs_label_params_t
|
||
|
labels_table[IOC_FM_PCD_PRS_NUM_OF_LABELS];
|
||
|
/**< SW parser labels table, containing num_of_labels
|
||
|
* entries
|
||
|
*/
|
||
|
} ioc_fm_pcd_prs_sw_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure to set the a KeyGen default value
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_dflt_value_params_t {
|
||
|
uint8_t value_id;/**< 0,1 - one of 2 global default values */
|
||
|
uint32_t value; /**< The requested default value */
|
||
|
} ioc_fm_pcd_kg_dflt_value_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_enable
|
||
|
*
|
||
|
* @Description This routine should be called after PCD is initialized for
|
||
|
* enabling all PCD engines according to their existing
|
||
|
* configuration.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is disabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_ENABLE _IO(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(1))
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_disable
|
||
|
*
|
||
|
* @Description This routine may be called when PCD is enabled in order to
|
||
|
* disable all PCD engines. It may be called only when none of
|
||
|
* the ports in the system are using the PCD.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is enabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_DISABLE _IO(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(2))
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_prs_load_sw
|
||
|
*
|
||
|
* @Description This routine may be called only when all ports in the
|
||
|
* system are actively using the classification plan scheme.
|
||
|
* In such cases it is recommended in order to save resources.
|
||
|
* The driver automatically saves 8 classification plans for
|
||
|
* ports that do NOT use the classification plan mechanism, to
|
||
|
* avoid this (in order to save those entries) this routine may
|
||
|
* be called.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_prs_sw_params_t
|
||
|
* A pointer to the image of the software parser code.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is disabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_PRS_LOAD_SW \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(3), ioc_fm_pcd_prs_sw_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_set_dflt_value
|
||
|
*
|
||
|
* @Description Calling this routine sets a global default value to be used
|
||
|
* by the KeyGen when parser does not recognize a required
|
||
|
* field/header.
|
||
|
* default value is 0.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_kg_dflt_value_params_t A pointer to a structure
|
||
|
* with the relevant
|
||
|
* parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is disabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_KG_SET_DFLT_VALUE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(6), \
|
||
|
ioc_fm_pcd_kg_dflt_value_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_set_additional_data_after_parsing
|
||
|
*
|
||
|
* @Description Calling this routine allows the keygen to access data past
|
||
|
* the parser finishing point.
|
||
|
*
|
||
|
* @Param[in] uint8_t payload-offset; the number of bytes beyond the
|
||
|
* parser location.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is disabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_KG_SET_ADDITIONAL_DATA_AFTER_PARSING \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(7), uint8_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_exception
|
||
|
*
|
||
|
* @Description Calling this routine enables/disables PCD interrupts.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_exception_params_t
|
||
|
* Arguments struct with exception to be enabled/disabled.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_SET_EXCEPTION \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(8), ioc_fm_pcd_exception_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_get_counter
|
||
|
*
|
||
|
* @Description Reads one of the FM PCD counters.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_counters_params_t The requested counter parameters.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions It is user's responsibility to call this routine only
|
||
|
* for enabled counters, and there will be no indication if a
|
||
|
* disabled counter is accessed.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_GET_COUNTER \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(9), ioc_fm_pcd_counters_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_get_counter
|
||
|
*
|
||
|
* @Description Reads scheme packet counter.
|
||
|
*
|
||
|
* @Param[in] h_scheme scheme handle as returned by
|
||
|
* fm_pcd_kg_scheme_set().
|
||
|
*
|
||
|
* @Return Counter's current value.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() & fm_pcd_kg_scheme_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_KG_SCHEME_GET_CNTR \
|
||
|
_IOR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(4), ioc_fm_pcd_kg_scheme_spc_t)
|
||
|
|
||
|
/*
|
||
|
* @Function FM_PCD_ForceIntr
|
||
|
*
|
||
|
* @Description Causes an interrupt event on the requested source.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_exceptions - An exception to be forced.
|
||
|
*
|
||
|
* @Return 0 on success; error code if the exception is not enabled,
|
||
|
* or is not able to create interrupt.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_FORCE_INTR \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(11), ioc_fm_pcd_exceptions)
|
||
|
|
||
|
/*
|
||
|
* @Collection Definitions of coarse classification parameters as required by
|
||
|
* KeyGen (when coarse classification is the next engine after this
|
||
|
* scheme).
|
||
|
*/
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_CC_TREES 8
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_CC_GROUPS 16
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_CC_UNITS 4
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_KEYS 256
|
||
|
#define IOC_FM_PCD_MAX_NUM_OF_FLOWS (4 * KILOBYTE)
|
||
|
#define IOC_FM_PCD_MAX_SIZE_OF_KEY 56
|
||
|
#define IOC_FM_PCD_MAX_CC_ENTRY_IN_GRP 16
|
||
|
#define IOC_FM_PCD_LAST_KEY_INDEX 0xffff
|
||
|
#define IOC_FM_PCD_MANIP_DSCP_VALUES 64
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Collection A set of definitions to allow protocol
|
||
|
* special option description.
|
||
|
*/
|
||
|
typedef uint32_t ioc_protocol_opt_t;
|
||
|
/**< A general type to define a protocol option. */
|
||
|
|
||
|
typedef ioc_protocol_opt_t ioc_eth_protocol_opt_t;
|
||
|
/**< Ethernet protocol options. */
|
||
|
#define IOC_ETH_BROADCAST 0x80000000 /**< Ethernet Broadcast. */
|
||
|
#define IOC_ETH_MULTICAST 0x40000000 /**< Ethernet Multicast. */
|
||
|
|
||
|
typedef ioc_protocol_opt_t ioc_vlan_protocol_opt_t;
|
||
|
/**< Vlan protocol options. */
|
||
|
#define IOC_VLAN_STACKED 0x20000000 /**< Stacked VLAN. */
|
||
|
|
||
|
typedef ioc_protocol_opt_t ioc_mpls_protocol_opt_t;
|
||
|
/**< MPLS protocol options. */
|
||
|
#define IOC_MPLS_STACKED 0x10000000 /**< Stacked MPLS. */
|
||
|
|
||
|
typedef ioc_protocol_opt_t ioc_ipv4_protocol_opt_t;
|
||
|
/**< IPv4 protocol options. */
|
||
|
#define IOC_IPV4_BROADCAST_1 0x08000000 /**< IPv4 Broadcast. */
|
||
|
#define IOC_IPV4_MULTICAST_1 0x04000000 /**< IPv4 Multicast. */
|
||
|
#define IOC_IPV4_UNICAST_2 0x02000000
|
||
|
/**< Tunneled IPv4 - Unicast.
|
||
|
*/
|
||
|
#define IOC_IPV4_MULTICAST_BROADCAST_2 0x01000000
|
||
|
/**< Tunneled IPv4 -
|
||
|
* Broadcast/Multicast.
|
||
|
*/
|
||
|
|
||
|
#define IOC_IPV4_FRAG_1 0x00000008
|
||
|
/**< IPV4 reassembly option. IPV4
|
||
|
* Reassembly manipulation requires network
|
||
|
* environment with IPV4 header and IPV4_FRAG_1
|
||
|
* option
|
||
|
*/
|
||
|
|
||
|
typedef ioc_protocol_opt_t ioc_ipv6_protocol_opt_t;
|
||
|
/**< IPv6 protocol options. */
|
||
|
#define IOC_IPV6_MULTICAST_1 0x00800000 /**< IPv6 Multicast. */
|
||
|
#define IOC_IPV6_UNICAST_2 0x00400000
|
||
|
/**< Tunneled IPv6 - Unicast. */
|
||
|
#define IOC_IPV6_MULTICAST_2 0x00200000
|
||
|
/**< Tunneled IPv6 - Multicast. */
|
||
|
|
||
|
#define IOC_IPV6_FRAG_1 0x00000004
|
||
|
/**< IPV6 reassembly option. IPV6 Reassembly
|
||
|
* manipulation requires network environment
|
||
|
* with IPV6 header and IPV6_FRAG_1 option
|
||
|
*/
|
||
|
typedef ioc_protocol_opt_t ioc_capwap_protocol_opt_t;
|
||
|
/**< CAPWAP protocol options. */
|
||
|
#define CAPWAP_FRAG_1 0x00000008
|
||
|
/**< CAPWAP reassembly option. CAPWAP Reassembly
|
||
|
* manipulation requires network environment
|
||
|
* with CAPWAP header and CAPWAP_FRAG_1 option;
|
||
|
* in case where fragment found, the
|
||
|
* fragment-extension offset may be found at
|
||
|
* 'shim2' (in parser-result).
|
||
|
*/
|
||
|
|
||
|
/* @} */
|
||
|
|
||
|
#define IOC_FM_PCD_MANIP_MAX_HDR_SIZE 256
|
||
|
#define IOC_FM_PCD_MANIP_DSCP_TO_VLAN_TRANS 64
|
||
|
/**
|
||
|
* @Collection A set of definitions to support Header Manipulation selection.
|
||
|
*/
|
||
|
typedef uint32_t ioc_hdr_manip_flags_t;
|
||
|
/**< A general type to define a HMan update command flags. */
|
||
|
|
||
|
typedef ioc_hdr_manip_flags_t ioc_ipv4_hdr_manip_update_flags_t;
|
||
|
/**< IPv4 protocol HMan update command flags. */
|
||
|
|
||
|
#define IOC_HDR_MANIP_IPV4_TOS 0x80000000
|
||
|
/**< update TOS with the given value ('tos' field of
|
||
|
* ioc_fm_pcd_manip_hdr_field_update_ipv4_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_IPV4_ID 0x40000000
|
||
|
/**< update IP ID with the given value ('id' field of
|
||
|
* ioc_fm_pcd_manip_hdr_field_update_ipv4_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_IPV4_TTL 0x20000000 /**< Decrement TTL by 1 */
|
||
|
#define IOC_HDR_MANIP_IPV4_SRC 0x10000000
|
||
|
/**< update IP source address with the given value ('src' field
|
||
|
* of ioc_fm_pcd_manip_hdr_field_update_ipv4_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_IPV4_DST 0x08000000
|
||
|
/**< update IP destination address with the given value
|
||
|
* ('dst' field of ioc_fm_pcd_manip_hdr_field_update_ipv4_t)
|
||
|
*/
|
||
|
|
||
|
typedef ioc_hdr_manip_flags_t ioc_ipv6_hdr_manip_update_flags_t;
|
||
|
/**< IPv6 protocol HMan update command flags. */
|
||
|
|
||
|
#define IOC_HDR_MANIP_IPV6_TC 0x80000000
|
||
|
/**< update Traffic Class address with the given value ('traffic_class'
|
||
|
* field of ioc_fm_pcd_manip_hdr_field_update_ipv6_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_IPV6_HL 0x40000000 /**< Decrement Hop Limit by 1 */
|
||
|
#define IOC_HDR_MANIP_IPV6_SRC 0x20000000
|
||
|
/**< update IP source address with the given value ('src' field
|
||
|
* of ioc_fm_pcd_manip_hdr_field_update_ipv6_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_IPV6_DST 0x10000000
|
||
|
/**< update IP destination address with the given value ('dst'
|
||
|
* field of ioc_fm_pcd_manip_hdr_field_update_ipv6_t)
|
||
|
*/
|
||
|
|
||
|
typedef ioc_hdr_manip_flags_t ioc_tcp_udp_hdr_manip_update_flags_t;
|
||
|
/**< TCP/UDP protocol HMan update command flags. */
|
||
|
|
||
|
#define IOC_HDR_MANIP_TCP_UDP_SRC 0x80000000
|
||
|
/**< update TCP/UDP source address with the given value
|
||
|
* ('src' field of ioc_fm_pcd_manip_hdr_field_update_tcp_udp_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_TCP_UDP_DST 0x40000000
|
||
|
/**< update TCP/UDP destination address with the given value
|
||
|
* ('dst' field of ioc_fm_pcd_manip_hdr_field_update_tcp_udp_t)
|
||
|
*/
|
||
|
#define IOC_HDR_MANIP_TCP_UDP_CHECKSUM 0x20000000
|
||
|
/**< update TCP/UDP checksum */
|
||
|
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Description A type used for returning the order of the key extraction.
|
||
|
* each value in this array represents the index of the
|
||
|
* extraction command as defined by the user in the
|
||
|
* initialization extraction array. The valid size of this array
|
||
|
* is the user define number of extractions required (also
|
||
|
* marked by the second '0' in this array).
|
||
|
*/
|
||
|
typedef uint8_t
|
||
|
ioc_fm_pcd_kg_key_order_t [IOC_FM_PCD_KG_MAX_EXTRACTS_PER_KEY];
|
||
|
|
||
|
/*
|
||
|
*@Description All PCD engines
|
||
|
* (must match enum e_FmPcdEngine defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
|
||
|
typedef enum ioc_fm_pcd_engine {
|
||
|
e_IOC_FM_PCD_INVALID = 0, /**< Invalid PCD engine */
|
||
|
e_IOC_FM_PCD_DONE, /**< No PCD Engine indicated */
|
||
|
e_IOC_FM_PCD_KG, /**< KeyGen */
|
||
|
e_IOC_FM_PCD_CC, /**< Coarse Classifier */
|
||
|
e_IOC_FM_PCD_PLCR, /**< Policer */
|
||
|
e_IOC_FM_PCD_PRS, /**< Parser */
|
||
|
e_IOC_FM_PCD_FR, /**< Frame Replicator */
|
||
|
e_IOC_FM_PCD_HASH /**< Hash Table */
|
||
|
} ioc_fm_pcd_engine;
|
||
|
|
||
|
/*
|
||
|
* @Description An enum for selecting extraction by header types
|
||
|
* (Must match enum e_FmPcdExtractByHdrType defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_extract_by_hdr_type {
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_HDR, /**< Extract bytes from header */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_FIELD,/**< Extract bytes from header field */
|
||
|
e_IOC_FM_PCD_EXTRACT_FULL_FIELD /**< Extract a full field */
|
||
|
} ioc_fm_pcd_extract_by_hdr_type;
|
||
|
|
||
|
/*
|
||
|
* @Description An enum for selecting extraction source (when it is not the
|
||
|
* header) (Must match enum e_FmPcdExtractFrom defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_extract_from {
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_FRAME_START,
|
||
|
/**< KG & CC: Extract from beginning of frame */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_DFLT_VALUE,
|
||
|
/**< KG only: Extract from a default value */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_CURR_END_OF_PARSE,
|
||
|
/**< KG only: Extract from the point where parsing had
|
||
|
* finished
|
||
|
*/
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_KEY, /**< CC only: Field where saved KEY */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_HASH, /**< CC only: Field where saved HASH */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_PARSE_RESULT,
|
||
|
/**< KG & CC: Extract from the parser result */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_ENQ_FQID,
|
||
|
/**< KG & CC: Extract from enqueue FQID */
|
||
|
e_IOC_FM_PCD_EXTRACT_FROM_FLOW_ID
|
||
|
/**< CC only: Field where saved Dequeue FQID */
|
||
|
} ioc_fm_pcd_extract_from;
|
||
|
|
||
|
/*
|
||
|
* @Description An enum for selecting extraction type
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_extract_type {
|
||
|
e_IOC_FM_PCD_EXTRACT_BY_HDR, /**< Extract according to header */
|
||
|
e_IOC_FM_PCD_EXTRACT_NON_HDR,
|
||
|
/**< Extract from data that is not the header */
|
||
|
e_IOC_FM_PCD_KG_EXTRACT_PORT_PRIVATE_INFO
|
||
|
/**< Extract private info as specified by user */
|
||
|
} ioc_fm_pcd_extract_type;
|
||
|
|
||
|
/*
|
||
|
* @Description An enum for selecting a default
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_kg_extract_dflt_select {
|
||
|
e_IOC_FM_PCD_KG_DFLT_GBL_0,
|
||
|
/**< Default selection is KG register 0 */
|
||
|
e_IOC_FM_PCD_KG_DFLT_GBL_1,
|
||
|
/**< Default selection is KG register 1 */
|
||
|
e_IOC_FM_PCD_KG_DFLT_PRIVATE_0,
|
||
|
/**< Default selection is a per scheme register 0 */
|
||
|
e_IOC_FM_PCD_KG_DFLT_PRIVATE_1,
|
||
|
/**< Default selection is a per scheme register 1 */
|
||
|
e_IOC_FM_PCD_KG_DFLT_ILLEGAL /**< Illegal selection */
|
||
|
} ioc_fm_pcd_kg_extract_dflt_select;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type defining all default groups - each group
|
||
|
* shares a default value, one of four user-initialized values.
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_kg_known_fields_dflt_types {
|
||
|
e_IOC_FM_PCD_KG_MAC_ADDR, /**< MAC Address */
|
||
|
e_IOC_FM_PCD_KG_TCI, /**< TCI field */
|
||
|
e_IOC_FM_PCD_KG_ENET_TYPE, /**< ENET Type */
|
||
|
e_IOC_FM_PCD_KG_PPP_SESSION_ID, /**< PPP Session id */
|
||
|
e_IOC_FM_PCD_KG_PPP_PROTOCOL_ID, /**< PPP Protocol id */
|
||
|
e_IOC_FM_PCD_KG_MPLS_LABEL, /**< MPLS label */
|
||
|
e_IOC_FM_PCD_KG_IP_ADDR, /**< IP addr */
|
||
|
e_IOC_FM_PCD_KG_PROTOCOL_TYPE, /**< Protocol type */
|
||
|
e_IOC_FM_PCD_KG_IP_TOS_TC, /**< TOS or TC */
|
||
|
e_IOC_FM_PCD_KG_IPV6_FLOW_LABEL, /**< IPV6 flow label */
|
||
|
e_IOC_FM_PCD_KG_IPSEC_SPI, /**< IPSEC SPI */
|
||
|
e_IOC_FM_PCD_KG_L4_PORT, /**< L4 Port */
|
||
|
e_IOC_FM_PCD_KG_TCP_FLAG, /**< TCP Flag */
|
||
|
e_IOC_FM_PCD_KG_GENERIC_FROM_DATA,
|
||
|
/**< grouping implemented by SW, any data extraction that is not
|
||
|
* the full field described above
|
||
|
*/
|
||
|
e_IOC_FM_PCD_KG_GENERIC_FROM_DATA_NO_V,
|
||
|
/**< grouping implemented by SW, any data extraction without
|
||
|
* validation
|
||
|
*/
|
||
|
e_IOC_FM_PCD_KG_GENERIC_NOT_FROM_DATA
|
||
|
/**< grouping implemented by SW, extraction from parser result
|
||
|
* or direct use of default value
|
||
|
*/
|
||
|
} ioc_fm_pcd_kg_known_fields_dflt_types;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for defining header index for scenarios with
|
||
|
* multiple (tunneled) headers
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_hdr_index {
|
||
|
e_IOC_FM_PCD_HDR_INDEX_NONE = 0,
|
||
|
/**< used when multiple headers not used, also
|
||
|
* to specify regular IP (not tunneled).
|
||
|
*/
|
||
|
e_IOC_FM_PCD_HDR_INDEX_1,/**< may be used for VLAN, MPLS, tunneled IP */
|
||
|
e_IOC_FM_PCD_HDR_INDEX_2,/**< may be used for MPLS, tunneled IP */
|
||
|
e_IOC_FM_PCD_HDR_INDEX_3,/**< may be used for MPLS */
|
||
|
e_IOC_FM_PCD_HDR_INDEX_LAST = 0xFF /**< may be used for VLAN, MPLS */
|
||
|
} ioc_fm_pcd_hdr_index;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the policer profile functional
|
||
|
* type
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_profile_type_selection {
|
||
|
e_IOC_FM_PCD_PLCR_PORT_PRIVATE, /**< Port dedicated profile */
|
||
|
e_IOC_FM_PCD_PLCR_SHARED
|
||
|
/**< Shared profile (shared within partition) */
|
||
|
} ioc_fm_pcd_profile_type_selection;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the policer profile algorithm
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_algorithm_selection {
|
||
|
e_IOC_FM_PCD_PLCR_PASS_THROUGH, /**< Policer pass through */
|
||
|
e_IOC_FM_PCD_PLCR_RFC_2698, /**< Policer algorithm RFC 2698 */
|
||
|
e_IOC_FM_PCD_PLCR_RFC_4115 /**< Policer algorithm RFC 4115 */
|
||
|
} ioc_fm_pcd_plcr_algorithm_selection;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting a policer profile color mode
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_color_mode {
|
||
|
e_IOC_FM_PCD_PLCR_COLOR_BLIND, /**< Color blind */
|
||
|
e_IOC_FM_PCD_PLCR_COLOR_AWARE /**< Color aware */
|
||
|
} ioc_fm_pcd_plcr_color_mode;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting a policer profile color
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_color {
|
||
|
e_IOC_FM_PCD_PLCR_GREEN, /**< Green */
|
||
|
e_IOC_FM_PCD_PLCR_YELLOW, /**< Yellow */
|
||
|
e_IOC_FM_PCD_PLCR_RED, /**< Red */
|
||
|
e_IOC_FM_PCD_PLCR_OVERRIDE /**< Color override */
|
||
|
} ioc_fm_pcd_plcr_color;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the policer profile packet
|
||
|
* frame length selector
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_frame_length_select {
|
||
|
e_IOC_FM_PCD_PLCR_L2_FRM_LEN, /**< L2 frame length */
|
||
|
e_IOC_FM_PCD_PLCR_L3_FRM_LEN, /**< L3 frame length */
|
||
|
e_IOC_FM_PCD_PLCR_L4_FRM_LEN, /**< L4 frame length */
|
||
|
e_IOC_FM_PCD_PLCR_FULL_FRM_LEN /**< Full frame length */
|
||
|
} ioc_fm_pcd_plcr_frame_length_select;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting roll-back frame
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_roll_back_frame_select {
|
||
|
e_IOC_FM_PCD_PLCR_ROLLBACK_L2_FRM_LEN, /**< Rollback L2 frame length */
|
||
|
e_IOC_FM_PCD_PLCR_ROLLBACK_FULL_FRM_LEN
|
||
|
/**< Rollback Full frame length */
|
||
|
} ioc_fm_pcd_plcr_roll_back_frame_select;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the policer profile packet or
|
||
|
* byte mode
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_rate_mode {
|
||
|
e_IOC_FM_PCD_PLCR_BYTE_MODE, /**< Byte mode */
|
||
|
e_IOC_FM_PCD_PLCR_PACKET_MODE /**< Packet mode */
|
||
|
} ioc_fm_pcd_plcr_rate_mode;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for defining action of frame
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_done_action {
|
||
|
e_IOC_FM_PCD_ENQ_FRAME = 0, /**< Enqueue frame */
|
||
|
e_IOC_FM_PCD_DROP_FRAME /**< Drop frame */
|
||
|
} ioc_fm_pcd_done_action;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the policer counter
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_plcr_profile_counters {
|
||
|
e_IOC_FM_PCD_PLCR_PROFILE_GREEN_PACKET_TOTAL_COUNTER,
|
||
|
/**< Green packets counter */
|
||
|
e_IOC_FM_PCD_PLCR_PROFILE_YELLOW_PACKET_TOTAL_COUNTER,
|
||
|
/**< Yellow packets counter */
|
||
|
e_IOC_FM_PCD_PLCR_PROFILE_RED_PACKET_TOTAL_COUNTER,
|
||
|
/**< Red packets counter */
|
||
|
e_IOC_FM_PCD_PLCR_PROFILE_RECOLOURED_YELLOW_PACKET_TOTAL_COUNTER,
|
||
|
/**< Recolored yellow packets counter */
|
||
|
e_IOC_FM_PCD_PLCR_PROFILE_RECOLOURED_RED_PACKET_TOTAL_COUNTER
|
||
|
/**< Recolored red packets counter */
|
||
|
} ioc_fm_pcd_plcr_profile_counters;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting the PCD action after extraction
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_action {
|
||
|
e_IOC_FM_PCD_ACTION_NONE, /**< NONE */
|
||
|
e_IOC_FM_PCD_ACTION_EXACT_MATCH,
|
||
|
/**< Exact match on the selected extraction */
|
||
|
e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP
|
||
|
/**< Indexed lookup on the selected extraction */
|
||
|
} ioc_fm_pcd_action;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of insert manipulation
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_insrt_type {
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_GENERIC,
|
||
|
/**< Insert according to offset & size */
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR,
|
||
|
/**< Insert according to protocol */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of remove manipulation
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_rmv_type {
|
||
|
e_IOC_FM_PCD_MANIP_RMV_GENERIC,
|
||
|
/**< Remove according to offset & size */
|
||
|
e_IOC_FM_PCD_MANIP_RMV_BY_HDR
|
||
|
/**< Remove according to offset & size */
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_type;
|
||
|
|
||
|
/*
|
||
|
* @Description An enum for selecting specific L2 fields removal
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_rmv_specific_l2 {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_RMV_ETHERNET, /**< Ethernet/802.3 MAC */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_RMV_STACKED_QTAGS, /**< stacked QTags */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_RMV_ETHERNET_AND_MPLS,
|
||
|
/**< MPLS and Ethernet/802.3 MAC header unitl the header
|
||
|
* which follows the MPLS header
|
||
|
*/
|
||
|
e_IOC_FM_PCD_MANIP_HDR_RMV_MPLS
|
||
|
/**< Remove MPLS header (Unlimited MPLS labels) */
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_specific_l2;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting specific fields updates
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_field_update_type {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_VLAN, /**< VLAN updates */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_IPV4, /**< IPV4 updates */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_IPV6, /**< IPV6 updates */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_TCP_UDP, /**< TCP_UDP updates */
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting VLAN updates
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_field_update_vlan {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_VLAN_VPRI,
|
||
|
/**< Replace VPri of outer most VLAN tag. */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_DSCP_TO_VLAN
|
||
|
/**< DSCP to VLAN priority bits translation */
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_vlan;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting specific L2 fields removal
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_insrt_specific_l2 {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_INSRT_MPLS
|
||
|
/**< Insert MPLS header (Unlimited MPLS labels) */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_specific_l2;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting QoS mapping mode
|
||
|
*
|
||
|
* Note: In all cases except
|
||
|
* 'e_FM_PCD_MANIP_HDR_QOS_MAPPING_NONE' User should instruct the
|
||
|
* port to read the parser-result
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_qos_mapping_mode {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_QOS_MAPPING_NONE = 0,
|
||
|
/**< No mapping, QoS field will not be changed */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_QOS_MAPPING_AS_IS,
|
||
|
/**< QoS field will be overwritten by the last byte in
|
||
|
* the parser-result.
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_qos_mapping_mode;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting QoS source
|
||
|
*
|
||
|
* Note: In all cases except 'e_FM_PCD_MANIP_HDR_QOS_SRC_NONE'
|
||
|
* User should left room for the parser-result on input/output
|
||
|
* buffer and instruct the port to read/write the parser-result
|
||
|
* to the buffer (RPD should be set)
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_qos_src {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_QOS_SRC_NONE = 0,
|
||
|
/**< TODO */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_QOS_SRC_USER_DEFINED,
|
||
|
/**< QoS will be taken from the last byte in the
|
||
|
* parser-result.
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_qos_src;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of header insertion
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_insrt_by_hdr_type {
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_SPECIFIC_L2,
|
||
|
/**< Specific L2 fields insertion */
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_IP, /**< IP insertion */
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_UDP, /**< UDP insertion */
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_UDP_LITE,
|
||
|
/**< UDP lite insertion */
|
||
|
e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_CAPWAP /**< CAPWAP insertion */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_by_hdr_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting specific custom command
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_custom_type {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_CUSTOM_IP_REPLACE,
|
||
|
/**< Replace IPv4/IPv6 */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_CUSTOM_GEN_FIELD_REPLACE,
|
||
|
} ioc_fm_pcd_manip_hdr_custom_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting specific custom command
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_custom_ip_replace {
|
||
|
e_IOC_FM_PCD_MANIP_HDR_CUSTOM_REPLACE_IPV4_BY_IPV6,
|
||
|
/**< Replace IPv4 by IPv6 */
|
||
|
e_IOC_FM_PCD_MANIP_HDR_CUSTOM_REPLACE_IPV6_BY_IPV4
|
||
|
/**< Replace IPv6 by IPv4 */
|
||
|
} ioc_fm_pcd_manip_hdr_custom_ip_replace;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of header removal
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_hdr_rmv_by_hdr_type {
|
||
|
e_IOC_FM_PCD_MANIP_RMV_BY_HDR_SPECIFIC_L2 = 0,
|
||
|
/**< Specific L2 fields removal */
|
||
|
e_IOC_FM_PCD_MANIP_RMV_BY_HDR_CAPWAP, /**< CAPWAP removal */
|
||
|
e_IOC_FM_PCD_MANIP_RMV_BY_HDR_FROM_START,
|
||
|
/**< Locate from data that is not the header */
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_by_hdr_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of timeout mode
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_reassem_time_out_mode {
|
||
|
e_IOC_FM_PCD_MANIP_TIME_OUT_BETWEEN_FRAMES,
|
||
|
/**< Limits the time of the reassembly
|
||
|
* process from the first fragment to
|
||
|
* the last
|
||
|
*/
|
||
|
e_IOC_FM_PCD_MANIP_TIME_OUT_BETWEEN_FRAG
|
||
|
/**< Limits the time of receiving the
|
||
|
* fragment
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_reassem_time_out_mode;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of WaysNumber mode
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_reassem_ways_number {
|
||
|
e_IOC_FM_PCD_MANIP_ONE_WAY_HASH = 1, /**< One way hash */
|
||
|
e_IOC_FM_PCD_MANIP_TWO_WAYS_HASH, /**< Two ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_THREE_WAYS_HASH, /**< Three ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_FOUR_WAYS_HASH, /**< Four ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_FIVE_WAYS_HASH, /**< Five ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_SIX_WAYS_HASH, /**< Six ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_SEVEN_WAYS_HASH, /**< Seven ways hash */
|
||
|
e_IOC_FM_PCD_MANIP_EIGHT_WAYS_HASH /**< Eight ways hash */
|
||
|
} ioc_fm_pcd_manip_reassem_ways_number;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting manipulation type
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_type {
|
||
|
e_IOC_FM_PCD_MANIP_HDR = 0, /**< Header manipulation */
|
||
|
e_IOC_FM_PCD_MANIP_REASSEM, /**< Reassembly */
|
||
|
e_IOC_FM_PCD_MANIP_FRAG, /**< Fragmentation */
|
||
|
e_IOC_FM_PCD_MANIP_SPECIAL_OFFLOAD /**< Special Offloading */
|
||
|
} ioc_fm_pcd_manip_type;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of statistics mode
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_cc_stats_mode {
|
||
|
e_IOC_FM_PCD_CC_STATS_MODE_NONE = 0, /**< No statistics support */
|
||
|
e_IOC_FM_PCD_CC_STATS_MODE_FRAME, /**< Frame count statistics */
|
||
|
e_IOC_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME,
|
||
|
/**< Byte and frame count statistics */
|
||
|
e_IOC_FM_PCD_CC_STATS_MODE_RMON,
|
||
|
/**< Byte and frame length range count statistics */
|
||
|
} ioc_fm_pcd_cc_stats_mode;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for determining the action in case an IP
|
||
|
* packet is larger than MTU but its DF (Don't Fragment) bit is
|
||
|
* set.
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_donot_frag_action {
|
||
|
e_IOC_FM_PCD_MANIP_DISCARD_PACKET = 0, /**< Discard packet */
|
||
|
e_IOC_FM_PCD_MANIP_ENQ_TO_ERR_Q_OR_DISCARD_PACKET =
|
||
|
e_IOC_FM_PCD_MANIP_DISCARD_PACKET,
|
||
|
/**< Obsolete, cannot enqueue to error queue; In
|
||
|
* practice, selects to discard packets; Will be
|
||
|
* removed in the future
|
||
|
*/
|
||
|
e_IOC_FM_PCD_MANIP_FRAGMENT_PACKECT,
|
||
|
/**< Fragment packet and continue normal
|
||
|
* processing
|
||
|
*/
|
||
|
e_IOC_FM_PCD_MANIP_CONTINUE_WITHOUT_FRAG
|
||
|
/**< Continue normal processing without
|
||
|
* fragmenting the packet
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_donot_frag_action;
|
||
|
|
||
|
/*
|
||
|
* @Description Enumeration type for selecting type of special offload
|
||
|
* manipulation
|
||
|
*/
|
||
|
typedef enum ioc_fm_pcd_manip_special_offload_type {
|
||
|
e_IOC_FM_PCD_MANIP_SPECIAL_OFFLOAD_IPSEC,
|
||
|
/**< IPSec offload manipulation */
|
||
|
e_IOC_FM_PCD_MANIP_SPECIAL_OFFLOAD_CAPWAP
|
||
|
/**< CAPWAP offload manipulation */
|
||
|
} ioc_fm_pcd_manip_special_offload_type;
|
||
|
|
||
|
/*
|
||
|
* @Description A union of protocol dependent special options
|
||
|
* (Must match union u_FmPcdHdrProtocolOpt defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef union ioc_fm_pcd_hdr_protocol_opt_u {
|
||
|
ioc_eth_protocol_opt_t eth_opt; /**< Ethernet options */
|
||
|
ioc_vlan_protocol_opt_t vlan_opt; /**< Vlan options */
|
||
|
ioc_mpls_protocol_opt_t mpls_opt; /**< MPLS options */
|
||
|
ioc_ipv4_protocol_opt_t ipv4_opt; /**< IPv4 options */
|
||
|
ioc_ipv6_protocol_opt_t ipv6_opt; /**< IPv6 options */
|
||
|
ioc_capwap_protocol_opt_t capwap_opt; /**< CAPWAP options */
|
||
|
} ioc_fm_pcd_hdr_protocol_opt_u;
|
||
|
|
||
|
/*
|
||
|
* @Description A union holding all known protocol fields
|
||
|
*/
|
||
|
typedef union ioc_fm_pcd_fields_u {
|
||
|
ioc_header_field_eth_t eth; /**< Ethernet*/
|
||
|
ioc_header_field_vlan_t vlan; /**< VLAN*/
|
||
|
ioc_header_field_llc_snap_t llc_snap; /**< LLC SNAP*/
|
||
|
ioc_header_field_pppoe_t pppoe; /**< PPPoE*/
|
||
|
ioc_header_field_mpls_t mpls; /**< MPLS*/
|
||
|
ioc_header_field_ip_t ip; /**< IP */
|
||
|
ioc_header_field_ipv4_t ipv4; /**< IPv4*/
|
||
|
ioc_header_field_ipv6_t ipv6; /**< IPv6*/
|
||
|
ioc_header_field_udp_t udp; /**< UDP */
|
||
|
ioc_header_field_udp_lite_t udp_lite; /**< UDP_Lite*/
|
||
|
ioc_header_field_tcp_t tcp; /**< TCP */
|
||
|
ioc_header_field_sctp_t sctp; /**< SCTP*/
|
||
|
ioc_header_field_dccp_t dccp; /**< DCCP*/
|
||
|
ioc_header_field_gre_t gre; /**< GRE */
|
||
|
ioc_header_field_minencap_t minencap;/**< Minimal Encapsulation */
|
||
|
ioc_header_field_ipsec_ah_t ipsec_ah; /**< IPSec AH*/
|
||
|
ioc_header_field_ipsec_esp_t ipsec_esp; /**< IPSec ESP*/
|
||
|
ioc_header_field_udp_encap_esp_t udp_encap_esp;
|
||
|
/**< UDP Encapsulation ESP */
|
||
|
} ioc_fm_pcd_fields_u;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header extraction for key generation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_from_hdr_t {
|
||
|
uint8_t size; /**< Size in byte */
|
||
|
uint8_t offset; /**< Byte offset */
|
||
|
} ioc_fm_pcd_from_hdr_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining field extraction for key generation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_from_field_t {
|
||
|
ioc_fm_pcd_fields_u field; /**< Field selection */
|
||
|
uint8_t size; /**< Size in byte */
|
||
|
uint8_t offset; /**< Byte offset */
|
||
|
} ioc_fm_pcd_from_field_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a single network environment unit
|
||
|
* A distinction unit should be defined if it will later be used
|
||
|
* by one or more PCD engines to distinguish between flows.
|
||
|
* (Must match struct t_FmPcdDistinctionUnit defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_distinction_unit_t {
|
||
|
struct {
|
||
|
ioc_net_header_type hdr;
|
||
|
/**< One of the headers supported by the FM */
|
||
|
ioc_fm_pcd_hdr_protocol_opt_u opt; /**< Select only one option! */
|
||
|
} hdrs[IOC_FM_PCD_MAX_NUM_OF_INTERCHANGEABLE_HDRS];
|
||
|
} ioc_fm_pcd_distinction_unit_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining all different distinction units
|
||
|
* supported by a specific PCD Network Environment
|
||
|
* Characteristics module.
|
||
|
*
|
||
|
* Each unit represent a protocol or a group of protocols that
|
||
|
* may be used later by the different PCD engines to distinguish
|
||
|
* between flows.
|
||
|
* (Must match struct t_FmPcdNetEnvParams defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
struct fm_pcd_net_env_params_t {
|
||
|
uint8_t num_of_distinction_units;
|
||
|
/**< Number of different units to be identified */
|
||
|
ioc_fm_pcd_distinction_unit_t
|
||
|
units[IOC_FM_PCD_MAX_NUM_OF_DISTINCTION_UNITS];
|
||
|
/**< An array of num_of_distinction_units of the different units to be
|
||
|
* identified
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_net_env_params_t {
|
||
|
struct fm_pcd_net_env_params_t param;
|
||
|
void *id;
|
||
|
/**< Output parameter; Returns the net-env Id to be used */
|
||
|
} ioc_fm_pcd_net_env_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a single extraction action when
|
||
|
* creating a key
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_extract_entry_t {
|
||
|
ioc_fm_pcd_extract_type type; /**< Extraction type select */
|
||
|
union {
|
||
|
struct {
|
||
|
ioc_net_header_type hdr; /**< Header selection */
|
||
|
bool ignore_protocol_validation;
|
||
|
/**< Ignore protocol validation */
|
||
|
ioc_fm_pcd_hdr_index hdr_index;
|
||
|
/**< Relevant only for MPLS, VLAN and
|
||
|
* tunneled IP. Otherwise should be
|
||
|
* cleared.
|
||
|
*/
|
||
|
ioc_fm_pcd_extract_by_hdr_type type;
|
||
|
/**< Header extraction type select */
|
||
|
union {
|
||
|
ioc_fm_pcd_from_hdr_t from_hdr;
|
||
|
/**< Extract bytes from header
|
||
|
* parameters
|
||
|
*/
|
||
|
ioc_fm_pcd_from_field_t from_field;
|
||
|
/**< Extract bytes from field parameters
|
||
|
*/
|
||
|
ioc_fm_pcd_fields_u full_field;
|
||
|
/**< Extract full field parameters */
|
||
|
} extract_by_hdr_type;
|
||
|
} extract_by_hdr;/**< Used when type = e_IOC_FM_PCD_KG_EXTRACT_BY_HDR */
|
||
|
struct {
|
||
|
ioc_fm_pcd_extract_from src;
|
||
|
/**< Non-header extraction source */
|
||
|
ioc_fm_pcd_action action; /**< Relevant for CC Only */
|
||
|
uint16_t ic_indx_mask;
|
||
|
/**< Relevant only for CC whenaction =
|
||
|
* e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP; Note that
|
||
|
* the number of bits that are set within this
|
||
|
* mask must be log2 of the CC-node
|
||
|
* 'num_of_keys'. Note that the mask cannot be
|
||
|
* set on the lower bits.
|
||
|
*/
|
||
|
uint8_t offset; /**< Byte offset */
|
||
|
uint8_t size; /**< Size in bytes */
|
||
|
} extract_non_hdr;
|
||
|
/**< Used when type = e_IOC_FM_PCD_KG_EXTRACT_NON_HDR */
|
||
|
} extract_params;
|
||
|
} ioc_fm_pcd_extract_entry_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining masks for each extracted
|
||
|
* field in the key.
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_extract_mask_t {
|
||
|
uint8_t extract_array_index;
|
||
|
/**< Index in the extraction array, as
|
||
|
* initialized by user
|
||
|
*/
|
||
|
uint8_t offset; /**< Byte offset */
|
||
|
uint8_t mask;
|
||
|
/**< A byte mask (selected bits will be ignored) */
|
||
|
} ioc_fm_pcd_kg_extract_mask_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining default selection per groups of
|
||
|
* fields
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_extract_dflt_t {
|
||
|
ioc_fm_pcd_kg_known_fields_dflt_types type;
|
||
|
/**< Default type select */
|
||
|
ioc_fm_pcd_kg_extract_dflt_select dflt_select;
|
||
|
/**< Default register select */
|
||
|
} ioc_fm_pcd_kg_extract_dflt_t;
|
||
|
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining all parameters needed for
|
||
|
* generation a key and using a hash function
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_key_extract_and_hash_params_t {
|
||
|
uint32_t private_dflt0;
|
||
|
/**< Scheme default register 0 */
|
||
|
uint32_t private_dflt1;
|
||
|
/**< Scheme default register 1 */
|
||
|
uint8_t num_of_used_extracts;
|
||
|
/**< defines the valid size of the
|
||
|
* following array
|
||
|
*/
|
||
|
ioc_fm_pcd_extract_entry_t
|
||
|
extract_array[IOC_FM_PCD_KG_MAX_EXTRACTS_PER_KEY];
|
||
|
/**< An array of extraction definitions.
|
||
|
*/
|
||
|
uint8_t num_of_used_dflts;
|
||
|
/**< defines the valid size of the
|
||
|
* following array
|
||
|
*/
|
||
|
ioc_fm_pcd_kg_extract_dflt_t
|
||
|
dflts[IOC_FM_PCD_KG_NUM_OF_DEFAULT_GROUPS];
|
||
|
/**< For each extraction used in this
|
||
|
* scheme, specify the required default
|
||
|
* register to be used when header is
|
||
|
* not found. types not specified in
|
||
|
* this array will get undefined value.
|
||
|
*/
|
||
|
uint8_t num_of_used_masks;
|
||
|
/**< Defines the valid size of the
|
||
|
* following array
|
||
|
*/
|
||
|
ioc_fm_pcd_kg_extract_mask_t
|
||
|
masks[IOC_FM_PCD_KG_NUM_OF_EXTRACT_MASKS];
|
||
|
uint8_t hash_shift;
|
||
|
/**< Hash result right shift. Selects
|
||
|
* the 24 bits out of the 64 hash
|
||
|
* result. 0 means using the 24 LSB's,
|
||
|
* otherwise use the 24 LSB's after
|
||
|
* shifting right.
|
||
|
*/
|
||
|
uint32_t hash_dist_num_of_fqids;
|
||
|
/**< must be > 1 and a power of 2.
|
||
|
* Represents the range of queues for
|
||
|
* the key and hash functionality
|
||
|
*/
|
||
|
uint8_t hash_distribution_fqids_shift;
|
||
|
/**< selects the FQID bits that will be
|
||
|
* effected by the hash
|
||
|
*/
|
||
|
bool symmetric_hash;
|
||
|
/**< TRUE to generate the same hash for
|
||
|
* frames with swapped source and
|
||
|
* destination fields on all layers; If
|
||
|
* TRUE, driver will check that for all
|
||
|
* layers, if SRC extraction is
|
||
|
* selected, DST extraction must also be
|
||
|
* selected, and vice versa.
|
||
|
*/
|
||
|
} ioc_fm_pcd_kg_key_extract_and_hash_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure of parameters for defining a single Qid mask
|
||
|
* (extracted OR).
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_extracted_or_params_t {
|
||
|
ioc_fm_pcd_extract_type type;
|
||
|
/**< Extraction type select */
|
||
|
union {
|
||
|
struct {
|
||
|
/**< used when type = e_IOC_FM_PCD_KG_EXTRACT_BY_HDR */
|
||
|
ioc_net_header_type hdr;
|
||
|
ioc_fm_pcd_hdr_index hdr_index;
|
||
|
/**< Relevant only for MPLS,
|
||
|
* VLAN and tunneled IP.
|
||
|
* Otherwise should be cleared.
|
||
|
*/
|
||
|
bool ignore_protocol_validation;
|
||
|
|
||
|
} extract_by_hdr;
|
||
|
ioc_fm_pcd_extract_from src;
|
||
|
/**< used when type =
|
||
|
* e_IOC_FM_PCD_KG_EXTRACT_NON_HDR
|
||
|
*/
|
||
|
} extract_params;
|
||
|
uint8_t extraction_offset;
|
||
|
/**< Offset for extraction */
|
||
|
ioc_fm_pcd_kg_extract_dflt_select dflt_value;
|
||
|
/**< Select register from which
|
||
|
* extraction is taken if field not
|
||
|
* found
|
||
|
*/
|
||
|
uint8_t mask;
|
||
|
/**< Mask LSB byte of extraction
|
||
|
* (specified bits are ignored)
|
||
|
*/
|
||
|
|
||
|
uint8_t bit_offset_in_fqid;
|
||
|
/**< 0-31, Selects which bits of the 24 FQID bits to effect
|
||
|
* using the extracted byte; Assume byte is placed as the 8
|
||
|
* MSB's in a 32 bit word where the lower bits are the FQID; i.e
|
||
|
* if bitOffsetInFqid=1 than its LSB will effect the FQID MSB,
|
||
|
* if bitOffsetInFqid=24 than the extracted byte will effect the
|
||
|
* 8 LSB's of the FQID, if bitOffsetInFqid=31 than the byte's
|
||
|
* MSB will effect the FQID's LSB; 0 means - no effect on FQID;
|
||
|
* Note that one, and only one of bitOffsetInFqid or
|
||
|
* bitOffsetInPlcrProfile must be set (i.e, extracted byte must
|
||
|
* effect either FQID or Policer profile).
|
||
|
*/
|
||
|
uint8_t bit_offset_in_plcr_profile;
|
||
|
/**< 0-15, Selects which bits of the 8 policer profile id bits
|
||
|
* to effect using the extracted byte; Assume byte is placed as
|
||
|
* the 8 MSB's in a 16 bit word where the lower bits are the
|
||
|
* policer profile id; i.e if bitOffsetInPlcrProfile=1 than its
|
||
|
* LSB will effect the profile MSB, if bitOffsetInFqid=8 than
|
||
|
* the extracted byte will effect the whole policer profile id,
|
||
|
* if bitOffsetInFqid=15 than the byte's MSB will effect the
|
||
|
* Policer Profile id's LSB; 0 means - no effect on policer
|
||
|
* profile; Note that one, and only one of bitOffsetInFqid or
|
||
|
* bitOffsetInPlcrProfile must be set (i.e, extracted byte must
|
||
|
* effect either FQID or Policer profile).
|
||
|
*/
|
||
|
} ioc_fm_pcd_kg_extracted_or_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for configuring scheme counter
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_scheme_counter_t {
|
||
|
bool update;
|
||
|
/**< FALSE to keep the current counter state and
|
||
|
* continue from that point, TRUE to update/reset the
|
||
|
* counter when the scheme is written.
|
||
|
*/
|
||
|
uint32_t value;
|
||
|
/**< If update=TRUE, this value will be written into the
|
||
|
* counter; clear this field to reset the counter.
|
||
|
*/
|
||
|
} ioc_fm_pcd_kg_scheme_counter_t;
|
||
|
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for retrieving FMKG_SE_SPC
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_scheme_spc_t {
|
||
|
uint32_t val; /**< return value */
|
||
|
void *id; /**< scheme handle */
|
||
|
} ioc_fm_pcd_kg_scheme_spc_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining policer profile parameters as
|
||
|
* required by keygen (when policer is the next engine after this
|
||
|
* scheme).
|
||
|
* (Must match struct t_FmPcdKgPlcrProfile defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_plcr_profile_t {
|
||
|
bool shared_profile;
|
||
|
/**< TRUE if this profile is shared between ports (i.e.
|
||
|
* managed by primary partition) May not be TRUE if
|
||
|
* profile is after Coarse Classification
|
||
|
*/
|
||
|
bool direct;
|
||
|
/**< If TRUE, direct_relative_profile_id only selects
|
||
|
* the profile id, if FALSE
|
||
|
* fqid_offset_relative_profile_id_base is used together
|
||
|
* with fqid_offset_shift and num_of_profiles
|
||
|
* parameters, to define a range of profiles from which
|
||
|
* the KeyGen result will determine the destination
|
||
|
* policer profile.
|
||
|
*/
|
||
|
union {
|
||
|
uint16_t direct_relative_profile_id;
|
||
|
/**< Used if 'direct' is TRUE, to select policer
|
||
|
* profile. This parameter should indicate the policer
|
||
|
* profile offset within the port's policer profiles or
|
||
|
* SHARED window.
|
||
|
*/
|
||
|
struct {
|
||
|
uint8_t fqid_offset_shift;
|
||
|
/**< Shift of KG results without the qid base */
|
||
|
uint8_t fqid_offset_relative_profile_id_base;
|
||
|
/**< OR of KG results without the qid base This
|
||
|
* parameter should indicate the policer profile offset
|
||
|
* within the port's policer profiles window or SHARED
|
||
|
* window depends on shared_profile
|
||
|
*/
|
||
|
uint8_t num_of_profiles;
|
||
|
/**< Range of profiles starting at base */
|
||
|
} indirect_profile; /**< Indirect profile parameters */
|
||
|
} profile_select;
|
||
|
/**< Direct/indirect profile selection and parameters */
|
||
|
} ioc_fm_pcd_kg_plcr_profile_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for configuring a storage profile for a KeyGen
|
||
|
* scheme.
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_storage_profile_t {
|
||
|
bool direct;
|
||
|
/**< If TRUE, directRelativeProfileId only selects the profile
|
||
|
* id; If FALSE, fqidOffsetRelativeProfileIdBase is used
|
||
|
* together with fqidOffsetShift and num_of_profiles parameters
|
||
|
* to define a range of profiles from which the KeyGen result
|
||
|
* will determine the destination storage profile.
|
||
|
*/
|
||
|
union {
|
||
|
uint16_t direct_relative_profile_id;
|
||
|
/**< Used when 'direct' is TRUE, to select a storage profile;
|
||
|
* should indicate the storage profile offset within the port's
|
||
|
* storage profiles window.
|
||
|
*/
|
||
|
struct {
|
||
|
uint8_t fqid_offset_shift;
|
||
|
/**< Shift of KeyGen results without the FQID base */
|
||
|
uint8_t fqid_offset_relative_profile_id_base;
|
||
|
/**< OR of KeyGen results without the FQID base; should
|
||
|
* indicate the policer profile offset within the port's
|
||
|
* storage profiles window.
|
||
|
*/
|
||
|
uint8_t num_of_profiles;
|
||
|
/**< Range of profiles starting at base. */
|
||
|
} indirect_profile;
|
||
|
/**< Indirect profile parameters. */
|
||
|
} profile_select;
|
||
|
/**< Direct/indirect profile selection and parameters. */
|
||
|
} ioc_fm_pcd_kg_storage_profile_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining CC as the next engine after KeyGen
|
||
|
* (Must match struct t_FmPcdKgCc defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_kg_cc_t {
|
||
|
void *tree_id;
|
||
|
/**< CC Tree id */
|
||
|
uint8_t grp_id;
|
||
|
/**< CC group id within the CC tree */
|
||
|
bool plcr_next;
|
||
|
/**< TRUE if after CC, in case of data
|
||
|
* frame, policing is required.
|
||
|
*/
|
||
|
bool bypass_plcr_profile_generation;
|
||
|
/**< TRUE to bypass KeyGen policer
|
||
|
* profile generation; selected profile
|
||
|
* is the one set at port initialization
|
||
|
*/
|
||
|
ioc_fm_pcd_kg_plcr_profile_t plcr_profile;
|
||
|
/**< Valid only if plcr_next = TRUE and
|
||
|
* bypass_plcr_profile_generation =
|
||
|
* FALSE
|
||
|
*/
|
||
|
} ioc_fm_pcd_kg_cc_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining initializing a KeyGen scheme (Must
|
||
|
* match struct t_FmPcdKgSchemeParams defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
struct fm_pcd_kg_scheme_params_t {
|
||
|
bool modify; /**< TRUE to change an existing scheme */
|
||
|
union {
|
||
|
uint8_t relative_scheme_id;
|
||
|
/**< if modify=FALSE: partition-relative scheme id */
|
||
|
void *scheme_id;
|
||
|
/**< if modify=TRUE: the id of an existing scheme */
|
||
|
} scm_id;
|
||
|
bool always_direct;
|
||
|
/**< This scheme is reached only directly, i.e. no need for
|
||
|
* match vector; KeyGen will ignore it when matching
|
||
|
*/
|
||
|
struct {
|
||
|
/**< HL relevant only if always_direct=FALSE */
|
||
|
void *net_env_id;
|
||
|
/**< The id of the Network Environment as returned
|
||
|
* by fm_pcd_net_env_characteristics_set()
|
||
|
*/
|
||
|
uint8_t num_of_distinction_units;
|
||
|
/**< Number of NetEnv units listed in unit_ids array */
|
||
|
uint8_t unit_ids[IOC_FM_PCD_MAX_NUM_OF_DISTINCTION_UNITS];
|
||
|
/**< Indexes as passed to SetNetEnvCharacteristics (?) array */
|
||
|
} net_env_params;
|
||
|
bool use_hash;
|
||
|
/**< use the KG Hash functionality */
|
||
|
ioc_fm_pcd_kg_key_extract_and_hash_params_t key_ext_and_hash;
|
||
|
/**< used only if useHash = TRUE */
|
||
|
bool bypass_fqid_generation;
|
||
|
/**< Normally - FALSE, TRUE to avoid FQID update in the IC; In
|
||
|
* such a case FQID after KG will be the default FQID defined
|
||
|
* for the relevant port, or the FQID defined by CC in cases
|
||
|
* where CC was the previous engine.
|
||
|
*/
|
||
|
uint32_t base_fqid;
|
||
|
/**< Base FQID; Relevant only if bypass_fqid_generation = FALSE;
|
||
|
* If hash is used and an even distribution is expected
|
||
|
* according to hash_dist_num_of_fqids, base_fqid must
|
||
|
* be aligned to hash_dist_num_of_fqids.
|
||
|
*/
|
||
|
uint8_t num_of_used_extracted_ors;
|
||
|
/**< Number of FQID masks listed in extracted_ors array*/
|
||
|
ioc_fm_pcd_kg_extracted_or_params_t
|
||
|
extracted_ors[IOC_FM_PCD_KG_NUM_OF_GENERIC_REGS];
|
||
|
/**< IOC_FM_PCD_KG_NUM_OF_GENERIC_REGS registers are shared
|
||
|
* between qid_masks functionality and some of the extraction
|
||
|
* actions; Normally only some will be used for qid_mask. Driver
|
||
|
* will return error if resource is full at initialization time.
|
||
|
*/
|
||
|
bool override_storage_profile;
|
||
|
/**< TRUE if KeyGen override previously decided storage profile
|
||
|
*/
|
||
|
ioc_fm_pcd_kg_storage_profile_t storage_profile;
|
||
|
/**< Used when override_storage_profile=TRUE */
|
||
|
ioc_fm_pcd_engine next_engine;
|
||
|
/**< may be BMI, PLCR or CC */
|
||
|
union {
|
||
|
/**< depends on nextEngine */
|
||
|
ioc_fm_pcd_done_action done_action;
|
||
|
/**< Used when next engine is BMI (done) */
|
||
|
ioc_fm_pcd_kg_plcr_profile_t plcr_profile;
|
||
|
/**< Used when next engine is PLCR */
|
||
|
ioc_fm_pcd_kg_cc_t cc;
|
||
|
/**< Used when next engine is CC */
|
||
|
} kg_next_engine_params;
|
||
|
ioc_fm_pcd_kg_scheme_counter_t scheme_counter;
|
||
|
/**< A structure of parameters for updating the scheme counter*/
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_kg_scheme_params_t {
|
||
|
struct fm_pcd_kg_scheme_params_t param;
|
||
|
void *id; /**< Returns the scheme Id to be used */
|
||
|
} ioc_fm_pcd_kg_scheme_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Collection
|
||
|
*/
|
||
|
#define IOC_FM_PCD_CC_STATS_MAX_FLR 10
|
||
|
/* Maximal supported number of frame length ranges */
|
||
|
#define IOC_FM_PCD_CC_STATS_FLR_SIZE 2
|
||
|
/* Size in bytes of a frame length range limit */
|
||
|
#define IOC_FM_PCD_CC_STATS_FLR_COUNT_SIZE 4
|
||
|
/* Size in bytes of a frame length range counter */
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining CC as the next engine after a CC node.
|
||
|
* (Must match struct t_FmPcdCcNextCcParams defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_cc_params_t {
|
||
|
void *cc_node_id; /**< Id of the next CC node */
|
||
|
} ioc_fm_pcd_cc_next_cc_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining Frame Replicator as the next engine
|
||
|
* after a CC node. (Must match struct t_FmPcdCcNextFrParams
|
||
|
* defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_fr_params_t {
|
||
|
void *frm_replic_id;
|
||
|
/**< The id of the next frame replicator group */
|
||
|
} ioc_fm_pcd_cc_next_fr_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining PLCR params when PLCR is the
|
||
|
* next engine after a CC node
|
||
|
* (Must match struct t_FmPcdCcNextPlcrParams defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_plcr_params_t {
|
||
|
bool override_params;
|
||
|
/**< TRUE if CC override previously decided parameters*/
|
||
|
bool shared_profile;
|
||
|
/**< Relevant only if overrideParams=TRUE: TRUE if this profile
|
||
|
* is shared between ports
|
||
|
*/
|
||
|
uint16_t new_relative_profile_id;
|
||
|
/**< Relevant only if overrideParams=TRUE: (otherwise profile id
|
||
|
* is taken from keygen); This parameter should indicate the
|
||
|
* policer profile offset within the port's policer profiles or
|
||
|
* from SHARED window.
|
||
|
*/
|
||
|
uint32_t new_fqid;
|
||
|
/**< Relevant only if overrideParams=TRUE: FQID for enquing the
|
||
|
* frame; In earlier chips if policer next engine is KEYGEN,
|
||
|
* this parameter can be 0, because the KEYGEN always decides
|
||
|
* the enqueue FQID.
|
||
|
*/
|
||
|
uint8_t new_relative_storage_profile_id;
|
||
|
/**< Indicates the relative storage profile offset within the
|
||
|
* port's storage profiles window; Relevant only if the port was
|
||
|
* configured with VSP.
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_next_plcr_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining enqueue params when BMI is the next
|
||
|
* engine after a CC node (Must match struct
|
||
|
* t_FmPcdCcNextEnqueueParams defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_enqueue_params_t {
|
||
|
ioc_fm_pcd_done_action action;
|
||
|
/**< Action - when next engine is BMI (done) */
|
||
|
bool override_fqid;
|
||
|
/**< TRUE if CC override previously decided fqid
|
||
|
* and vspid, relevant if action =
|
||
|
* e_IOC_FM_PCD_ENQ_FRAME
|
||
|
*/
|
||
|
uint32_t new_fqid;
|
||
|
/**< Valid if overrideFqid=TRUE, FQID for
|
||
|
* enqueuing the frame (otherwise FQID is taken
|
||
|
* from KeyGen), relevant if action =
|
||
|
* e_IOC_FM_PCD_ENQ_FRAME
|
||
|
*/
|
||
|
uint8_t new_relative_storage_profile_id;
|
||
|
/**< Valid if override_fqid=TRUE, Indicates the relative
|
||
|
* virtual storage profile offset within the port's
|
||
|
* storage profiles window; Relevant only if the port
|
||
|
* was configured with VSP.
|
||
|
*/
|
||
|
|
||
|
} ioc_fm_pcd_cc_next_enqueue_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for defining KG params when KG is the next engine
|
||
|
* after a CC node (Must match struct t_FmPcdCcNextKgParams
|
||
|
* defined in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_kg_params_t {
|
||
|
bool override_fqid;
|
||
|
/**< TRUE if CC override previously decided fqid and vspid,
|
||
|
* Note - this parameters are irrelevant for earlier chips
|
||
|
*/
|
||
|
uint32_t new_fqid;
|
||
|
/**< Valid if overrideFqid=TRUE, FQID for enqueuing the frame
|
||
|
* (otherwise FQID is taken from KeyGen),
|
||
|
* Note - this parameters are irrelevant for earlier chips
|
||
|
*/
|
||
|
uint8_t new_relative_storage_profile_id;
|
||
|
/**< Valid if override_fqid=TRUE, Indicates the relative virtual
|
||
|
* storage profile offset within the port's storage profiles
|
||
|
* window; Relevant only if the port was configured with VSP.
|
||
|
*/
|
||
|
void *p_direct_scheme; /**< Direct scheme id to go to. */
|
||
|
} ioc_fm_pcd_cc_next_kg_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining the next engine after a CC node.
|
||
|
* (Must match struct ioc_fm_pcd_cc_next_engine_params_t defined
|
||
|
* in fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_next_engine_params_t {
|
||
|
ioc_fm_pcd_engine next_engine;
|
||
|
/**< User has to initialize parameters according
|
||
|
* to nextEngine definition
|
||
|
*/
|
||
|
union {
|
||
|
ioc_fm_pcd_cc_next_cc_params_t cc_params;
|
||
|
/**< Parameters in case next engine is CC */
|
||
|
ioc_fm_pcd_cc_next_plcr_params_t plcr_params;
|
||
|
/**< Parameters in case next engine is PLCR */
|
||
|
ioc_fm_pcd_cc_next_enqueue_params_t enqueue_params;
|
||
|
/**< Parameters in case next engine is BMI */
|
||
|
ioc_fm_pcd_cc_next_kg_params_t kg_params;
|
||
|
/**< Parameters in case next engine is KG */
|
||
|
ioc_fm_pcd_cc_next_fr_params_t fr_params;
|
||
|
/**< Parameters in case next engine is FR */
|
||
|
} params;
|
||
|
/**< Union used for all the next-engine parameters options */
|
||
|
void *manip_id;
|
||
|
/**< Handle to Manipulation object. Relevant if
|
||
|
* next engine is of type result
|
||
|
* (e_IOC_FM_PCD_PLCR, e_IOC_FM_PCD_KG,
|
||
|
* e_IOC_FM_PCD_DONE)
|
||
|
*/
|
||
|
bool statistics_en;
|
||
|
/**< If TRUE, statistics counters are
|
||
|
* incremented for each frame passing through
|
||
|
* this Coarse Classification entry.
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_next_engine_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a single CC key
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_key_params_t {
|
||
|
uint8_t *p_key;
|
||
|
/**< pointer to the key of the size defined in key_size
|
||
|
*/
|
||
|
uint8_t *p_mask;
|
||
|
/**< pointer to the Mask per key of the size defined in
|
||
|
* key_size. p_key and p_mask (if defined) has to be of
|
||
|
* the same size defined in the key_size
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params;
|
||
|
/**< parameters for the next for the defined Key in
|
||
|
* p_key
|
||
|
*/
|
||
|
|
||
|
} ioc_fm_pcd_cc_key_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining CC keys parameters
|
||
|
* The driver supports two methods for CC node allocation:
|
||
|
* dynamic and static. Static mode was created in order to
|
||
|
* prevent runtime alloc/free of FMan memory (MURAM), which may
|
||
|
* cause fragmentation; in this mode, the driver automatically
|
||
|
* allocates the memory according to 'max_num_of_keys' parameter.
|
||
|
* The driver calculates the maximal memory size that may be used
|
||
|
* for this CC-Node taking into consideration 'mask_support' and
|
||
|
* 'statistics_mode' parameters. When 'action' =
|
||
|
* e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP in the extraction
|
||
|
* parameters of this node, 'max_num_of_keys' must be equal to
|
||
|
* 'num_of_keys'. In dynamic mode, 'max_num_of_keys' must be
|
||
|
* zero. At initialization, all required structures are allocated
|
||
|
* according to 'num_of_keys' parameter. During runtime
|
||
|
* modification, these structures are re-allocated according to
|
||
|
* the updated number of keys.
|
||
|
* Please note that 'action' and 'ic_indx_mask' mentioned in the
|
||
|
* specific parameter explanations are passed in the extraction
|
||
|
* parameters of the node (fields of
|
||
|
* extractccparams.extractnonhdr).
|
||
|
*/
|
||
|
typedef struct ioc_keys_params_t {
|
||
|
uint16_t max_num_of_keys;
|
||
|
/**< Maximum number of keys that will (ever) be used in
|
||
|
* this CC-Node; A value of zero may be used for dynamic
|
||
|
* memory allocation.
|
||
|
*/
|
||
|
bool mask_support;
|
||
|
/**< This parameter is relevant only if a node is
|
||
|
* initialized with action =
|
||
|
* e_IOC_FM_PCD_ACTION_EXACT_MATCH and max_num_of_keys >
|
||
|
* 0; Should be TRUE to reserve table memory for key
|
||
|
* masks, even if initial keys do not contain masks, or
|
||
|
* if the node was initialized as 'empty' (without
|
||
|
* keys); this will allow user to add keys with masks at
|
||
|
* runtime.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_stats_mode statistics_mode;
|
||
|
/**< Determines the supported statistics mode for all
|
||
|
* node's keys. To enable statistics gathering,
|
||
|
* statistics should be enabled per every key, using
|
||
|
* 'statistics_en' in next engine parameters structure
|
||
|
* of that key; If 'max_num_of_keys' is set, all
|
||
|
* required structures will be preallocated for all keys
|
||
|
*/
|
||
|
uint16_t frame_length_ranges[IOC_FM_PCD_CC_STATS_MAX_FLR];
|
||
|
/**< Relevant only for 'RMON' statistics mode (this feature is
|
||
|
* supported only on B4860 device); Holds a list of programmable
|
||
|
* thresholds. For each received frame, its length in bytes is
|
||
|
* examined against these range thresholds and the appropriate
|
||
|
* counter is incremented by 1. For example, to belong to range
|
||
|
* i, the following should hold: range i-1 threshold < frame
|
||
|
* length <= range i threshold Each range threshold must be
|
||
|
* larger then its preceding range threshold. Last range
|
||
|
* threshold must be 0xFFFF.
|
||
|
*/
|
||
|
uint16_t num_of_keys;
|
||
|
/**< Number of initial keys; Note that in case of 'action' =
|
||
|
* e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP, this field should be
|
||
|
* power-of-2 of the number of bits that are set in
|
||
|
* 'ic_indx_mask'.
|
||
|
*/
|
||
|
uint8_t key_size;
|
||
|
/**< Size of key - for extraction of type FULL_FIELD, 'key_size'
|
||
|
* has to be the standard size of the selected key; For other
|
||
|
* extraction types, 'key_size' has to be as size of extraction;
|
||
|
* When 'action' = e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP,
|
||
|
* 'key_size' must be 2.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_key_params_t key_params[IOC_FM_PCD_MAX_NUM_OF_KEYS];
|
||
|
/**< An array with 'num_of_keys' entries, each entry specifies
|
||
|
* the corresponding key parameters; When 'action' =
|
||
|
* e_IOC_FM_PCD_ACTION_EXACT_MATCH, this value must not exceed
|
||
|
* 255 (IOC_FM_PCD_MAX_NUM_OF_KEYS-1) as the last entry is saved
|
||
|
* for the 'miss' entry.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params_for_miss;
|
||
|
/**< Parameters for defining the next engine when a key is not
|
||
|
* matched; Not relevant if action =
|
||
|
* e_IOC_FM_PCD_ACTION_INDEXED_LOOKUP.
|
||
|
*/
|
||
|
} ioc_keys_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a CC node
|
||
|
*/
|
||
|
struct fm_pcd_cc_node_params_t {
|
||
|
ioc_fm_pcd_extract_entry_t extract_cc_params;
|
||
|
/**< Extraction parameters */
|
||
|
ioc_keys_params_t keys_params;
|
||
|
/**< Keys definition matching the selected extraction */
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_cc_node_params_t {
|
||
|
struct fm_pcd_cc_node_params_t param;
|
||
|
void *id;
|
||
|
/**< Output parameter; returns the CC node Id to be used */
|
||
|
} ioc_fm_pcd_cc_node_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a hash table
|
||
|
* (Must match struct ioc_fm_pcd_hash_table_params_t defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
struct fm_pcd_hash_table_params_t {
|
||
|
uint16_t max_num_of_keys;
|
||
|
/**< Maximum Number Of Keys that will (ever) be used in this
|
||
|
* Hash-table
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_stats_mode statistics_mode;
|
||
|
/**< If not e_IOC_FM_PCD_CC_STATS_MODE_NONE, the required
|
||
|
* structures for the requested statistics mode will be
|
||
|
* allocated according to max_num_of_keys.
|
||
|
*/
|
||
|
uint8_t kg_hash_shift;
|
||
|
/**< KG-Hash-shift as it was configured in the KG-scheme that
|
||
|
* leads to this hash-table.
|
||
|
*/
|
||
|
uint16_t hash_res_mask;
|
||
|
/**< Mask that will be used on the hash-result; The
|
||
|
* number-of-sets for this hash will be calculated as (2^(number
|
||
|
* of bits set in 'hash_res_mask')); The 4 lower bits must be
|
||
|
* cleared.
|
||
|
*/
|
||
|
uint8_t hash_shift;
|
||
|
/**< Byte offset from the beginning of the KeyGen hash result to
|
||
|
* the 2-bytes to be used as hash index.
|
||
|
*/
|
||
|
uint8_t match_key_size;
|
||
|
/**< Size of the exact match keys held by the hash buckets */
|
||
|
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params_for_miss;
|
||
|
/**< Parameters for defining the next engine when a key is not
|
||
|
* matched
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_hash_table_params_t {
|
||
|
struct fm_pcd_hash_table_params_t param;
|
||
|
void *id;
|
||
|
} ioc_fm_pcd_hash_table_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure with the arguments for the
|
||
|
* fm_pcd_hash_table_add_key ioctl() call
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_hash_table_add_key_params_t {
|
||
|
void *p_hash_tbl;
|
||
|
uint8_t key_size;
|
||
|
ioc_fm_pcd_cc_key_params_t key_params;
|
||
|
} ioc_fm_pcd_hash_table_add_key_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a CC tree group.
|
||
|
*
|
||
|
* This structure defines a CC group in terms of NetEnv units and
|
||
|
* the action to be taken in each case. The unit_ids list must be
|
||
|
* given in order from low to high indices.
|
||
|
* ioc_fm_pcd_cc_next_engine_params_t is a list of
|
||
|
* 2^num_of_distinction_units structures where each defines the
|
||
|
* next action to be taken for each units combination. for
|
||
|
* example: num_of_distinction_units = 2 unit_ids = {1,3}
|
||
|
* next_engine_per_entries_in_grp[0] =
|
||
|
* ioc_fm_pcd_cc_next_engine_params_t for the case that unit 1 -
|
||
|
* not found; unit 3 - not found;
|
||
|
* next_engine_per_entries_in_grp[1] =
|
||
|
* ioc_fm_pcd_cc_next_engine_params_t for the case that unit 1 -
|
||
|
* not found; unit 3 - found;
|
||
|
* next_engine_per_entries_in_grp[2] =
|
||
|
* ioc_fm_pcd_cc_next_engine_params_t for the case that unit 1 -
|
||
|
* found; unit 3 - not found;
|
||
|
* next_engine_per_entries_in_grp[3] =
|
||
|
* ioc_fm_pcd_cc_next_engine_params_t for the case that unit 1 -
|
||
|
* found; unit 3 - found;
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_grp_params_t {
|
||
|
uint8_t num_of_distinction_units; /**< Up to 4 */
|
||
|
uint8_t unit_ids[IOC_FM_PCD_MAX_NUM_OF_CC_UNITS];
|
||
|
/**< Indexes of the units as defined in
|
||
|
* fm_pcd_net_env_characteristics_set()
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_next_engine_params_t
|
||
|
next_engine_per_entries_in_grp[IOC_FM_PCD_MAX_CC_ENTRY_IN_GRP];
|
||
|
/**< Maximum entries per group is 16 */
|
||
|
} ioc_fm_pcd_cc_grp_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining the CC tree groups
|
||
|
* (Must match struct ioc_fm_pcd_cc_tree_params_t defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_tree_params_t {
|
||
|
void *net_env_id;
|
||
|
/**< Id of the Network Environment as returned
|
||
|
* by fm_pcd_net_env_characteristics_set()
|
||
|
*/
|
||
|
uint8_t num_of_groups;
|
||
|
/**< Number of CC groups within the CC tree */
|
||
|
ioc_fm_pcd_cc_grp_params_t
|
||
|
fm_pcd_cc_group_params[IOC_FM_PCD_MAX_NUM_OF_CC_GROUPS];
|
||
|
/**< Parameters for each group. */
|
||
|
void *id;
|
||
|
/**< Output parameter; Returns the tree Id to be used */
|
||
|
} ioc_fm_pcd_cc_tree_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining policer byte rate
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_plcr_byte_rate_mode_param_t {
|
||
|
ioc_fm_pcd_plcr_frame_length_select frame_length_selection;
|
||
|
/**< Frame length selection */
|
||
|
ioc_fm_pcd_plcr_roll_back_frame_select roll_back_frame_selection;
|
||
|
/**< relevant option only e_IOC_FM_PCD_PLCR_L2_FRM_LEN,
|
||
|
* e_IOC_FM_PCD_PLCR_FULL_FRM_LEN
|
||
|
*/
|
||
|
} ioc_fm_pcd_plcr_byte_rate_mode_param_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining the policer profile (based on
|
||
|
* RFC-2698 or RFC-4115 attributes).
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_plcr_non_passthrough_alg_param_t {
|
||
|
ioc_fm_pcd_plcr_rate_mode rate_mode;
|
||
|
/**< Byte / Packet */
|
||
|
ioc_fm_pcd_plcr_byte_rate_mode_param_t byte_mode_param;
|
||
|
/**< Valid for Byte NULL for Packet */
|
||
|
uint32_t committed_info_rate;
|
||
|
/**< KBits/Sec or Packets/Sec */
|
||
|
uint32_t committed_burst_size;
|
||
|
/**< KBits or Packets */
|
||
|
uint32_t peak_or_excess_info_rate;
|
||
|
/**< KBits/Sec or Packets/Sec */
|
||
|
uint32_t peak_or_excess_burst_size;
|
||
|
/**< KBits or Packets */
|
||
|
} ioc_fm_pcd_plcr_non_passthrough_alg_param_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining the next engine after policer
|
||
|
*/
|
||
|
typedef union ioc_fm_pcd_plcr_next_engine_params_u {
|
||
|
ioc_fm_pcd_done_action action;
|
||
|
/**< Action - when next engine is BMI (done) */
|
||
|
void *p_profile;
|
||
|
/**< Policer profile handle - used when next
|
||
|
* engine is PLCR, must be a SHARED profile
|
||
|
*/
|
||
|
void *p_direct_scheme;
|
||
|
/**< Direct scheme select - when next engine is
|
||
|
* Keygen
|
||
|
*/
|
||
|
} ioc_fm_pcd_plcr_next_engine_params_u;
|
||
|
|
||
|
typedef struct ioc_fm_pcd_port_params_t {
|
||
|
ioc_fm_port_type port_type;
|
||
|
/**< Type of port for this profile */
|
||
|
uint8_t port_id;
|
||
|
/**< FM-Port id of port for this profile */
|
||
|
} ioc_fm_pcd_port_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining the policer profile entry
|
||
|
* (Must match struct ioc_fm_pcd_plcr_profile_params_t defined in
|
||
|
* fm_pcd_ext.h)
|
||
|
*/
|
||
|
struct fm_pcd_plcr_profile_params_t {
|
||
|
bool modify;
|
||
|
/**< TRUE to change an existing profile */
|
||
|
union {
|
||
|
struct {
|
||
|
ioc_fm_pcd_profile_type_selection profile_type;
|
||
|
/**< Type of policer profile */
|
||
|
ioc_fm_pcd_port_params_t *p_fm_port;
|
||
|
/**< Relevant for per-port profiles only */
|
||
|
uint16_t relative_profile_id;
|
||
|
/**< Profile id - relative to shared group or to
|
||
|
* port
|
||
|
*/
|
||
|
} new_params;
|
||
|
/**< Use it when modify = FALSE */
|
||
|
void *p_profile;
|
||
|
/**< A handle to a profile - use it when modify=TRUE */
|
||
|
} profile_select;
|
||
|
ioc_fm_pcd_plcr_algorithm_selection alg_selection;
|
||
|
/**< Profile Algorithm PASS_THROUGH, RFC_2698, RFC_4115 */
|
||
|
ioc_fm_pcd_plcr_color_mode color_mode;
|
||
|
/**< COLOR_BLIND, COLOR_AWARE */
|
||
|
|
||
|
union {
|
||
|
ioc_fm_pcd_plcr_color dflt_color;
|
||
|
/**< For Color-Blind Pass-Through mode; the policer will
|
||
|
* re-color any incoming packet with the default value.
|
||
|
*/
|
||
|
ioc_fm_pcd_plcr_color override;
|
||
|
/**< For Color-Aware modes; the profile response to a pre-color
|
||
|
* value of 2'b11.
|
||
|
*/
|
||
|
} color;
|
||
|
|
||
|
ioc_fm_pcd_plcr_non_passthrough_alg_param_t
|
||
|
non_passthrough_alg_param;
|
||
|
/**< RFC2698 or RFC4115 parameters */
|
||
|
|
||
|
ioc_fm_pcd_engine next_engine_on_green;
|
||
|
/**< Next engine for green-colored frames */
|
||
|
ioc_fm_pcd_plcr_next_engine_params_u params_on_green;
|
||
|
/**< Next engine parameters for green-colored frames */
|
||
|
|
||
|
ioc_fm_pcd_engine next_engine_on_yellow;
|
||
|
/**< Next engine for yellow-colored frames */
|
||
|
ioc_fm_pcd_plcr_next_engine_params_u params_on_yellow;
|
||
|
/**< Next engine parameters for yellow-colored frames */
|
||
|
|
||
|
ioc_fm_pcd_engine next_engine_on_red;
|
||
|
/**< Next engine for red-colored frames */
|
||
|
ioc_fm_pcd_plcr_next_engine_params_u params_on_red;
|
||
|
/**< Next engine parameters for red-colored frames */
|
||
|
|
||
|
bool trap_profile_on_flow_A;
|
||
|
/**< Obsolete - do not use */
|
||
|
bool trap_profile_on_flow_B;
|
||
|
/**< Obsolete - do not use */
|
||
|
bool trap_profile_on_flow_C;
|
||
|
/**< Obsolete - do not use */
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_plcr_profile_params_t {
|
||
|
struct fm_pcd_plcr_profile_params_t param;
|
||
|
void *id;
|
||
|
/**< output parameter; Returns the profile Id to be used */
|
||
|
} ioc_fm_pcd_plcr_profile_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for modifying CC tree next engine
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_tree_modify_next_engine_params_t {
|
||
|
void *id;
|
||
|
/**< CC tree Id to be used */
|
||
|
uint8_t grp_indx;
|
||
|
/**< A Group index in the tree */
|
||
|
uint8_t indx;
|
||
|
/**< Entry index in the group defined by grp_index */
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params;
|
||
|
/**< Parameters for the next for the defined Key in the
|
||
|
* p_key
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_tree_modify_next_engine_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for modifying CC node next engine
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_node_modify_next_engine_params_t {
|
||
|
void *id;
|
||
|
/**< CC node Id to be used */
|
||
|
uint16_t key_indx;
|
||
|
/**< Key index for Next Engine Params modifications;
|
||
|
* NOTE: This parameter is IGNORED for miss-key!
|
||
|
*/
|
||
|
uint8_t key_size;
|
||
|
/**< Key size of added key */
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params;
|
||
|
/**< parameters for the next for the defined Key in the
|
||
|
* p_key
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_node_modify_next_engine_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for remove CC node key
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_node_remove_key_params_t {
|
||
|
void *id;
|
||
|
/**< CC node Id to be used */
|
||
|
uint16_t key_indx;
|
||
|
/**< Key index for Next Engine Params modifications;
|
||
|
* NOTE: This parameter is IGNORED for miss-key!
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_node_remove_key_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for modifying CC node key and next engine
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t {
|
||
|
void *id;
|
||
|
/**< CC node Id to be used */
|
||
|
uint16_t key_indx;
|
||
|
/**< Key index for Next Engine Params modifications;
|
||
|
* NOTE: This parameter is IGNORED for miss-key!
|
||
|
*/
|
||
|
uint8_t key_size;
|
||
|
/**< Key size of added key */
|
||
|
ioc_fm_pcd_cc_key_params_t key_params;
|
||
|
/**< it's array with num_of_keys entries each entry in
|
||
|
* the array of the type ioc_fm_pcd_cc_key_params_t
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure for modifying CC node key
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_cc_node_modify_key_params_t {
|
||
|
void *id;
|
||
|
/**< CC node Id to be used */
|
||
|
uint16_t key_indx;
|
||
|
/**< Key index for Next Engine Params modifications;
|
||
|
* NOTE: This parameter is IGNORED for miss-key!
|
||
|
*/
|
||
|
uint8_t key_size;
|
||
|
/**< Key size of added key */
|
||
|
uint8_t *p_key;
|
||
|
/**< Pointer to the key of the size defined in key_size
|
||
|
*/
|
||
|
uint8_t *p_mask;
|
||
|
/**< Pointer to the Mask per key of the size defined in
|
||
|
* key_size. p_key and p_mask (if defined) have to be of
|
||
|
* the same size as defined in the key_size
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_node_modify_key_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description A structure with the arguments for the
|
||
|
* fm_pcd_hash_table_remove_key ioctl() call
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_hash_table_remove_key_params_t {
|
||
|
void *p_hash_tbl; /**< The id of the hash table */
|
||
|
uint8_t key_size; /**< The size of the key to remove */
|
||
|
uint8_t *p_key; /**< Pointer to the key to remove */
|
||
|
} ioc_fm_pcd_hash_table_remove_key_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for selecting a location for requested manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_manip_hdr_info_t {
|
||
|
ioc_net_header_type hdr; /**< Header selection */
|
||
|
ioc_fm_pcd_hdr_index hdr_index;
|
||
|
/**< Relevant only for MPLS, VLAN and tunneled IP.
|
||
|
* Otherwise should be cleared.
|
||
|
*/
|
||
|
bool by_field;
|
||
|
/**< TRUE if the location of manipulation is according
|
||
|
* to some field in the specific header
|
||
|
*/
|
||
|
ioc_fm_pcd_fields_u full_field;
|
||
|
/**< Relevant only when by_field = TRUE: Extract field
|
||
|
*/
|
||
|
} ioc_fm_manip_hdr_info_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header removal by header type
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_rmv_by_hdr_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_rmv_by_hdr_type type;
|
||
|
/**< Selection of header removal location */
|
||
|
union {
|
||
|
ioc_fm_manip_hdr_info_t hdr_info;
|
||
|
/**< Relevant when type = e_FM_PCD_MANIP_RMV_BY_HDR_FROM_START
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_rmv_specific_l2 specific_l2;
|
||
|
/**< Relevant when type = e_IOC_FM_PCD_MANIP_BY_HDR_SPECIFIC_L2;
|
||
|
* Defines which L2 headers to remove.
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_by_hdr_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for configuring IP fragmentation manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_ip_params_t {
|
||
|
uint16_t size_for_fragmentation;
|
||
|
/**< If length of the frame is greater than this value, IP
|
||
|
* fragmentation will be executed.
|
||
|
*/
|
||
|
bool sg_bpid_en;
|
||
|
/**< Enable a dedicated buffer pool id for the Scatter/Gather
|
||
|
* buffer allocation; If disabled, the Scatter/Gather buffer
|
||
|
* will be allocated from the same pool as the received frame's
|
||
|
* buffer.
|
||
|
*/
|
||
|
uint8_t sg_bpid;
|
||
|
/**< Scatter/Gather buffer pool id; This parameter is relevant
|
||
|
* when 'sg_bpid_en=TRUE'; Same LIODN number is used for these
|
||
|
* buffers as for the received frames buffers, so buffers of
|
||
|
* this pool need to be allocated in the same memory area as the
|
||
|
* received buffers. If the received buffers arrive from
|
||
|
* different sources, the Scatter/Gather BP id should be mutual
|
||
|
* to all these sources.
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_donot_frag_action donot_frag_action;
|
||
|
/**< Don't Fragment Action - If an IP packet is larger than MTU
|
||
|
* and its DF bit is set, then this field will determine the
|
||
|
* action to be taken.
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_frag_ip_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for configuring IP reassembly manipulation.
|
||
|
*
|
||
|
* This is a common structure for both IPv4 and IPv6 reassembly
|
||
|
* manipulation. For reassembly of both IPv4 and IPv6, make sure
|
||
|
* to set the 'hdr' field in ioc_fm_pcd_manip_reassem_params_t to
|
||
|
* IOC_header_type_ipv_6.
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_ip_params_t {
|
||
|
uint8_t relative_scheme_id[2];
|
||
|
/**< Partition relative scheme id: relativeSchemeId[0] -
|
||
|
* Relative scheme ID for IPV4 Reassembly manipulation;
|
||
|
* relativeSchemeId[1] - Relative scheme ID for IPV6
|
||
|
* Reassembly manipulation; NOTE: The following comment
|
||
|
* is relevant only for FMAN v2 devices: Relative scheme
|
||
|
* ID for IPv4/IPv6 Reassembly manipulation must be
|
||
|
* smaller than the user schemes id to ensure that the
|
||
|
* reassembly's schemes will be first match. The
|
||
|
* remaining schemes, if defined, should have higher
|
||
|
* relative scheme ID.
|
||
|
*/
|
||
|
uint32_t non_consistent_sp_fqid;
|
||
|
/**< In case that other fragments of the frame
|
||
|
* corresponds to different storage profile than the
|
||
|
* opening fragment (Non-Consistent-SP state) then one
|
||
|
* of two possible scenarios occurs: if
|
||
|
* 'nonConsistentSpFqid != 0', the reassembled frame
|
||
|
* will be enqueued to this fqid, otherwise a 'Non
|
||
|
* Consistent SP' bit will be set in the FD[status].
|
||
|
*/
|
||
|
uint8_t data_mem_id;
|
||
|
/**< Memory partition ID for the IPR's external tables
|
||
|
* structure
|
||
|
*/
|
||
|
uint16_t data_liodn_offset;
|
||
|
/**< LIODN offset for access the IPR's external tables
|
||
|
* structure.
|
||
|
*/
|
||
|
uint16_t min_frag_size[2];
|
||
|
/**< Minimum fragment size: minFragSize[0] - for ipv4,
|
||
|
* minFragSize[1] - for ipv6
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_reassem_ways_number num_of_frames_per_hash_entry[2];
|
||
|
/**< Number of frames per hash entry needed for
|
||
|
* reassembly process: num_of_frames_per_hash_entry[0] -
|
||
|
* for ipv4 (max value is
|
||
|
* e_IOC_FM_PCD_MANIP_EIGHT_WAYS_HASH);
|
||
|
* num_of_frames_per_hash_entry[1] - for ipv6 (max value
|
||
|
* is e_IOC_FM_PCD_MANIP_SIX_WAYS_HASH).
|
||
|
*/
|
||
|
uint16_t max_num_frames_in_process;
|
||
|
/**< Number of frames which can be processed by
|
||
|
* Reassembly in the same time; Must be power of 2; In
|
||
|
* the case num_of_frames_per_hash_entry ==
|
||
|
* e_IOC_FM_PCD_MANIP_FOUR_WAYS_HASH,
|
||
|
* max_num_frames_in_process has to be in the range of
|
||
|
* 4 - 512; In the case num_of_frames_per_hash_entry ==
|
||
|
* e_IOC_FM_PCD_MANIP_EIGHT_WAYS_HASH,
|
||
|
* max_num_frames_in_process has to be in the range of
|
||
|
* 8 - 2048.
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_reassem_time_out_mode time_out_mode;
|
||
|
/**< Expiration delay initialized by Reassembly process
|
||
|
*/
|
||
|
uint32_t fqid_for_time_out_frames;
|
||
|
/**< FQID in which time out frames will enqueue during
|
||
|
* Time Out Process
|
||
|
*/
|
||
|
uint32_t timeout_threshold_for_reassm_process;
|
||
|
/**< Represents the time interval in microseconds which
|
||
|
* defines if opened frame (at least one fragment was
|
||
|
* processed but not all the fragments)is found as too
|
||
|
* old
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_reassem_ip_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining IPSEC manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_special_offload_ipsec_params_t {
|
||
|
bool decryption;
|
||
|
/**< TRUE if being used in decryption direction;
|
||
|
* FALSE if being used in encryption direction.
|
||
|
*/
|
||
|
bool ecn_copy;
|
||
|
/**< TRUE to copy the ECN bits from inner/outer to
|
||
|
* outer/inner (direction depends on the 'decryption'
|
||
|
* field).
|
||
|
*/
|
||
|
bool dscp_copy;
|
||
|
/**< TRUE to copy the DSCP bits from inner/outer to
|
||
|
* outer/inner (direction depends on the 'decryption'
|
||
|
* field).
|
||
|
*/
|
||
|
bool variable_ip_hdr_len;
|
||
|
/**< TRUE for supporting variable IP header length in
|
||
|
* decryption.
|
||
|
*/
|
||
|
bool variable_ip_version;
|
||
|
/**< TRUE for supporting both IP version on the same SA
|
||
|
* in encryption
|
||
|
*/
|
||
|
uint8_t outer_ip_hdr_len;
|
||
|
/**< If 'variable_ip_version == TRUE' than this field
|
||
|
* must be set to non-zero value; It is specifies the
|
||
|
* length of the outer IP header that was configured in
|
||
|
* the corresponding SA.
|
||
|
*/
|
||
|
uint16_t arw_size;
|
||
|
/**< if <> '0' then will perform ARW check for this SA;
|
||
|
* The value must be a multiplication of 16
|
||
|
*/
|
||
|
void *arw_addr;
|
||
|
/**< if arwSize <> '0' then this field must be set to
|
||
|
* non-zero value; MUST be allocated from FMAN's MURAM
|
||
|
* that the post-sec op-port belong Must be 4B aligned.
|
||
|
* Required MURAM size is
|
||
|
* '(NEXT_POWER_OF_2(arwSize+32))/8+4' Bytes
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_special_offload_ipsec_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for configuring CAPWAP fragmentation manipulation
|
||
|
*
|
||
|
* Restrictions:
|
||
|
* - Maximum number of fragments per frame is 16.
|
||
|
* - Transmit confirmation is not supported.
|
||
|
* - Fragmentation nodes must be set as the last PCD action (i.e.
|
||
|
* the corresponding CC node key must have next engine set to
|
||
|
* e_FM_PCD_DONE).
|
||
|
* - Only BMan buffers shall be used for frames to be fragmented.
|
||
|
* - NOTE: The following comment is relevant only for FMAN v3
|
||
|
* devices: IPF does not support VSP. Therefore, on the same
|
||
|
* port where we have IPF we cannot support VSP.
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_capwap_params_t {
|
||
|
uint16_t size_for_fragmentation;
|
||
|
/**< If length of the frame is greater than this value,
|
||
|
* CAPWAP fragmentation will be executed.
|
||
|
*/
|
||
|
bool sg_bpid_en;
|
||
|
/**< Enable a dedicated buffer pool id for the
|
||
|
* Scatter/Gather buffer allocation; If disabled, the
|
||
|
* Scatter/Gather buffer will be allocated from the same
|
||
|
* pool as the received frame's buffer.
|
||
|
*/
|
||
|
uint8_t sg_bpid;
|
||
|
/**< Scatter/Gather buffer pool id; This parameters is
|
||
|
* relevant when 'sg_bpidEn=TRUE'; Same LIODN number is
|
||
|
* used for these buffers as for the received frames
|
||
|
* buffers, so buffers of this pool need to be allocated
|
||
|
* in the same memory area as the received buffers. If
|
||
|
* the received buffers arrive from different sources,
|
||
|
* the Scatter/Gather BP id should be mutual to all
|
||
|
* these sources.
|
||
|
*/
|
||
|
bool compress_mode_en;
|
||
|
/**< CAPWAP Header Options Compress Enable mode; When
|
||
|
* this mode is enabled then only the first fragment
|
||
|
* include the CAPWAP header options field (if user
|
||
|
* provides it in the input frame) and all other
|
||
|
* fragments exclude the CAPWAP options field (CAPWAP
|
||
|
* header is updated accordingly).
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_frag_capwap_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for configuring CAPWAP reassembly manipulation.
|
||
|
*
|
||
|
* Restrictions:
|
||
|
* - Application must define one scheme to catch the reassembled
|
||
|
* frames.
|
||
|
* - Maximum number of fragments per frame is 16.
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_capwap_params_t {
|
||
|
uint8_t relative_scheme_id;
|
||
|
/**< Partition relative scheme id; NOTE: this id must be
|
||
|
* smaller than the user schemes id to ensure that the
|
||
|
* reassembly scheme will be first match; Rest schemes,
|
||
|
* if defined, should have higher relative scheme ID.
|
||
|
*/
|
||
|
uint8_t data_mem_id;
|
||
|
/**< Memory partition ID for the IPR's external tables
|
||
|
* structure
|
||
|
*/
|
||
|
uint16_t data_liodn_offset;
|
||
|
/**< LIODN offset for access the IPR's external tables
|
||
|
* structure.
|
||
|
*/
|
||
|
uint16_t max_reassembled_frame_length;
|
||
|
/**< The maximum CAPWAP reassembled frame length in
|
||
|
* bytes; If maxReassembledFrameLength == 0, any
|
||
|
* successful reassembled frame length is considered as
|
||
|
* a valid length; if maxReassembledFrameLength > 0, a
|
||
|
* successful reassembled frame which its length exceeds
|
||
|
* this value is considered as an error frame (FD
|
||
|
* status[CRE] bit is set).
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_reassem_ways_number num_of_frames_per_hash_entry;
|
||
|
/**< Number of frames per hash entry needed for
|
||
|
* reassembly process
|
||
|
*/
|
||
|
uint16_t max_num_frames_in_process;
|
||
|
/**< Number of frames which can be processed by
|
||
|
* reassembly in the same time; Must be power of 2; In
|
||
|
* the case num_of_frames_per_hash_entry ==
|
||
|
* e_FM_PCD_MANIP_FOUR_WAYS_HASH,
|
||
|
* max_num_frames_in_process has to be in the range of
|
||
|
* 4 - 512; In the case num_of_frames_per_hash_entry ==
|
||
|
* e_FM_PCD_MANIP_EIGHT_WAYS_HASH,
|
||
|
* max_num_frames_in_process has to be in the range of
|
||
|
* 8 - 2048.
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_reassem_time_out_mode time_out_mode;
|
||
|
/**< Expiration delay initialized by Reassembly process
|
||
|
*/
|
||
|
uint32_t fqid_for_time_out_frames;
|
||
|
/**< FQID in which time out frames will enqueue during
|
||
|
* Time Out Process; Recommended value for this field is
|
||
|
* 0; in this way timed-out frames will be discarded
|
||
|
*/
|
||
|
uint32_t timeout_threshold_for_reassm_process;
|
||
|
/**< Represents the time interval in microseconds which
|
||
|
* defines if opened frame (at least one fragment was
|
||
|
* processed but not all the fragments)is found as too
|
||
|
* old
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_reassem_capwap_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for defining CAPWAP manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_special_offload_capwap_params_t {
|
||
|
bool dtls;
|
||
|
/**< TRUE if continue to SEC DTLS encryption */
|
||
|
ioc_fm_pcd_manip_hdr_qos_src qos_src;
|
||
|
/**< TODO */
|
||
|
} ioc_fm_pcd_manip_special_offload_capwap_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining special offload manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_special_offload_params_t {
|
||
|
ioc_fm_pcd_manip_special_offload_type type;
|
||
|
/**< Type of special offload manipulation */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_special_offload_ipsec_params_t ipsec;
|
||
|
/**< Parameters for IPSec; Relevant when type =
|
||
|
* e_IOC_FM_PCD_MANIP_SPECIAL_OFFLOAD_IPSEC
|
||
|
*/
|
||
|
|
||
|
ioc_fm_pcd_manip_special_offload_capwap_params_t capwap;
|
||
|
/**< Parameters for CAPWAP; Relevant when type =
|
||
|
* e_FM_PCD_MANIP_SPECIAL_OFFLOAD_CAPWAP
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_special_offload_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining generic removal manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_rmv_generic_params_t {
|
||
|
uint8_t offset;
|
||
|
/**< Offset from beginning of header to the start location of
|
||
|
* the removal
|
||
|
*/
|
||
|
uint8_t size; /**< Size of removed section */
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_generic_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining insertion manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_t {
|
||
|
uint8_t size; /**< size of inserted section */
|
||
|
uint8_t *p_data; /**< data to be inserted */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining generic insertion manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_generic_params_t {
|
||
|
uint8_t offset;
|
||
|
/**< Offset from beginning of header to the start
|
||
|
* location of the insertion
|
||
|
*/
|
||
|
uint8_t size; /**< Size of inserted section */
|
||
|
bool replace;
|
||
|
/**< TRUE to override (replace) existing data at
|
||
|
* 'offset', FALSE to insert
|
||
|
*/
|
||
|
uint8_t *p_data;
|
||
|
/**< Pointer to data to be inserted */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_generic_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation VLAN DSCP To Vpri
|
||
|
* translation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_vlan_dscp_to_vpri_t {
|
||
|
uint8_t dscp_to_vpri_table[IOC_FM_PCD_MANIP_DSCP_TO_VLAN_TRANS];
|
||
|
/**< A table of VPri values for each DSCP value; The index is
|
||
|
* the D_SCP value (0-0x3F) and the value is the corresponding
|
||
|
* VPRI (0-15).
|
||
|
*/
|
||
|
uint8_t vpri_def_val;
|
||
|
/**< 0-7, Relevant only if update_type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_DSCP_TO_VLAN, this field
|
||
|
* is the Q Tag default value if the IP header is not found.
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_vlan_dscp_to_vpri_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation VLAN fields
|
||
|
* updates
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_vlan_t {
|
||
|
ioc_fm_pcd_manip_hdr_field_update_vlan update_type;
|
||
|
/**< Selects VLAN update type */
|
||
|
union {
|
||
|
uint8_t vpri;
|
||
|
/**< 0-7, Relevant only if If update_type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_VLAN_PRI, this is the new
|
||
|
* VLAN pri.
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_field_update_vlan_dscp_to_vpri_t dscp_to_vpri;
|
||
|
/**< Parameters structure, Relevant only if update_type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_DSCP_TO_VLAN.
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_vlan_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation IPV4 fields
|
||
|
* updates
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_ipv4_t {
|
||
|
ioc_ipv4_hdr_manip_update_flags_t valid_updates;
|
||
|
/**< ORed flag, selecting the required updates */
|
||
|
uint8_t tos;
|
||
|
/**< 8 bit New TOS; Relevant if valid_updates contains
|
||
|
* IOC_HDR_MANIP_IPV4_TOS
|
||
|
*/
|
||
|
uint16_t id;
|
||
|
/**< 16 bit New IP ID; Relevant only if
|
||
|
* valid_updates contains IOC_HDR_MANIP_IPV4_ID
|
||
|
*/
|
||
|
uint32_t src;
|
||
|
/**< 32 bit New IP SRC; Relevant only if
|
||
|
* valid_updates contains IOC_HDR_MANIP_IPV4_SRC
|
||
|
*/
|
||
|
uint32_t dst;
|
||
|
/**< 32 bit New IP DST; Relevant only if
|
||
|
* valid_updates contains IOC_HDR_MANIP_IPV4_DST
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_ipv4_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation IPV6 fields
|
||
|
* updates
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_ipv6_t {
|
||
|
ioc_ipv6_hdr_manip_update_flags_t valid_updates;
|
||
|
/**< ORed flag, selecting the required updates */
|
||
|
uint8_t traffic_class;
|
||
|
/**< 8 bit New Traffic Class; Relevant if valid_updates
|
||
|
* contains IOC_HDR_MANIP_IPV6_TC
|
||
|
*/
|
||
|
uint8_t src[ioc_net_hf_ipv6_addr_size];
|
||
|
/**< 16 byte new IP SRC; Relevant only if valid_updates
|
||
|
* contains IOC_HDR_MANIP_IPV6_SRC
|
||
|
*/
|
||
|
uint8_t dst[ioc_net_hf_ipv6_addr_size];
|
||
|
/**< 16 byte new IP DST; Relevant only if valid_updates
|
||
|
* contains IOC_HDR_MANIP_IPV6_DST
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_ipv6_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation TCP/UDP fields
|
||
|
* updates
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_tcp_udp_t {
|
||
|
ioc_tcp_udp_hdr_manip_update_flags_t valid_updates;
|
||
|
/**< ORed flag, selecting the required updates */
|
||
|
uint16_t src;
|
||
|
/**< 16 bit New TCP/UDP SRC; Relevant only if
|
||
|
* valid_updates contains IOC_HDR_MANIP_TCP_UDP_SRC
|
||
|
*/
|
||
|
uint16_t dst;
|
||
|
/**< 16 bit New TCP/UDP DST; Relevant only if
|
||
|
* valid_updates contains IOC_HDR_MANIP_TCP_UDP_DST
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_tcp_udp_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation fields updates
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_field_update_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_field_update_type type;
|
||
|
/**< Type of header field update manipulation */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_field_update_vlan_t vlan;
|
||
|
/**< Parameters for VLAN update. Relevant when type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_VLAN
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_field_update_ipv4_t ipv4;
|
||
|
/**< Parameters for IPv4 update. Relevant when type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_IPV4
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_field_update_ipv6_t ipv6;
|
||
|
/**< Parameters for IPv6 update. Relevant when type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_IPV6
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_field_update_tcp_udp_t tcp_udp;
|
||
|
/**< Parameters for TCP/UDP update. Relevant when type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_FIELD_UPDATE_TCP_UDP
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_field_update_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining custom header manipulation for IP
|
||
|
* replacement
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_custom_ip_hdr_replace_t {
|
||
|
ioc_fm_pcd_manip_hdr_custom_ip_replace replace_type;
|
||
|
/**< Selects replace update type */
|
||
|
bool dec_ttl_hl;
|
||
|
/**< Decrement TTL (IPV4) or Hop limit (IPV6) by 1 */
|
||
|
bool update_ipv4_id;
|
||
|
/**< Relevant when replace_type =
|
||
|
* e_IOC_FM_PCD_MANIP_HDR_CUSTOM_REPLACE_IPV6_BY_IPV4
|
||
|
*/
|
||
|
uint16_t id;
|
||
|
/**< 16 bit New IP ID; Relevant only if update_ipv4_id = TRUE */
|
||
|
uint8_t hdr_size;
|
||
|
/**< The size of the new IP header */
|
||
|
uint8_t hdr[IOC_FM_PCD_MANIP_MAX_HDR_SIZE];
|
||
|
/**< The new IP header */
|
||
|
} ioc_fm_pcd_manip_hdr_custom_ip_hdr_replace_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining custom header manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_custom_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_custom_type type;
|
||
|
/**< Type of header field update manipulation */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_custom_ip_hdr_replace_t ip_hdr_replace;
|
||
|
/**< Parameters IP header replacement */
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_custom_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining specific L2 insertion manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_specific_l2_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_insrt_specific_l2 specific_l2;
|
||
|
/**< Selects which L2 headers to insert */
|
||
|
bool update;
|
||
|
/**< TRUE to update MPLS header */
|
||
|
uint8_t size;
|
||
|
/**< size of inserted section */
|
||
|
uint8_t *p_data;
|
||
|
/**< data to be inserted */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_specific_l2_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining IP insertion manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_ip_params_t {
|
||
|
bool calc_l4_checksum;
|
||
|
/**< Calculate L4 checksum. */
|
||
|
ioc_fm_pcd_manip_hdr_qos_mapping_mode mapping_mode;
|
||
|
/**< TODO */
|
||
|
uint8_t last_pid_offset;
|
||
|
/**< the offset of the last Protocol within the inserted
|
||
|
* header
|
||
|
*/
|
||
|
uint16_t id; /**< 16 bit New IP ID */
|
||
|
bool donot_frag_overwrite;
|
||
|
/**< IPv4 only. DF is overwritten with the hash-result
|
||
|
* next-to-last byte. This byte is configured to be
|
||
|
* overwritten when RPD is set.
|
||
|
*/
|
||
|
uint8_t last_dst_offset;
|
||
|
/**< IPv6 only. if routing extension exist, user should
|
||
|
* set the offset of the destination address in order
|
||
|
* to calculate UDP checksum pseudo header; Otherwise
|
||
|
* set it to '0'.
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_insrt_t insrt;
|
||
|
/**< size and data to be inserted. */
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_ip_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header insertion manipulation by
|
||
|
* header type
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_by_hdr_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_insrt_by_hdr_type type;
|
||
|
/**< Selects manipulation type */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_insrt_specific_l2_params_t specific_l2_params;
|
||
|
/**< Used when type =
|
||
|
* e_IOC_FM_PCD_MANIP_INSRT_BY_HDR_SPECIFIC_L2: Selects
|
||
|
* which L2 headers to remove
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_insrt_ip_params_t ip_params;
|
||
|
/**< Used when type = e_FM_PCD_MANIP_INSRT_BY_HDR_IP */
|
||
|
ioc_fm_pcd_manip_hdr_insrt_t insrt;
|
||
|
/**< Used when type is one of
|
||
|
* e_FM_PCD_MANIP_INSRT_BY_HDR_UDP,
|
||
|
* e_FM_PCD_MANIP_INSRT_BY_HDR_UDP_LITE, or
|
||
|
* e_FM_PCD_MANIP_INSRT_BY_HDR_CAPWAP
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_by_hdr_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header insertion manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_insrt_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_insrt_type type;
|
||
|
/**< Type of insertion manipulation */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_insrt_by_hdr_params_t by_hdr;
|
||
|
/**< Parameters for defining header insertion
|
||
|
* manipulation by header type, relevant if 'type' =
|
||
|
* e_IOC_FM_PCD_MANIP_INSRT_BY_HDR
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_insrt_generic_params_t generic;
|
||
|
/**< Parameters for defining generic header insertion
|
||
|
* manipulation, relevant if type =
|
||
|
* e_IOC_FM_PCD_MANIP_INSRT_GENERIC
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_insrt_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header removal manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_rmv_params_t {
|
||
|
ioc_fm_pcd_manip_hdr_rmv_type type;
|
||
|
/**< Type of header removal manipulation */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_rmv_by_hdr_params_t by_hdr;
|
||
|
/**< Parameters for defining header removal manipulation
|
||
|
* by header type, relevant if type =
|
||
|
* e_IOC_FM_PCD_MANIP_RMV_BY_HDR
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_hdr_rmv_generic_params_t generic;
|
||
|
/**< Parameters for defining generic header removal
|
||
|
* manipulation, relevant if type =
|
||
|
* e_IOC_FM_PCD_MANIP_RMV_GENERIC
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_hdr_rmv_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining header manipulation node
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_params_t {
|
||
|
bool rmv;
|
||
|
/**< TRUE, to define removal manipulation */
|
||
|
ioc_fm_pcd_manip_hdr_rmv_params_t rmv_params;
|
||
|
/**< Parameters for removal manipulation, relevant if
|
||
|
* 'rmv' = TRUE
|
||
|
*/
|
||
|
|
||
|
bool insrt;
|
||
|
/**< TRUE, to define insertion manipulation */
|
||
|
ioc_fm_pcd_manip_hdr_insrt_params_t insrt_params;
|
||
|
/**< Parameters for insertion manipulation, relevant if
|
||
|
* 'insrt' = TRUE
|
||
|
*/
|
||
|
|
||
|
bool field_update;
|
||
|
/**< TRUE, to define field update manipulation */
|
||
|
ioc_fm_pcd_manip_hdr_field_update_params_t field_update_params;
|
||
|
/**< Parameters for field update manipulation, relevant
|
||
|
* if 'fieldUpdate' = TRUE
|
||
|
*/
|
||
|
|
||
|
bool custom;
|
||
|
/**< TRUE, to define custom manipulation */
|
||
|
ioc_fm_pcd_manip_hdr_custom_params_t custom_params;
|
||
|
/**< Parameters for custom manipulation, relevant if
|
||
|
* 'custom' = TRUE
|
||
|
*/
|
||
|
|
||
|
bool donot_parse_after_manip;
|
||
|
/**< FALSE to activate the parser a second time after
|
||
|
* completing the manipulation on the frame
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for defining fragmentation manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_params_t {
|
||
|
ioc_net_header_type hdr;
|
||
|
/**< Header selection */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_frag_capwap_params_t capwap_frag;
|
||
|
/**< Parameters for defining CAPWAP fragmentation,
|
||
|
* relevant if 'hdr' = HEADER_TYPE_CAPWAP
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_frag_ip_params_t ip_frag;
|
||
|
/**< Parameters for defining IP fragmentation, relevant
|
||
|
* if 'hdr' = HEADER_TYPE_Ipv4 or HEADER_TYPE_Ipv6
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_frag_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for defining reassemble manipulation
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_params_t {
|
||
|
ioc_net_header_type hdr;
|
||
|
/**< Header selection */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_reassem_capwap_params_t capwap_reassem;
|
||
|
/**< Parameters for defining CAPWAP reassembly, relevant
|
||
|
* if 'hdr' = HEADER_TYPE_CAPWAP
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_reassem_ip_params_t ip_reassem;
|
||
|
/**< Parameters for defining IP reassembly, relevant if
|
||
|
* 'hdr' = HEADER_TYPE_Ipv4 or HEADER_TYPE_Ipv6
|
||
|
*/
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_reassem_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining a manipulation node
|
||
|
*/
|
||
|
struct fm_pcd_manip_params_t {
|
||
|
ioc_fm_pcd_manip_type type;
|
||
|
/**< Selects type of manipulation node */
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_hdr_params_t hdr;
|
||
|
/**< Parameters for defining header manipulation node */
|
||
|
ioc_fm_pcd_manip_reassem_params_t reassem;
|
||
|
/**< Parameters for defining reassembly manipulation
|
||
|
* node
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_frag_params_t frag;
|
||
|
/**< Parameters for defining fragmentation manipulation
|
||
|
* node
|
||
|
*/
|
||
|
ioc_fm_pcd_manip_special_offload_params_t special_offload;
|
||
|
/**< Parameters for defining special offload
|
||
|
* manipulation node
|
||
|
*/
|
||
|
} u;
|
||
|
void *p_next_manip;
|
||
|
/**< Handle to another (previously defined) manipulation node;
|
||
|
* Allows concatenation of manipulation actions. This parameter
|
||
|
* is optional and may be NULL.
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_manip_params_t {
|
||
|
struct fm_pcd_manip_params_t param;
|
||
|
void *id;
|
||
|
} ioc_fm_pcd_manip_params_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Structure for retrieving IP reassembly statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_ip_stats_t {
|
||
|
/* common counters for both IPv4 and IPv6 */
|
||
|
uint32_t timeout;
|
||
|
/**< Counts the number of TimeOut occurrences */
|
||
|
uint32_t rfd_pool_busy;
|
||
|
/**< Counts the number of failed attempts to allocate a
|
||
|
* Reassembly Frame Descriptor
|
||
|
*/
|
||
|
uint32_t internal_buffer_busy;
|
||
|
/**< Counts the number of times an internal buffer busy occurred
|
||
|
*/
|
||
|
uint32_t external_buffer_busy;
|
||
|
/**< Counts the number of times external buffer busy occurred */
|
||
|
uint32_t sg_fragments;
|
||
|
/**< Counts the number of Scatter/Gather fragments */
|
||
|
uint32_t dma_semaphore_depletion;
|
||
|
/**< Counts the number of failed attempts to allocate a DMA
|
||
|
* semaphore
|
||
|
*/
|
||
|
uint32_t non_consistent_sp;
|
||
|
/**< Counts the number of Non Consistent Storage Profile events
|
||
|
* for successfully reassembled frames
|
||
|
*/
|
||
|
struct {
|
||
|
uint32_t successfully_reassembled;
|
||
|
/**< Counts the number of successfully reassembled frames */
|
||
|
uint32_t valid_fragments;
|
||
|
/**< Counts the total number of valid fragments that have been
|
||
|
* processed for all frames
|
||
|
*/
|
||
|
uint32_t processed_fragments;
|
||
|
/**< Counts the number of processed fragments (valid and error
|
||
|
* fragments) for all frames
|
||
|
*/
|
||
|
uint32_t malformed_fragments;
|
||
|
/**< Counts the number of malformed fragments processed for all
|
||
|
* frames
|
||
|
*/
|
||
|
uint32_t discarded_fragments;
|
||
|
/**< Counts the number of fragments discarded by the reassembly
|
||
|
* process
|
||
|
*/
|
||
|
uint32_t auto_learn_busy;
|
||
|
/**< Counts the number of times a busy condition occurs when
|
||
|
* attempting to access an IP-Reassembly Automatic Learning Hash
|
||
|
* set
|
||
|
*/
|
||
|
uint32_t more_than16fragments;
|
||
|
/**< Counts the fragment occurrences in which the number of
|
||
|
* fragments-per-frame exceeds 16
|
||
|
*/
|
||
|
} specific_hdr_statistics[2];
|
||
|
/**< slot '0' is for IPv4, slot '1' is for IPv6 */
|
||
|
} ioc_fm_pcd_manip_reassem_ip_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Structure for retrieving IP fragmentation statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_ip_stats_t {
|
||
|
uint32_t total_frames;
|
||
|
/**< Number of frames that passed through the
|
||
|
* manipulation node
|
||
|
*/
|
||
|
uint32_t fragmented_frames;
|
||
|
/**< Number of frames that were fragmented */
|
||
|
uint32_t generated_fragments;
|
||
|
/**< Number of fragments that were generated */
|
||
|
} ioc_fm_pcd_manip_frag_ip_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Structure for retrieving CAPWAP reassembly statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_capwap_stats_t {
|
||
|
uint32_t timeout;
|
||
|
/**< Counts the number of timeout occurrences */
|
||
|
uint32_t rfd_pool_busy;
|
||
|
/**< Counts the number of failed attempts to allocate a
|
||
|
* Reassembly Frame Descriptor
|
||
|
*/
|
||
|
uint32_t internal_buffer_busy;
|
||
|
/**< Counts the number of times an internal buffer busy
|
||
|
* occurred
|
||
|
*/
|
||
|
uint32_t external_buffer_busy;
|
||
|
/**< Counts the number of times external buffer busy
|
||
|
* occurred
|
||
|
*/
|
||
|
uint32_t sg_fragments;
|
||
|
/**< Counts the number of Scatter/Gather fragments */
|
||
|
uint32_t dma_semaphore_depletion;
|
||
|
/**< Counts the number of failed attempts to allocate a
|
||
|
* DMA semaphore
|
||
|
*/
|
||
|
uint32_t successfully_reassembled;
|
||
|
/**< Counts the number of successfully reassembled
|
||
|
* frames
|
||
|
*/
|
||
|
uint32_t valid_fragments;
|
||
|
/**< Counts the total number of valid fragments that
|
||
|
* have been processed for all frames
|
||
|
*/
|
||
|
uint32_t processed_fragments;
|
||
|
/**< Counts the number of processed fragments (valid and
|
||
|
* error fragments) for all frames
|
||
|
*/
|
||
|
uint32_t malformed_fragments;
|
||
|
/**< Counts the number of malformed fragments processed
|
||
|
* for all frames
|
||
|
*/
|
||
|
uint32_t auto_learn_busy;
|
||
|
/**< Counts the number of times a busy condition occurs
|
||
|
* when attempting to access an Reassembly Automatic
|
||
|
* Learning Hash set
|
||
|
*/
|
||
|
uint32_t discarded_fragments;
|
||
|
/**< Counts the number of fragments discarded by the
|
||
|
* reassembly process
|
||
|
*/
|
||
|
uint32_t more_than16fragments;
|
||
|
/**< Counts the fragment occurrences in which the number
|
||
|
* of fragments-per-frame exceeds 16
|
||
|
*/
|
||
|
uint32_t exceed_max_reassembly_frame_len;
|
||
|
/**< ounts the number of times that a successful
|
||
|
* reassembled frame length exceeds
|
||
|
* MaxReassembledFrameLength value
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_reassem_capwap_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Structure for retrieving CAPWAP fragmentation statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_capwap_stats_t {
|
||
|
uint32_t total_frames;
|
||
|
/**< Number of frames that passed through the
|
||
|
* manipulation node
|
||
|
*/
|
||
|
uint32_t fragmented_frames;
|
||
|
/**< Number of frames that were fragmented */
|
||
|
uint32_t generated_fragments;
|
||
|
/**< Number of fragments that were generated */
|
||
|
#if (defined(DEBUG_ERRORS) && (DEBUG_ERRORS > 0))
|
||
|
uint8_t sg_allocation_failure;
|
||
|
/**< Number of allocation failure of s/g buffers */
|
||
|
#endif /* (defined(DEBUG_ERRORS) && (DEBUG_ERRORS > 0)) */
|
||
|
} ioc_fm_pcd_manip_frag_capwap_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Structure for retrieving reassembly statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_reassem_stats_t {
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_reassem_ip_stats_t ip_reassem;
|
||
|
/**< Structure for IP reassembly statistics */
|
||
|
ioc_fm_pcd_manip_reassem_capwap_stats_t capwap_reassem;
|
||
|
/**< Structure for CAPWAP reassembly statistics */
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_reassem_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for retrieving fragmentation statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_frag_stats_t {
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_frag_ip_stats_t ip_frag;
|
||
|
/**< Structure for IP fragmentation statistics */
|
||
|
ioc_fm_pcd_manip_frag_capwap_stats_t capwap_frag;
|
||
|
/**< Structure for CAPWAP fragmentation statistics */
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_frag_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description structure for defining manipulation statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_stats_t {
|
||
|
union {
|
||
|
ioc_fm_pcd_manip_reassem_stats_t reassem;
|
||
|
/**< Structure for reassembly statistics */
|
||
|
ioc_fm_pcd_manip_frag_stats_t frag;
|
||
|
/**< Structure for fragmentation statistics */
|
||
|
} u;
|
||
|
} ioc_fm_pcd_manip_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for acquiring manipulation statistics
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_get_stats_t {
|
||
|
void *id;
|
||
|
ioc_fm_pcd_manip_stats_t stats;
|
||
|
} ioc_fm_pcd_manip_get_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining frame replicator group and its members
|
||
|
*/
|
||
|
struct fm_pcd_frm_replic_group_params_t {
|
||
|
uint8_t max_num_of_entries;
|
||
|
/**< Maximal number of members in the group -
|
||
|
* must be at least two
|
||
|
*/
|
||
|
uint8_t num_of_entries;
|
||
|
/**< Number of members in the group - must be at
|
||
|
* least 1
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_next_engine_params_t
|
||
|
next_engine_params[IOC_FM_PCD_FRM_REPLIC_MAX_NUM_OF_ENTRIES];
|
||
|
/**< Array of members' parameters */
|
||
|
};
|
||
|
|
||
|
typedef struct ioc_fm_pcd_frm_replic_group_params_t {
|
||
|
struct fm_pcd_frm_replic_group_params_t param;
|
||
|
void *id;
|
||
|
} ioc_fm_pcd_frm_replic_group_params_t;
|
||
|
|
||
|
typedef struct ioc_fm_pcd_frm_replic_member_t {
|
||
|
void *h_replic_group;
|
||
|
uint16_t member_index;
|
||
|
} ioc_fm_pcd_frm_replic_member_t;
|
||
|
|
||
|
typedef struct ioc_fm_pcd_frm_replic_member_params_t {
|
||
|
ioc_fm_pcd_frm_replic_member_t member;
|
||
|
ioc_fm_pcd_cc_next_engine_params_t next_engine_params;
|
||
|
} ioc_fm_pcd_frm_replic_member_params_t;
|
||
|
|
||
|
|
||
|
typedef struct ioc_fm_pcd_cc_key_statistics_t {
|
||
|
uint32_t byte_count;
|
||
|
/**< This counter reflects byte count of frames that
|
||
|
* were matched by this key.
|
||
|
*/
|
||
|
uint32_t frame_count;
|
||
|
/**< This counter reflects count of frames that were
|
||
|
* matched by this key.
|
||
|
*/
|
||
|
uint32_t frame_length_range_count[IOC_FM_PCD_CC_STATS_MAX_FLR];
|
||
|
/**< These counters reflect how many frames matched this
|
||
|
* key in 'RMON' statistics mode: Each counter holds the
|
||
|
* number of frames of a specific frames length range,
|
||
|
* according to the ranges provided at initialization.
|
||
|
*/
|
||
|
} ioc_fm_pcd_cc_key_statistics_t;
|
||
|
|
||
|
|
||
|
typedef struct ioc_fm_pcd_cc_tbl_get_stats_t {
|
||
|
void *id;
|
||
|
uint16_t key_index;
|
||
|
ioc_fm_pcd_cc_key_statistics_t statistics;
|
||
|
} ioc_fm_pcd_cc_tbl_get_stats_t;
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_key_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of
|
||
|
* specific key in a CC Node.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames passed that were
|
||
|
* matched this key; The total frames count will be returned in
|
||
|
* the counter of the first range (as only one frame length range
|
||
|
* was defined). If 'e_FM_PCD_CC_STATS_MODE_RMON' was set for
|
||
|
* this node, the total frame count will be separated to frame
|
||
|
* length counters, based on provided frame length ranges.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding
|
||
|
* @Param[out] p_key_statistics Key statistics counters
|
||
|
*
|
||
|
* @Return The specific key statistics.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_GET_KEY_STAT \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(12), \
|
||
|
ioc_fm_pcd_cc_tbl_get_stats_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_miss_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of miss
|
||
|
* entry in a CC Node.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames were not matched
|
||
|
* to any existing key and therefore passed through the miss
|
||
|
* entry; The total frames count will be returned in the counter
|
||
|
* of the first range (as only one frame length range was
|
||
|
* defined).
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[out] p_miss_statistics Statistics counters for 'miss'
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_GET_MISS_STAT \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(13), \
|
||
|
ioc_fm_pcd_cc_tbl_get_stats_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_get_miss_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of 'miss'
|
||
|
* entry of the a hash table.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames were not matched
|
||
|
* to any existing key and therefore passed through the miss
|
||
|
* entry;
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[out] p_miss_statistics Statistics counters for 'miss'
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_HASH_TABLE_GET_MISS_STAT \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(14), \
|
||
|
ioc_fm_pcd_cc_tbl_get_stats_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_net_env_characteristics_set
|
||
|
*
|
||
|
* @Description Define a set of Network Environment Characteristics.
|
||
|
*
|
||
|
* When setting an environment it is important to understand its
|
||
|
* application. It is not meant to describe the flows that will
|
||
|
* run on the ports using this environment, but what the user
|
||
|
* means TO DO with the PCD mechanisms in order to
|
||
|
* parse-classify-distribute those frames.
|
||
|
* By specifying a distinction unit, the user means it would use
|
||
|
* that option for distinction between frames at either a KeyGen
|
||
|
* scheme or a coarse classification action descriptor. Using
|
||
|
* interchangeable headers to define a unit means that the user
|
||
|
* is indifferent to which of the interchangeable headers is
|
||
|
* present in the frame, and wants the distinction to be based on
|
||
|
* the presence of either one of them.
|
||
|
*
|
||
|
* Depending on context, there are limitations to the use of
|
||
|
* environments. A port using the PCD functionality is bound to
|
||
|
* an environment. Some or even all ports may share an
|
||
|
* environment but also an environment per port is possible. When
|
||
|
* initializing a scheme, a classification plan group (see
|
||
|
* below), or a coarse classification tree, one of the
|
||
|
* initialized environments must be stated and related to. When a
|
||
|
* port is bound to a scheme, a classification plan group, or a
|
||
|
* coarse classification tree, it MUST be bound to the same
|
||
|
* environment.
|
||
|
*
|
||
|
* The different PCD modules, may relate (for flows definition)
|
||
|
* ONLY on distinction units as defined by their environment.
|
||
|
* When initializing a scheme for example, it may not choose to
|
||
|
* select IPV4 as a match for recognizing flows unless it was
|
||
|
* defined in the relating environment. In fact, to guide the
|
||
|
* user through the configuration of the PCD, each module's
|
||
|
* characterization in terms of flows is not done using protocol
|
||
|
* names, but using environment indexes.
|
||
|
*
|
||
|
* In terms of HW implementation, the list of distinction units
|
||
|
* sets the LCV vectors and later used for match vector,
|
||
|
* classification plan vectors and coarse classification
|
||
|
* indexing.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_net_env_params_t A structure defining the
|
||
|
* distinction units for this
|
||
|
* configuration.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_NET_ENV_CHARACTERISTICS_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(20), \
|
||
|
ioc_fm_pcd_net_env_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_net_env_characteristics_delete
|
||
|
*
|
||
|
* @Description Deletes a set of Network Environment Charecteristics.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t The id of a Network Environment object.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_NET_ENV_CHARACTERISTICS_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(21), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_set
|
||
|
*
|
||
|
* @Description Initializing or modifying and enabling a scheme for the
|
||
|
* KeyGen. This routine should be called for adding or modifying
|
||
|
* a scheme. When a scheme needs modifying, the API requires that
|
||
|
* it will be rewritten. In such a case 'modify' should be TRUE.
|
||
|
* If the routine is called for a valid scheme and 'modify' is
|
||
|
* FALSE, it will return error.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_kg_scheme_params_t A structure of
|
||
|
* parameters for defining
|
||
|
* the scheme
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_KG_SCHEME_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(24), \
|
||
|
ioc_fm_pcd_kg_scheme_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_delete
|
||
|
*
|
||
|
* @Description Deleting an initialized scheme.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t scheme id as initialized by application at
|
||
|
* FM_PCD_IOC_KG_SET_SCHEME
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_KG_SCHEME_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(25), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_build
|
||
|
*
|
||
|
* @Description This routine must be called to define a complete coarse
|
||
|
* classification tree. This is the way to define coarse
|
||
|
* classification to a certain flow - the KeyGen schemes may
|
||
|
* point only to trees defined in this way.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_cc_tree_params_t A structure of parameters to
|
||
|
* define the tree.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_CC_ROOT_BUILD \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(26), void *)
|
||
|
/* workaround ...*/
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_delete
|
||
|
*
|
||
|
* @Description Deleting a built tree.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t - The id of a CC tree.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_CC_ROOT_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(27), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_set
|
||
|
*
|
||
|
* @Description This routine should be called for each CC (coarse
|
||
|
* classification) node. The whole CC tree should be built bottom
|
||
|
* up so that each node points to already defined nodes. p_NodeId
|
||
|
* returns the node Id to be used by other nodes.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_cc_node_params_t A structure for defining the CC
|
||
|
* node params
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(28), void *)
|
||
|
/* workaround ...*/
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_delete
|
||
|
*
|
||
|
* @Description Deleting a built node.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t - The id of a CC node.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(29), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_modify_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters in the entry of the tree.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_tree_modify_next_engine_params_t
|
||
|
* Pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_cc_root_build().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_CC_ROOT_MODIFY_NEXT_ENGINE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(30), \
|
||
|
ioc_fm_pcd_cc_tree_modify_next_engine_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters in the relevant key entry of
|
||
|
* the node.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_modify_next_engine_params_t
|
||
|
* A pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_MODIFY_NEXT_ENGINE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(31), \
|
||
|
ioc_fm_pcd_cc_node_modify_next_engine_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_miss_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters of the Miss key case of the
|
||
|
* node.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_modify_next_engine_params_t
|
||
|
* Pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_MODIFY_MISS_NEXT_ENGINE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(32), \
|
||
|
ioc_fm_pcd_cc_node_modify_next_engine_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_remove_key
|
||
|
*
|
||
|
* @Description Remove the key (including next engine parameters of this key)
|
||
|
* defined by the index of the relevant node.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_remove_key_params_t
|
||
|
* A pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only after fm_pcd_match_table_set() has been called
|
||
|
* for this node and for all of the nodes that lead to it.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_REMOVE_KEY \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(33), \
|
||
|
ioc_fm_pcd_cc_node_remove_key_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_add_key
|
||
|
*
|
||
|
* @Description Add the key (including next engine parameters of this key in
|
||
|
* the index defined by the key_index. Note that
|
||
|
* 'FM_PCD_LAST_KEY_INDEX' may be used when the user don't care
|
||
|
* about the position of the key in the table - in that case, the
|
||
|
* key will be automatically added by the driver in the last
|
||
|
* available entry.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t
|
||
|
* A pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only after fm_pcd_match_table_set() has been called
|
||
|
* for this node and for all of the nodes that lead to it.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_ADD_KEY \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(34), \
|
||
|
ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_key_and_next_engine
|
||
|
*
|
||
|
* @Description Modify the key and Next Engine Parameters of this key in the
|
||
|
* index defined by key_index.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t
|
||
|
* A pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() not only of
|
||
|
* the relevnt node but also the node that points to this node.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_MODIFY_KEY_AND_NEXT_ENGINE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(35), \
|
||
|
ioc_fm_pcd_cc_node_modify_key_and_next_engine_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_key
|
||
|
*
|
||
|
* @Description Modify the key at the index defined by key_index.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_cc_node_modify_key_params_t - Pointer to a
|
||
|
* structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only after fm_pcd_match_table_set() has been called
|
||
|
* for this node and for all of the nodes that lead to it.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MATCH_TABLE_MODIFY_KEY \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(36), \
|
||
|
ioc_fm_pcd_cc_node_modify_key_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_set
|
||
|
*
|
||
|
* @Description This routine initializes a hash table structure.
|
||
|
* KeyGen hash result determines the hash bucket.
|
||
|
* Next, KeyGen key is compared against all keys of this bucket
|
||
|
* (exact match).
|
||
|
* Number of sets (number of buckets) of the hash equals to the
|
||
|
* number of 1-s in 'hash_res_mask' in the provided parameters.
|
||
|
* Number of hash table ways is then calculated by dividing
|
||
|
* 'max_num_of_keys' equally between the hash sets. This is the
|
||
|
* maximal number of keys that a hash bucket may hold.
|
||
|
* The hash table is initialized empty and keys may be added to
|
||
|
* it following the initialization. Keys masks are not supported
|
||
|
* in current hash table implementation. The initialized hash
|
||
|
* table can be integrated as a node in a CC tree.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_hash_table_params_t Pointer to a structure
|
||
|
* with the relevant
|
||
|
* parameters.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_HASH_TABLE_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(37), \
|
||
|
ioc_fm_pcd_hash_table_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_delete
|
||
|
*
|
||
|
* @Description This routine deletes the provided hash table and released all
|
||
|
* its allocated resources.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t The ID of a hash table.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_HASH_TABLE_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(37), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_add_key
|
||
|
*
|
||
|
* @Description This routine adds the provided key (including next engine
|
||
|
* parameters of this key) to the hash table.
|
||
|
* The key is added as the last key of the bucket that it is
|
||
|
* mapped to.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_hash_table_add_key_params_t
|
||
|
* Pointer to a structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_HASH_TABLE_ADD_KEY \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(39), \
|
||
|
ioc_fm_pcd_hash_table_add_key_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_remove_key
|
||
|
*
|
||
|
* @Description This routine removes the requested key (including next engine
|
||
|
* parameters of this key) from the hash table.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_hash_table_remove_key_params_t - Pointer to a
|
||
|
* structure with the relevant parameters
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_HASH_TABLE_REMOVE_KEY \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(40), \
|
||
|
ioc_fm_pcd_hash_table_remove_key_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_set
|
||
|
*
|
||
|
* @Description Sets a profile entry in the policer profile table.
|
||
|
* The routine overrides any existing value.
|
||
|
*
|
||
|
* @Param[in,out] ioc_fm_pcd_plcr_profile_params_t A structure of
|
||
|
* parameters for defining
|
||
|
* a policer profile entry.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_PLCR_PROFILE_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(41), \
|
||
|
ioc_fm_pcd_plcr_profile_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_delete
|
||
|
*
|
||
|
* @Description Delete a profile entry in the policer profile table.
|
||
|
* The routine set entry to invalid.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t The id of a policer profile.
|
||
|
*
|
||
|
* @Return 0 on success; Error code otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_PLCR_PROFILE_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(41), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_set
|
||
|
*
|
||
|
* @Description This routine should be called for defining a manipulation
|
||
|
* node. A manipulation node must be defined before the CC node
|
||
|
* that precedes it.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_manip_params_t A structure of parameters
|
||
|
* defining the manipulation.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MANIP_NODE_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(43), \
|
||
|
ioc_fm_pcd_manip_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_replace
|
||
|
*
|
||
|
* @Description Change existing manipulation node to be according to new
|
||
|
* requirement. (Here, it's implemented as a variant of the same
|
||
|
* IOCTL as for fm_pcd_manip_node_set(), and one that when
|
||
|
* called, the 'id' member in its 'ioc_fm_pcd_manip_params_t'
|
||
|
* argument is set to contain the manip node's handle)
|
||
|
*
|
||
|
* @Param[in] ioc_fm_pcd_manip_params_t A structure of parameters
|
||
|
* defining the manipulation.
|
||
|
*
|
||
|
* @Return 0 on success; error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MANIP_NODE_REPLACE FM_PCD_IOC_MANIP_NODE_SET
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_delete
|
||
|
*
|
||
|
* @Description Delete an existing manipulation node.
|
||
|
*
|
||
|
* @Param[in] ioc_fm_obj_t The id of the manipulation node to delete.
|
||
|
*
|
||
|
* @Return 0 on success; error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MANIP_NODE_DELETE \
|
||
|
_IOW(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(44), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_get_statistics
|
||
|
*
|
||
|
* @Description Retrieve the manipulation statistics.
|
||
|
*
|
||
|
* @Param[in] h_manip_node A handle to a manipulation node.
|
||
|
* @Param[out] p_fm_pcd_manip_stats A structure for retrieving the
|
||
|
* manipulation statistics.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_MANIP_GET_STATS \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(50), \
|
||
|
ioc_fm_pcd_manip_get_stats_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_advanced_offload_support
|
||
|
*
|
||
|
* @Description This routine must be called in order to support the following
|
||
|
* features: IP-fragmentation, IP-reassembly, IPsec,
|
||
|
* Header-manipulation, frame-replicator.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return 0 on success; error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only when PCD is disabled.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_SET_ADVANCED_OFFLOAD_SUPPORT \
|
||
|
_IO(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(45))
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_set_group
|
||
|
*
|
||
|
* @Description Initialize a Frame Replicator group.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_frm_replic_group_param A structure of parameters for
|
||
|
* the initialization of the frame
|
||
|
* replicator group.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_FRM_REPLIC_GROUP_SET \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(46), \
|
||
|
ioc_fm_pcd_frm_replic_group_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_delete_group
|
||
|
*
|
||
|
* @Description Delete a Frame Replicator group.
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group().
|
||
|
*/
|
||
|
#define FM_PCD_IOC_FRM_REPLIC_GROUP_DELETE \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(47), ioc_fm_obj_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_add_member
|
||
|
*
|
||
|
* @Description Add the member in the index defined by the member_index.
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
* @Param[in] member_index Member index for adding.
|
||
|
* @Param[in] p_member_params A pointer to the new member parameters.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group() of this
|
||
|
* group.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_FRM_REPLIC_MEMBER_ADD \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(48), \
|
||
|
ioc_fm_pcd_frm_replic_member_params_t)
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_remove_member
|
||
|
*
|
||
|
* @Description Remove the member defined by the index from the relevant group
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
* @Param[in] member_index Member index for removing.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group() of this
|
||
|
* group.
|
||
|
*/
|
||
|
#define FM_PCD_IOC_FRM_REPLIC_MEMBER_REMOVE \
|
||
|
_IOWR(FM_IOC_TYPE_BASE, FM_PCD_IOC_NUM(49), \
|
||
|
ioc_fm_pcd_frm_replic_member_t)
|
||
|
|
||
|
/*
|
||
|
* @Group FM_grp Frame Manager API
|
||
|
*
|
||
|
* @Description Frame Manager Application Programming Interface
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Group FM_PCD_grp FM PCD
|
||
|
*
|
||
|
* @Description Frame Manager PCD (Parse-Classify-Distribute) API.
|
||
|
*
|
||
|
* The FM PCD module is responsible for the initialization of all
|
||
|
* global classifying FM modules. This includes the parser
|
||
|
* general and common registers, the key generator global and
|
||
|
* common registers, and the policer global and common registers.
|
||
|
* In addition, the FM PCD SW module will initialize all required
|
||
|
* key generator schemes, coarse classification flows, and
|
||
|
* policer profiles. When FM module is configured to work with
|
||
|
* one of these entities, it will register to it using the FM
|
||
|
* PORT API. The PCD module will manage the PCD resources - i.e.
|
||
|
* resource management of KeyGen schemes, etc.
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Collection General PCD defines
|
||
|
*/
|
||
|
#define FM_PCD_MAX_NUM_OF_PRIVATE_HDRS 2
|
||
|
/**< Number of units/headers saved for user */
|
||
|
|
||
|
#define FM_PCD_PRS_NUM_OF_HDRS 16
|
||
|
/**< Number of headers supported by HW parser */
|
||
|
#define FM_PCD_MAX_NUM_OF_DISTINCTION_UNITS \
|
||
|
(32 - FM_PCD_MAX_NUM_OF_PRIVATE_HDRS)
|
||
|
/**< Number of distinction units is limited by register size (32 bits) minus
|
||
|
*reserved bits for private headers.
|
||
|
*/
|
||
|
#define FM_PCD_MAX_NUM_OF_INTERCHANGEABLE_HDRS 4
|
||
|
/**< Maximum number of interchangeable headers in a distinction unit */
|
||
|
#define FM_PCD_KG_NUM_OF_GENERIC_REGS FM_KG_NUM_OF_GENERIC_REGS
|
||
|
/**< Total number of generic KeyGen registers */
|
||
|
#define FM_PCD_KG_MAX_NUM_OF_EXTRACTS_PER_KEY 35
|
||
|
/**< Max number allowed on any configuration; For HW implementation reasons, in
|
||
|
* most cases less than this will be allowed; The driver will return an
|
||
|
* initialization error if resource is unavailable.
|
||
|
*/
|
||
|
#define FM_PCD_KG_NUM_OF_EXTRACT_MASKS 4
|
||
|
/**< Total number of masks allowed on KeyGen extractions. */
|
||
|
#define FM_PCD_KG_NUM_OF_DEFAULT_GROUPS 16
|
||
|
/**< Number of default value logical groups */
|
||
|
|
||
|
#define FM_PCD_PRS_NUM_OF_LABELS 32
|
||
|
/**< Maximum number of SW parser labels */
|
||
|
#define FM_SW_PRS_MAX_IMAGE_SIZE \
|
||
|
(FM_PCD_SW_PRS_SIZE \
|
||
|
/*- FM_PCD_PRS_SW_OFFSET -FM_PCD_PRS_SW_TAIL_SIZE*/ \
|
||
|
- FM_PCD_PRS_SW_PATCHES_SIZE)
|
||
|
/**< Maximum size of SW parser code */
|
||
|
|
||
|
#define FM_PCD_MAX_MANIP_INSRT_TEMPLATE_SIZE 128
|
||
|
/**< Maximum size of insertion template for insert manipulation */
|
||
|
|
||
|
#define FM_PCD_FRM_REPLIC_MAX_NUM_OF_ENTRIES 64
|
||
|
/**< Maximum possible entries for frame replicator group */
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Group FM_PCD_init_grp FM PCD Initialization Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Initialization Unit API
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Description Exceptions user callback routine, will be called upon an
|
||
|
* exception passing the exception identification.
|
||
|
*
|
||
|
* @Param[in] h_app User's application descriptor.
|
||
|
* @Param[in] exception The exception.
|
||
|
*/
|
||
|
typedef void (t_fm_pcd_exception_callback) (t_handle h_app,
|
||
|
ioc_fm_pcd_exceptions exception);
|
||
|
|
||
|
/*
|
||
|
* @Description Exceptions user callback routine, will be called upon an
|
||
|
* exception passing the exception identification.
|
||
|
*
|
||
|
* @Param[in] h_app User's application descriptor.
|
||
|
* @Param[in] exception The exception.
|
||
|
* @Param[in] index id of the relevant source (may be scheme or
|
||
|
* profile id).
|
||
|
*/
|
||
|
typedef void (t_fm_pcd_id_exception_callback) (t_handle h_app,
|
||
|
ioc_fm_pcd_exceptions exception,
|
||
|
uint16_t index);
|
||
|
|
||
|
/*
|
||
|
* @Description A callback for enqueuing frame onto a QM queue.
|
||
|
*
|
||
|
* @Param[in] h_qm_arg Application's handle passed to QM module on
|
||
|
* enqueue.
|
||
|
* @Param[in] p_fd Frame descriptor for the frame.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*/
|
||
|
typedef uint32_t (t_fm_pcd_qm_enqueue_callback) (t_handle h_qm_arg, void *p_fd);
|
||
|
|
||
|
/*
|
||
|
* @Description Host-Command parameters structure.
|
||
|
*
|
||
|
* When using Host command for PCD functionalities, a dedicated
|
||
|
* port must be used. If this routine is called for a PCD in a
|
||
|
* single partition environment, or it is the Master partition in
|
||
|
* a Multi-partition environment, The port will be initialized by
|
||
|
* the PCD driver initialization routine.
|
||
|
*/
|
||
|
typedef struct t_fm_pcd_hc_params {
|
||
|
uintptr_t port_base_addr;
|
||
|
/**< Virtual Address of Host-Command Port memory mapped registers.*/
|
||
|
uint8_t port_id;
|
||
|
/**< Port Id (0-6 relative to Host-Command/Offline-Parsing ports);
|
||
|
* NOTE: When configuring Host Command port for FMANv3 devices
|
||
|
* (DPAA_VERSION 11 and higher), port_id=0 MUST be used.
|
||
|
*/
|
||
|
uint16_t liodn_base;
|
||
|
/**< LIODN base for this port, to be used together with LIODN offset
|
||
|
* (irrelevant for P4080 revision 1.0)
|
||
|
*/
|
||
|
uint32_t err_fqid;
|
||
|
/**< Host-Command Port error queue Id. */
|
||
|
uint32_t conf_fqid;
|
||
|
/**< Host-Command Port confirmation queue Id. */
|
||
|
uint32_t qm_channel;
|
||
|
/**< QM channel dedicated to this Host-Command port; will be used by the
|
||
|
* FM for dequeue.
|
||
|
*/
|
||
|
t_fm_pcd_qm_enqueue_callback *f_qm_enqueue;
|
||
|
/**< Callback routine for enqueuing a frame to the QM */
|
||
|
t_handle h_qm_arg;
|
||
|
/**< Application's handle passed to QM module on enqueue */
|
||
|
} t_fm_pcd_hc_params;
|
||
|
|
||
|
/*
|
||
|
* @Description The main structure for PCD initialization
|
||
|
*/
|
||
|
typedef struct t_fm_pcd_params {
|
||
|
bool prs_support;
|
||
|
/**< TRUE if Parser will be used for any of the FM ports. */
|
||
|
bool cc_support;
|
||
|
/**< TRUE if Coarse Classification will be used for any of the FM ports.
|
||
|
*/
|
||
|
bool kg_support;
|
||
|
/**< TRUE if KeyGen will be used for any of the FM ports. */
|
||
|
bool plcr_support;
|
||
|
/**< TRUE if Policer will be used for any of the FM ports. */
|
||
|
t_handle h_fm;
|
||
|
/**< A handle to the FM module. */
|
||
|
uint8_t num_schemes;
|
||
|
/**< Number of schemes dedicated to this partition.
|
||
|
* this parameter is relevant if 'kg_support'=TRUE.
|
||
|
*/
|
||
|
bool use_host_command;
|
||
|
/**< Optional for single partition, Mandatory for Multi partition */
|
||
|
t_fm_pcd_hc_params hc;
|
||
|
/**< Host Command parameters, relevant only if 'use_host_command'=TRUE;
|
||
|
* Relevant when FM not runs in "guest-mode".
|
||
|
*/
|
||
|
t_fm_pcd_exception_callback *f_exception;
|
||
|
/**< Callback routine for general PCD exceptions; Relevant when FM not
|
||
|
* runs in "guest-mode".
|
||
|
*/
|
||
|
t_fm_pcd_id_exception_callback *f_exception_id;
|
||
|
/**< Callback routine for specific KeyGen scheme or Policer profile
|
||
|
* exceptions; Relevant when FM not runs in "guest-mode".
|
||
|
*/
|
||
|
t_handle h_app;
|
||
|
/**< A handle to an application layer object; This handle will be passed
|
||
|
* by the driver upon calling the above callbacks; Relevant when FM not
|
||
|
* runs in "guest-mode".
|
||
|
*/
|
||
|
uint8_t part_plcr_profiles_base;
|
||
|
/**< The first policer-profile-id dedicated to this partition. this
|
||
|
* parameter is relevant if 'plcr_support'=TRUE. NOTE: this parameter
|
||
|
* relevant only when working with multiple partitions.
|
||
|
*/
|
||
|
uint16_t part_num_of_plcr_profiles;
|
||
|
/**< Number of policer-profiles dedicated to this partition. This
|
||
|
* parameter is relevant if 'plcr_support'=TRUE. NOTE: this parameter
|
||
|
* relevant only when working with multiple partitions.
|
||
|
*/
|
||
|
} t_fm_pcd_params;
|
||
|
|
||
|
typedef struct t_fm_pcd_prs_label_params {
|
||
|
uint32_t instruction_offset;
|
||
|
ioc_net_header_type hdr;
|
||
|
uint8_t index_per_hdr;
|
||
|
} t_fm_pcd_prs_label_params;
|
||
|
|
||
|
typedef struct t_fm_pcd_prs_sw_params {
|
||
|
bool override;
|
||
|
uint32_t size;
|
||
|
uint16_t base;
|
||
|
uint8_t *p_code;
|
||
|
uint32_t sw_prs_data_params[FM_PCD_PRS_NUM_OF_HDRS];
|
||
|
uint8_t num_of_labels;
|
||
|
t_fm_pcd_prs_label_params labels_table[FM_PCD_PRS_NUM_OF_LABELS];
|
||
|
} t_fm_pcd_prs_sw_params;
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config
|
||
|
*
|
||
|
* @Description Basic configuration of the PCD module.
|
||
|
* Creates descriptor for the FM PCD module.
|
||
|
*
|
||
|
* @Param[in] p_fm_pcd_params A structure of parameters for the
|
||
|
initialization of PCD.
|
||
|
*
|
||
|
* @Return A handle to the initialized module.
|
||
|
*/
|
||
|
t_handle fm_pcd_config(t_fm_pcd_params *p_fm_pcd_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_init
|
||
|
*
|
||
|
* @Description Initialization of the PCD module.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*/
|
||
|
uint32_t fm_pcd_init(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_free
|
||
|
*
|
||
|
* @Description Frees all resources that were assigned to FM module.
|
||
|
* Calling this routine invalidates the descriptor.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*/
|
||
|
uint32_t fm_pcd_free(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Group FM_PCD_advanced_cfg_grp FM PCD Advanced Configuration
|
||
|
* Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Advanced Configuration API.
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config_exception
|
||
|
*
|
||
|
* @Description Calling this routine changes the internal driver data base
|
||
|
* from its default selection of exceptions enabling.
|
||
|
* [DEFAULT_num_of_shared_plcr_profiles].
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] exception The exception to be selected.
|
||
|
* @Param[in] enable TRUE to enable interrupt, FALSE to mask it.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions This routine should NOT be called from guest-partition (i.e.
|
||
|
* guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_config_exception(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_exceptions exception, bool enable);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config_hc_frames_data_memory
|
||
|
*
|
||
|
* @Description Configures memory-partition-id for FMan-Controller
|
||
|
* Host-Command frames. Calling this routine changes the internal
|
||
|
* driver data base from its default configuration [0].
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] mem_id Memory partition ID.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions This routine may be called only if 'use_host_command' was TRUE
|
||
|
* when fm_pcd_config() routine was called.
|
||
|
*/
|
||
|
uint32_t fm_pcd_config_hc_frames_data_memory(t_handle h_fm_pcd, uint8_t mem_id);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config_plcr_num_of_shared_profiles
|
||
|
*
|
||
|
* @Description Calling this routine changes the internal driver data base
|
||
|
* from its default selection of exceptions enablement.
|
||
|
* [DEFAULT_num_of_shared_plcr_profiles].
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] num_of_shared_plcr_profiles Number of profiles to be shared
|
||
|
* between ports on this partition
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*/
|
||
|
uint32_t fm_pcd_config_plcr_num_of_shared_profiles(t_handle h_fm_pcd,
|
||
|
uint16_t num_of_shared_plcr_profiles);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config_plcr_auto_refresh_mode
|
||
|
*
|
||
|
* @Description Calling this routine changes the internal driver data base
|
||
|
* from its default selection of exceptions enablement. By
|
||
|
* default auto-refresh is [DEFAULT_plcrAutoRefresh].
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] enable TRUE to enable, FALSE to disable
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_config_plcr_auto_refresh_mode(t_handle h_fm_pcd, bool enable);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_config_prs_max_cycle_limit
|
||
|
*
|
||
|
* @Description Calling this routine changes the internal data structure for
|
||
|
* the maximum parsing time from its default value
|
||
|
* [DEFAULT_MAX_PRS_CYC_LIM].
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] value 0 to disable the mechanism, or new maximum
|
||
|
* parsing time.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_config_prs_max_cycle_limit(t_handle h_fm_pcd, uint16_t value);
|
||
|
|
||
|
/** @} */ /* end of FM_PCD_advanced_cfg_grp group */
|
||
|
/** @} */ /* end of FM_PCD_init_grp group */
|
||
|
|
||
|
/*
|
||
|
* @Group FM_PCD_Runtime_grp FM PCD Runtime Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Runtime Unit API
|
||
|
*
|
||
|
* The runtime control allows creation of PCD infrastructure
|
||
|
* modules such as Network Environment Characteristics,
|
||
|
* Classification Plan Groups and Coarse Classification Trees.
|
||
|
* It also allows on-the-fly initialization, modification and
|
||
|
* removal of PCD modules such as KeyGen schemes, coarse
|
||
|
* classification nodes and Policer profiles.
|
||
|
*
|
||
|
* In order to explain the programming model of the PCD driver
|
||
|
* interface a few terms should be explained, and will be used
|
||
|
* below.
|
||
|
* - Distinction Header - One of the 16 protocols supported by
|
||
|
* the FM parser, or one of the SHIM headers (1 or 2). May be a
|
||
|
* header with a special option (see below).
|
||
|
* - Interchangeable Headers Group - This is a group of Headers
|
||
|
* recognized by either one of them. For example, if in a
|
||
|
* specific context the user chooses to treat IPv4 and IPV6 in
|
||
|
* the same way, they may create an interchangeable Headers
|
||
|
* Unit consisting of these 2 headers.
|
||
|
* - A Distinction Unit - a Distinction Header or an
|
||
|
* Interchangeable Headers Group.
|
||
|
* - Header with special option - applies to Ethernet, MPLS,
|
||
|
* VLAN, IPv4 and IPv6, includes multicast, broadcast and other
|
||
|
* protocol specific options. In terms of hardware it relates
|
||
|
* to the options available in the classification plan.
|
||
|
* - Network Environment Characteristics - a set of Distinction
|
||
|
* Units that define the total recognizable header selection
|
||
|
* for a certain environment. This is NOT the list of all
|
||
|
* headers that will ever appear in a flow, but rather
|
||
|
* everything that needs distinction in a flow, where
|
||
|
* distinction is made by KeyGen schemes and coarse
|
||
|
* classification action descriptors.
|
||
|
*
|
||
|
* The PCD runtime modules initialization is done in stages. The
|
||
|
* first stage after initializing the PCD module itself is to
|
||
|
* establish a Network Flows Environment Definition. The
|
||
|
* application may choose to establish one or more such
|
||
|
* environments. Later, when needed, the application will have to
|
||
|
* state, for some of its modules, to which single environment it
|
||
|
* belongs.
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
t_handle fm_pcd_open(t_fm_pcd_params *p_fm_pcd_params);
|
||
|
void fm_pcd_close(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_enable
|
||
|
*
|
||
|
* @Description This routine should be called after PCD is initialized for
|
||
|
* enabling all PCD engines according to their existing
|
||
|
* configuration.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is disabled.
|
||
|
*/
|
||
|
uint32_t fm_pcd_enable(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_disable
|
||
|
*
|
||
|
* @Description This routine may be called when PCD is enabled in order to
|
||
|
* disable all PCD engines. It may be called only when none of
|
||
|
* the ports in the system are using the PCD.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is enabled.
|
||
|
*/
|
||
|
uint32_t fm_pcd_disable(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_get_counter
|
||
|
*
|
||
|
* @Description Reads one of the FM PCD counters.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] counter The requested counter.
|
||
|
*
|
||
|
* @Return Counter's current value.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* Note that it is user's responsibility to call this routine
|
||
|
* only for enabled counters, and there will be no indication if
|
||
|
* a disabled counter is accessed.
|
||
|
*/
|
||
|
uint32_t fm_pcd_get_counter(t_handle h_fm_pcd, ioc_fm_pcd_counters counter);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_prs_load_sw
|
||
|
*
|
||
|
* @Description This routine may be called in order to load software parsing
|
||
|
* code.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_sw_prs A pointer to a structure of software
|
||
|
* parser parameters, including the software
|
||
|
* parser image.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is disabled.
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_prs_load_sw(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_prs_sw_params_t *p_sw_prs);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_advanced_offload_support
|
||
|
*
|
||
|
* @Description This routine must be called in order to support the following
|
||
|
* features: IP-fragmentation, IP-reassembly, IPsec,
|
||
|
* Header-manipulation, frame-replicator.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is disabled.
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_set_advanced_offload_support(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_set_dflt_value
|
||
|
*
|
||
|
* @Description Calling this routine sets a global default value to be used
|
||
|
* by the KeyGen when parser does not recognize a required
|
||
|
* field/header.
|
||
|
* default value is 0.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] value_id 0,1 - one of 2 global default values.
|
||
|
* @Param[in] value The requested default value.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is disabled.
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_set_dflt_value(t_handle h_fm_pcd,
|
||
|
uint8_t value_id, uint32_t value);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_set_additional_data_after_parsing
|
||
|
*
|
||
|
* @Description Calling this routine allows the KeyGen to access data past
|
||
|
* the parser finishing point.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] payload_offset the number of bytes beyond the parser
|
||
|
* location.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() and when PCD is disabled.
|
||
|
* This routine should NOT be called from guest-partition (i.e.
|
||
|
* guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_set_additional_data_after_parsing(t_handle h_fm_pcd,
|
||
|
uint8_t payload_offset);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_exception
|
||
|
*
|
||
|
* @Description Calling this routine enables/disables PCD interrupts.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] exception The exception to be selected.
|
||
|
* @Param[in] enable TRUE to enable interrupt, FALSE to mask it.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_set_exception(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_exceptions exception, bool enable);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_modify_counter
|
||
|
*
|
||
|
* @Description Sets a value to an enabled counter. Use "0" to reset the
|
||
|
* counter.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] counter The requested counter.
|
||
|
* @Param[in] value The requested value to be written into the
|
||
|
* counter.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_modify_counter(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_counters counter, uint32_t value);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_plcr_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to enable/disable policer statistics
|
||
|
* counter. By default the statistics is enabled.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor
|
||
|
* @Param[in] enable TRUE to enable, FALSE to disable.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
uint32_t fm_pcd_set_plcr_statistics(t_handle h_fm_pcd, bool enable);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_set_prs_statistics
|
||
|
*
|
||
|
* @Description Defines whether to gather parser statistics including all
|
||
|
* ports.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] enable TRUE to enable, FALSE to disable.
|
||
|
*
|
||
|
* @Return None
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* This routine should NOT be called from guest-partition
|
||
|
* (i.e. guestId != NCSW_PRIMARY_ID)
|
||
|
*/
|
||
|
void fm_pcd_set_prs_statistics(t_handle h_fm_pcd, bool enable);
|
||
|
|
||
|
#if (defined(DEBUG_ERRORS) && (DEBUG_ERRORS > 0))
|
||
|
/*
|
||
|
* @Function fm_pcd_dump_regs
|
||
|
*
|
||
|
* @Description Dumps all PCD registers
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID) or in a case that the
|
||
|
* registers are mapped.
|
||
|
*/
|
||
|
uint32_t fm_pcd_dump_regs(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_dump_regs
|
||
|
*
|
||
|
* @Description Dumps all PCD KG registers
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID) or in a case that the
|
||
|
* registers are mapped.
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_dump_regs(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_dump_regs
|
||
|
*
|
||
|
* @Description Dumps all PCD Policer registers
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID) or in a case that the
|
||
|
* registers are mapped.
|
||
|
*/
|
||
|
uint32_t fm_pcd_plcr_dump_regs(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_dump_regs
|
||
|
*
|
||
|
* @Description Dumps all PCD Policer profile registers
|
||
|
*
|
||
|
* @Param[in] h_profile A handle to a Policer profile.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID) or in a case that the
|
||
|
* registers are mapped.
|
||
|
*/
|
||
|
uint32_t fm_pcd_plcr_profile_dump_regs(t_handle h_profile);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_prs_dump_regs
|
||
|
*
|
||
|
* @Description Dumps all PCD Parser registers
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID) or in a case that the
|
||
|
* registers are mapped.
|
||
|
*/
|
||
|
uint32_t fm_pcd_prs_dump_regs(t_handle h_fm_pcd);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hc_dump_regs
|
||
|
*
|
||
|
* @Description Dumps HC Port registers
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
* NOTE: this routine may be called only for FM in master mode
|
||
|
* (i.e. 'guestId'=NCSW_PRIMARY_ID).
|
||
|
*/
|
||
|
uint32_t fm_pcd_hc_dump_regs(t_handle h_fm_pcd);
|
||
|
#endif /* (defined(DEBUG_ERRORS) && ... */
|
||
|
|
||
|
|
||
|
/*
|
||
|
* KeyGen FM_PCD_Runtime_build_grp FM PCD Runtime Building Unit
|
||
|
*
|
||
|
* @Description Frame Manager PCD Runtime Building API
|
||
|
*
|
||
|
* This group contains routines for setting, deleting and
|
||
|
* modifying PCD resources, for defining the total PCD tree.
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @Collection Definitions of coarse classification
|
||
|
* parameters as required by KeyGen (when coarse classification
|
||
|
* is the next engine after this scheme).
|
||
|
*/
|
||
|
#define FM_PCD_MAX_NUM_OF_CC_TREES 8
|
||
|
#define FM_PCD_MAX_NUM_OF_CC_GROUPS 16
|
||
|
#define FM_PCD_MAX_NUM_OF_CC_UNITS 4
|
||
|
#define FM_PCD_MAX_NUM_OF_KEYS 256
|
||
|
#define FM_PCD_MAX_NUM_OF_FLOWS (4 * KILOBYTE)
|
||
|
#define FM_PCD_MAX_SIZE_OF_KEY 56
|
||
|
#define FM_PCD_MAX_NUM_OF_CC_ENTRIES_IN_GRP 16
|
||
|
#define FM_PCD_LAST_KEY_INDEX 0xffff
|
||
|
|
||
|
#define FM_PCD_MAX_NUM_OF_CC_NODES 255
|
||
|
/* Obsolete, not used - will be removed in the future */
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Collection A set of definitions to allow protocol
|
||
|
* special option description.
|
||
|
*/
|
||
|
typedef uint32_t protocol_opt_t;
|
||
|
/**< A general type to define a protocol option. */
|
||
|
|
||
|
typedef protocol_opt_t eth_protocol_opt_t;
|
||
|
/**< Ethernet protocol options. */
|
||
|
#define ETH_BROADCAST 0x80000000 /**< Ethernet Broadcast. */
|
||
|
#define ETH_MULTICAST 0x40000000 /**< Ethernet Multicast. */
|
||
|
|
||
|
typedef protocol_opt_t vlan_protocol_opt_t; /**< VLAN protocol options. */
|
||
|
#define VLAN_STACKED 0x20000000 /**< Stacked VLAN. */
|
||
|
|
||
|
typedef protocol_opt_t mpls_protocol_opt_t; /**< MPLS protocol options. */
|
||
|
#define MPLS_STACKED 0x10000000 /**< Stacked MPLS. */
|
||
|
|
||
|
typedef protocol_opt_t ipv_4protocol_opt_t; /**< IPv4 protocol options. */
|
||
|
#define IPV4_BROADCAST_1 0x08000000 /**< IPv4 Broadcast. */
|
||
|
#define IPV4_MULTICAST_1 0x04000000 /**< IPv4 Multicast. */
|
||
|
#define IPV4_UNICAST_2 0x02000000 /**< Tunneled IPv4 - Unicast. */
|
||
|
#define IPV4_MULTICAST_BROADCAST_2 0x01000000
|
||
|
/**< Tunneled IPv4 - Broadcast/Multicast. */
|
||
|
|
||
|
#define IPV4_FRAG_1 0x00000008
|
||
|
/**< IPV4 reassembly option. IPV4 Reassembly
|
||
|
* manipulation requires network environment
|
||
|
* with IPV4 header and IPV4_FRAG_1 option
|
||
|
*/
|
||
|
|
||
|
typedef protocol_opt_t ipv_6protocol_opt_t; /**< IPv6 protocol options. */
|
||
|
#define IPV6_MULTICAST_1 0x00800000 /**< IPv6 Multicast. */
|
||
|
#define IPV6_UNICAST_2 0x00400000 /**< Tunneled IPv6 - Unicast. */
|
||
|
#define IPV6_MULTICAST_2 0x00200000 /**< Tunneled IPv6 - Multicast. */
|
||
|
|
||
|
#define IPV6_FRAG_1 0x00000004
|
||
|
/**< IPV6 reassembly option. IPV6 Reassembly
|
||
|
* manipulation requires network environment
|
||
|
* with IPV6 header and IPV6_FRAG_1 option; in
|
||
|
* case where fragment found, the
|
||
|
* fragment-extension offset may be found at
|
||
|
* 'shim2' (in parser-result).
|
||
|
*/
|
||
|
typedef protocol_opt_t capwap_protocol_opt_t; /**< CAPWAP protocol options. */
|
||
|
#define CAPWAP_FRAG_1 0x00000008
|
||
|
/**< CAPWAP reassembly option. CAPWAP Reassembly
|
||
|
* manipulation requires network environment
|
||
|
* with CAPWAP header and CAPWAP_FRAG_1 option;
|
||
|
* in case where fragment found, the
|
||
|
* fragment-extension offset may be found at
|
||
|
* 'shim2' (in parser-result).
|
||
|
*/
|
||
|
|
||
|
/* @} */
|
||
|
|
||
|
#define FM_PCD_MANIP_MAX_HDR_SIZE 256
|
||
|
#define FM_PCD_MANIP_DSCP_TO_VLAN_TRANS 64
|
||
|
|
||
|
/*
|
||
|
* @Collection A set of definitions to support Header Manipulation selection.
|
||
|
*/
|
||
|
typedef uint32_t hdr_manip_flags_t;
|
||
|
/**< A general type to define a HMan update command flags. */
|
||
|
|
||
|
typedef hdr_manip_flags_t ipv_4hdr_manip_update_flags_t;
|
||
|
/**< IPv4 protocol HMan update command flags. */
|
||
|
|
||
|
#define HDR_MANIP_IPV4_TOS 0x80000000
|
||
|
/**< update TOS with the given value ('tos' field
|
||
|
* of t_FmPcdManipHdrFieldUpdateIpv4)
|
||
|
*/
|
||
|
#define HDR_MANIP_IPV4_ID 0x40000000
|
||
|
/**< update IP ID with the given value ('id' field
|
||
|
* of t_FmPcdManipHdrFieldUpdateIpv4)
|
||
|
*/
|
||
|
#define HDR_MANIP_IPV4_TTL 0x20000000
|
||
|
/**< Decrement TTL by 1 */
|
||
|
#define HDR_MANIP_IPV4_SRC 0x10000000
|
||
|
/**< update IP source address with the given value
|
||
|
* ('src' field of t_FmPcdManipHdrFieldUpdateIpv4)
|
||
|
*/
|
||
|
#define HDR_MANIP_IPV4_DST 0x08000000
|
||
|
/**< update IP destination address with the given value
|
||
|
* ('dst' field of t_FmPcdManipHdrFieldUpdateIpv4)
|
||
|
*/
|
||
|
|
||
|
typedef hdr_manip_flags_t ipv_6hdr_manip_update_flags_t;
|
||
|
/**< IPv6 protocol HMan update command flags. */
|
||
|
|
||
|
#define HDR_MANIP_IPV6_TC 0x80000000
|
||
|
/**< update Traffic Class address with the given value
|
||
|
* ('trafficClass' field of
|
||
|
* t_FmPcdManipHdrFieldUpdateIpv6)
|
||
|
*/
|
||
|
#define HDR_MANIP_IPV6_HL 0x40000000
|
||
|
/**< Decrement Hop Limit by 1 */
|
||
|
#define HDR_MANIP_IPV6_SRC 0x20000000
|
||
|
/**< update IP source address with the given value
|
||
|
* ('src' field of t_FmPcdManipHdrFieldUpdateIpv6)
|
||
|
*/
|
||
|
#define HDR_MANIP_IPV6_DST 0x10000000
|
||
|
/**< update IP destination address with the given value
|
||
|
* ('dst' field of t_FmPcdManipHdrFieldUpdateIpv6)
|
||
|
*/
|
||
|
|
||
|
typedef hdr_manip_flags_t tcp_udp_hdr_manip_update_flags_t;
|
||
|
/**< TCP/UDP protocol HMan update command flags. */
|
||
|
|
||
|
#define HDR_MANIP_TCP_UDP_SRC 0x80000000
|
||
|
/**< update TCP/UDP source address with the given value
|
||
|
* ('src' field of t_FmPcdManipHdrFieldUpdateTcpUdp)
|
||
|
*/
|
||
|
#define HDR_MANIP_TCP_UDP_DST 0x40000000
|
||
|
/**< update TCP/UDP destination address with the given value
|
||
|
* ('dst' field of t_FmPcdManipHdrFieldUpdateTcpUdp)
|
||
|
*/
|
||
|
#define HDR_MANIP_TCP_UDP_CHECKSUM 0x20000000
|
||
|
/**< update TCP/UDP checksum */
|
||
|
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Description A type used for returning the order of the key extraction.
|
||
|
* each value in this array represents the index of the
|
||
|
* extraction command as defined by the user in the
|
||
|
* initialization extraction array. The valid size of this array
|
||
|
* is the user define number of extractions required (also marked
|
||
|
* by the second '0' in this array).
|
||
|
*/
|
||
|
typedef uint8_t t_fm_pcd_kg_key_order[FM_PCD_KG_MAX_NUM_OF_EXTRACTS_PER_KEY];
|
||
|
|
||
|
/*
|
||
|
* @Collection Definitions for CC statistics
|
||
|
*/
|
||
|
#define FM_PCD_CC_STATS_MAX_NUM_OF_FLR 10
|
||
|
/* Maximal supported number of frame length ranges */
|
||
|
#define FM_PCD_CC_STATS_FLR_SIZE 2
|
||
|
/* Size in bytes of a frame length range limit */
|
||
|
#define FM_PCD_CC_STATS_COUNTER_SIZE 4
|
||
|
/* Size in bytes of a frame length range counter */
|
||
|
/* @} */
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining CC keys parameters
|
||
|
* The driver supports two methods for CC node allocation:
|
||
|
* dynamic and static. Static mode was created in order to
|
||
|
* prevent runtime alloc/free of FMan memory (MURAM), which may
|
||
|
* cause fragmentation; in this mode, the driver automatically
|
||
|
* allocates the memory according to 'max_num_of_keys' parameter.
|
||
|
* The driver calculates the maximal memory size that may be used
|
||
|
* for this CC-Node taking into consideration 'mask_support' and
|
||
|
* 'statistics_mode' parameters. When 'action' =
|
||
|
* e_FM_PCD_ACTION_INDEXED_LOOKUP in the extraction parameters of
|
||
|
* this node, 'max_num_of_keys' must be equal to 'num_of_keys'.
|
||
|
* In dynamic mode, 'max_num_of_keys' must be zero. At
|
||
|
* initialization, all required structures are allocated
|
||
|
* according to 'num_of_keys' parameter. During runtime
|
||
|
* modification, these structures are re-allocated according to
|
||
|
* the updated number of keys.
|
||
|
*
|
||
|
* Please note that 'action' and 'icIndxMask' mentioned in the
|
||
|
* specific parameter explanations are passed in the extraction
|
||
|
* parameters of the node (fields of
|
||
|
* extractCcParams.extractNonHdr).
|
||
|
*/
|
||
|
typedef struct t_keys_params {
|
||
|
uint16_t max_num_of_keys;
|
||
|
/**< Maximum number of keys that will (ever) be used in this
|
||
|
* CC-Node; A value of zero may be used for dynamic memory
|
||
|
* allocation.
|
||
|
*/
|
||
|
bool mask_support;
|
||
|
/**< This parameter is relevant only if a node is initialized
|
||
|
* with 'action' = e_FM_PCD_ACTION_EXACT_MATCH and
|
||
|
* max_num_of_keys > 0; Should be TRUE to reserve table memory
|
||
|
* for key masks, even if initial keys do not contain masks, or
|
||
|
* if the node was initialized as 'empty' (without keys); this
|
||
|
* will allow user to add keys with masks at runtime.
|
||
|
* NOTE that if user want to use only global-masks (i.e. one
|
||
|
* common mask for all the entries within this table, this
|
||
|
* parameter should set to 'FALSE'.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_stats_mode statistics_mode;
|
||
|
/**< Determines the supported statistics mode for all node's
|
||
|
* keys. To enable statistics gathering, statistics should be
|
||
|
* enabled per every key, using 'statisticsEn' in next engine
|
||
|
* parameters structure of that key; If 'max_num_of_keys' is
|
||
|
* set, all required structures will be preallocated for all
|
||
|
* keys.
|
||
|
*/
|
||
|
uint16_t frame_length_ranges[FM_PCD_CC_STATS_MAX_NUM_OF_FLR];
|
||
|
/**< Relevant only for 'RMON' statistics mode (this feature is
|
||
|
* supported only on B4860 device); Holds a list of programmable
|
||
|
* thresholds - for each received frame, its length in bytes is
|
||
|
* examined against these range thresholds and the appropriate
|
||
|
* counter is incremented by 1 - for example, to belong to range
|
||
|
* i, the following should hold: range i-1 threshold < frame
|
||
|
* length <= range i threshold. Each range threshold must be
|
||
|
* larger then its preceding range threshold, and last range
|
||
|
* threshold must be 0xFFFF.
|
||
|
*/
|
||
|
uint16_t num_of_keys;
|
||
|
/**< Number of initial keys; Note that in case of 'action' =
|
||
|
* e_FM_PCD_ACTION_INDEXED_LOOKUP, this field should be
|
||
|
* power-of-2 of the number of bits that are set in 'icIndxMask'
|
||
|
*/
|
||
|
uint8_t key_size;
|
||
|
/**< Size of key - for extraction of type FULL_FIELD, 'key_size'
|
||
|
* has to be the standard size of the selected key; For other
|
||
|
* extraction types, 'key_size' has to be as size of extraction;
|
||
|
* When 'action' = e_FM_PCD_ACTION_INDEXED_LOOKUP, 'key_size'
|
||
|
* must be 2.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_key_params_t key_params[FM_PCD_MAX_NUM_OF_KEYS];
|
||
|
/**< An array with 'num_of_keys' entries, each entry specifies
|
||
|
* the corresponding key parameters; When 'action' =
|
||
|
* e_FM_PCD_ACTION_EXACT_MATCH, this value must not exceed 255
|
||
|
* (FM_PCD_MAX_NUM_OF_KEYS-1) as the last entry is saved for the
|
||
|
* 'miss' entry.
|
||
|
*/
|
||
|
ioc_fm_pcd_cc_next_engine_params_t cc_next_engine_params_for_miss;
|
||
|
/**< Parameters for defining the next engine when a key is not
|
||
|
* matched; Not relevant if action =
|
||
|
* e_FM_PCD_ACTION_INDEXED_LOOKUP.
|
||
|
*/
|
||
|
} t_keys_params;
|
||
|
|
||
|
/*
|
||
|
* @Description Parameters for defining custom header manipulation for generic
|
||
|
* field replacement
|
||
|
*/
|
||
|
typedef struct ioc_fm_pcd_manip_hdr_custom_gen_field_replace {
|
||
|
uint8_t src_offset;
|
||
|
/**< Location of new data - Offset from Parse Result
|
||
|
* (>= 16, src_offset+size <= 32, )
|
||
|
*/
|
||
|
uint8_t dst_offset;
|
||
|
/**< Location of data to be overwritten - Offset from
|
||
|
* start of frame (dst_offset + size <= 256).
|
||
|
*/
|
||
|
uint8_t size;
|
||
|
/**< The number of bytes (<=16) to be replaced */
|
||
|
uint8_t mask;
|
||
|
/**< Optional 1 byte mask. Set to select bits for
|
||
|
* replacement (1 - bit will be replaced); Clear to use
|
||
|
* field as is.
|
||
|
*/
|
||
|
uint8_t mask_offset;
|
||
|
/**< Relevant if mask != 0; Mask offset within the
|
||
|
* replaces "size"
|
||
|
*/
|
||
|
} ioc_fm_pcd_manip_hdr_custom_gen_field_replace;
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_net_env_characteristics_set
|
||
|
*
|
||
|
* @Description Define a set of Network Environment Characteristics.
|
||
|
*
|
||
|
* When setting an environment it is important to understand its
|
||
|
* application. It is not meant to describe the flows that will
|
||
|
* run on the ports using this environment, but what the user
|
||
|
* means TO DO with the PCD mechanisms in order to
|
||
|
* parse-classify-distribute those frames.
|
||
|
* By specifying a distinction unit, the user means it would use
|
||
|
* that option for distinction between frames at either a KeyGen
|
||
|
* scheme or a coarse classification action descriptor. Using
|
||
|
* interchangeable headers to define a unit means that the user
|
||
|
* is indifferent to which of the interchangeable headers is
|
||
|
* present in the frame, and wants the distinction to be based on
|
||
|
* the presence of either one of them.
|
||
|
*
|
||
|
* Depending on context, there are limitations to the use of
|
||
|
* environments. A port using the PCD functionality is bound to
|
||
|
* an environment. Some or even all ports may share an
|
||
|
* environment but also an environment per port is possible. When
|
||
|
* initializing a scheme, a classification plan group (see
|
||
|
* below), or a coarse classification tree, one of the
|
||
|
* initialized environments must be stated and related to. When a
|
||
|
* port is bound to a scheme, a classification plan group, or a
|
||
|
* coarse classification tree, it MUST be bound to the same
|
||
|
* environment.
|
||
|
*
|
||
|
* The different PCD modules, may relate (for flows definition)
|
||
|
* ONLY on distinction units as defined by their environment.
|
||
|
* When initializing a scheme for example, it may not choose to
|
||
|
* select IPV4 as a match for recognizing flows unless it was
|
||
|
* defined in the relating environment. In fact, to guide the
|
||
|
* user through the configuration of the PCD, each module's
|
||
|
* characterization in terms of flows is not done using protocol
|
||
|
* names, but using environment indexes.
|
||
|
*
|
||
|
* In terms of HW implementation, the list of distinction units
|
||
|
* sets the LCV vectors and later used for match vector,
|
||
|
* classification plan vectors and coarse classification
|
||
|
* indexing.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_netenv_params A structure of parameters for the
|
||
|
* initialization of the network
|
||
|
* environment.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_net_env_characteristics_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_net_env_params_t *p_netenv_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_net_env_characteristics_delete
|
||
|
*
|
||
|
* @Description Deletes a set of Network Environment Characteristics.
|
||
|
*
|
||
|
* @Param[in] h_net_env A handle to the Network environment.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*/
|
||
|
uint32_t fm_pcd_net_env_characteristics_delete(t_handle h_net_env);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_set
|
||
|
*
|
||
|
* @Description Initializing or modifying and enabling a scheme for the
|
||
|
* KeyGen. This routine should be called for adding or modifying
|
||
|
* a scheme. When a scheme needs modifying, the API requires that
|
||
|
* it will be rewritten. In such a case 'modify' should be TRUE.
|
||
|
* If the routine is called for a valid scheme and 'modify' is
|
||
|
* FALSE, it will return error.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd If this is a new scheme - A handle to an
|
||
|
* FM PCD Module. Otherwise NULL (ignored
|
||
|
* by driver).
|
||
|
* @Param[in,out] p_scheme_params A structure of parameters for defining
|
||
|
* the scheme
|
||
|
*
|
||
|
* @Return A handle to the initialized scheme on success; NULL code
|
||
|
* otherwise. When used as "modify" (rather than for setting a
|
||
|
* new scheme), p_scheme_params->id.h_scheme will return NULL if
|
||
|
* action fails due to scheme BUSY state.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_kg_scheme_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_kg_scheme_params_t *p_scheme_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_delete
|
||
|
*
|
||
|
* @Description Deleting an initialized scheme.
|
||
|
*
|
||
|
* @Param[in] h_scheme scheme handle as returned by
|
||
|
* fm_pcd_kg_scheme_set()
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() & fm_pcd_kg_scheme_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_scheme_delete(t_handle h_scheme);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_get_counter
|
||
|
*
|
||
|
* @Description Reads scheme packet counter.
|
||
|
*
|
||
|
* @Param[in] h_scheme scheme handle as returned by
|
||
|
* fm_pcd_kg_scheme_set().
|
||
|
*
|
||
|
* @Return Counter's current value.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() & fm_pcd_kg_scheme_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_scheme_get_counter(t_handle h_scheme);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_kg_scheme_set_counter
|
||
|
*
|
||
|
* @Description Writes scheme packet counter.
|
||
|
*
|
||
|
* @Param[in] h_scheme scheme handle as returned by
|
||
|
* fm_pcd_kg_scheme_set().
|
||
|
* @Param[in] value New scheme counter value - typically '0' for
|
||
|
* resetting the counter.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init() & fm_pcd_kg_scheme_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_kg_scheme_set_counter(t_handle h_scheme,
|
||
|
uint32_t value);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_set
|
||
|
*
|
||
|
* @Description Sets a profile entry in the policer profile table.
|
||
|
* The routine overrides any existing value.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd A handle to an FM PCD Module.
|
||
|
* @Param[in] p_profile A structure of parameters for defining a
|
||
|
* policer profile entry.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise. When used as "modify" (rather than for setting a
|
||
|
* new profile), p_profile->id.h_profile will return NULL if
|
||
|
* action fails due to profile BUSY state.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_plcr_profile_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_plcr_profile_params_t *p_profile);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_delete
|
||
|
*
|
||
|
* @Description Delete a profile entry in the policer profile table.
|
||
|
* The routine set entry to invalid.
|
||
|
*
|
||
|
* @Param[in] h_profile A handle to the profile.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_plcr_profile_delete(t_handle h_profile);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_get_counter
|
||
|
*
|
||
|
* @Description Sets an entry in the classification plan.
|
||
|
* The routine overrides any existing value.
|
||
|
*
|
||
|
* @Param[in] h_profile A handle to the profile.
|
||
|
* @Param[in] counter Counter selector.
|
||
|
*
|
||
|
* @Return specific counter value.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_plcr_profile_get_counter(t_handle h_profile,
|
||
|
ioc_fm_pcd_plcr_profile_counters counter);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_plcr_profile_set_counter
|
||
|
*
|
||
|
* @Description Sets an entry in the classification plan.
|
||
|
* The routine overrides any existing value.
|
||
|
*
|
||
|
* @Param[in] h_profile A handle to the profile.
|
||
|
* @Param[in] counter Counter selector.
|
||
|
* @Param[in] value value to set counter with.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_plcr_profile_set_counter(t_handle h_profile,
|
||
|
ioc_fm_pcd_plcr_profile_counters counter,
|
||
|
uint32_t value);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_build
|
||
|
*
|
||
|
* @Description This routine must be called to define a complete coarse
|
||
|
* classification tree. This is the way to define coarse
|
||
|
* classification to a certain flow - the KeyGen schemes may
|
||
|
* point only to trees defined in this way.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_params A structure of parameters to define the tree.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_cc_root_build(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_cc_tree_params_t *p_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_delete
|
||
|
*
|
||
|
* @Description Deleting an built tree.
|
||
|
*
|
||
|
* @Param[in] h_cc_tree A handle to a CC tree.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_cc_root_delete(t_handle h_cc_tree);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_cc_root_modify_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters in the entry of the tree.
|
||
|
*
|
||
|
* @Param[in] h_cc_tree A handle to the tree
|
||
|
* @Param[in] grp_id A Group index in the tree
|
||
|
* @Param[in] index Entry index in the group
|
||
|
* defined by grp_id
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine Pointer to new next
|
||
|
* engine parameters
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following FM_PCD_CcBuildTree().
|
||
|
*/
|
||
|
uint32_t fm_pcd_cc_root_modify_next_engine(t_handle h_cc_tree,
|
||
|
uint8_t grp_id,
|
||
|
uint8_t index,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_set
|
||
|
*
|
||
|
* @Description This routine should be called for each CC (coarse
|
||
|
* classification) node. The whole CC tree should be built bottom
|
||
|
* up so that each node points to already defined nodes.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_param A structure of parameters defining the CC node
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_match_table_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_cc_node_params_t *p_param);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_delete
|
||
|
*
|
||
|
* @Description Deleting an built node.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to a CC node.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_delete(t_handle h_cc_node);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_miss_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters of the Miss key case of the
|
||
|
* node.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine_params Parameters for defining
|
||
|
* next engine
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set(); Not
|
||
|
* relevant in the case the node is of type 'INDEXED_LOOKUP'.
|
||
|
* When configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_modify_miss_next_engine(t_handle h_cc_node,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_remove_key
|
||
|
*
|
||
|
* @Description Remove the key (including next engine parameters of this key)
|
||
|
* defined by the index of the relevant node.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for removing
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_remove_key(t_handle h_cc_node,
|
||
|
uint16_t key_index);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_add_key
|
||
|
*
|
||
|
* @Description Add the key (including next engine parameters of this key in
|
||
|
* the index defined by the key_index. Note that
|
||
|
* 'FM_PCD_LAST_KEY_INDEX' may be used by user that don't care
|
||
|
* about the position of the key in the table - in that case, the
|
||
|
* key will be automatically added by the driver in the last
|
||
|
* available entry.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding.
|
||
|
* @Param[in] key_size Key size of added key
|
||
|
* @Param[in] p_key_params A pointer to the parameters includes new key
|
||
|
* with Next Engine Parameters
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_add_key(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
uint8_t key_size,
|
||
|
ioc_fm_pcd_cc_key_params_t *p_key_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters in the relevant key entry of
|
||
|
* the node.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for Next
|
||
|
* Engine modifications
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine Parameters for defining
|
||
|
* next engine
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set(). When
|
||
|
* configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_modify_next_engine(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_key_and_next_engine
|
||
|
*
|
||
|
* @Description Modify the key and Next Engine Parameters of this key in the
|
||
|
* index defined by the key_index.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding
|
||
|
* @Param[in] key_size Key size of added key
|
||
|
* @Param[in] p_key_params A pointer to the parameters includes
|
||
|
* modified key and modified Next Engine
|
||
|
* Params
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it. When configuring
|
||
|
* nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_modify_key_and_next_engine(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
uint8_t key_size,
|
||
|
ioc_fm_pcd_cc_key_params_t *p_key_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_modify_key
|
||
|
*
|
||
|
* @Description Modify the key in the index defined by the key_index.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding
|
||
|
* @Param[in] key_size Key size of added key
|
||
|
* @Param[in] p_key A pointer to the new key
|
||
|
* @Param[in] p_mask A pointer to the new mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_modify_key(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_find_nremove_key
|
||
|
*
|
||
|
* @Description Remove the key (including next engine parameters of this key)
|
||
|
* defined by the key and mask. Note that this routine will
|
||
|
* search the node to locate the index of the required key
|
||
|
* (& mask) to remove.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_size Key size of the one to remove.
|
||
|
* @Param[in] p_key A pointer to the requested key to remove.
|
||
|
* @Param[in] p_mask A pointer to the mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_find_nremove_key(t_handle h_cc_node,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_find_nmodify_next_engine
|
||
|
*
|
||
|
* @Description Modify the Next Engine Parameters in the relevant key entry of
|
||
|
* the node. Note that this routine will search the node to
|
||
|
* locate the index of the required key (& mask) to modify.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_size Key size of the one to modify.
|
||
|
* @Param[in] p_key A pointer to the requested key to modify
|
||
|
* @Param[in] p_mask A pointer to the mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine Parameters for defining
|
||
|
* next engine
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set(). When
|
||
|
* configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_find_nmodify_next_engine(t_handle h_cc_node,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_find_nmodify_key_and_next_engine
|
||
|
*
|
||
|
* @Description Modify the key and Next Engine Parameters of this key in the
|
||
|
* index defined by the key_index. Note that this routine will
|
||
|
* search the node to locate the index of the required key
|
||
|
* (& mask) to modify.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_size Key size of the one to modify.
|
||
|
* @Param[in] p_key A pointer to the requested key to modify
|
||
|
* @Param[in] p_mask A pointer to the mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
* @Param[in] p_key_params A pointer to the parameters includes
|
||
|
* modified key and modified Next Engine
|
||
|
* Params
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
* When configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_find_nmodify_key_and_next_engine(t_handle h_cc_node,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask,
|
||
|
ioc_fm_pcd_cc_key_params_t *p_key_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_find_nmodify_key
|
||
|
*
|
||
|
* @Description Modify the key in the index defined by the key_index. Note
|
||
|
* that this routine will search the node to locate the index of
|
||
|
* the required key (& mask) to modify.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_size Key size of the one to modify.
|
||
|
* @Param[in] p_key A pointer to the requested key to modify.
|
||
|
* @Param[in] p_mask A pointer to the mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
* @Param[in] p_new_key A pointer to the new key
|
||
|
* @Param[in] p_new_mask A pointer to the new mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set() was called for
|
||
|
* this node and the nodes that lead to it.
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_find_nmodify_key(t_handle h_cc_node,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask,
|
||
|
uint8_t *p_new_key,
|
||
|
uint8_t *p_new_mask);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_key_counter
|
||
|
*
|
||
|
* @Description This routine may be used to get a counter of specific key in a
|
||
|
* CC Node; This counter reflects how many frames passed that
|
||
|
* were matched this key.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding
|
||
|
*
|
||
|
* @Return The specific key counter.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_get_key_counter(t_handle h_cc_node,
|
||
|
uint16_t key_index);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_key_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of
|
||
|
* specific key in a CC Node.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames passed that were
|
||
|
* matched this key; The total frames count will be returned in
|
||
|
* the counter of the first range (as only one frame length range
|
||
|
* was defined). If 'e_FM_PCD_CC_STATS_MODE_RMON' was set for
|
||
|
* this node, the total frame count will be separated to frame
|
||
|
* length counters, based on provided frame length ranges.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_index Key index for adding
|
||
|
* @Param[out] p_key_statistics Key statistics counters
|
||
|
*
|
||
|
* @Return The specific key statistics.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_get_key_statistics(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
ioc_fm_pcd_cc_key_statistics_t *p_key_statistics);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_miss_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of miss
|
||
|
* entry in a CC Node.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames were not matched
|
||
|
* to any existing key and therefore passed through the miss
|
||
|
* entry; The total frames count will be returned in the counter
|
||
|
* of the first range (as only one frame length range was
|
||
|
* defined).
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[out] p_miss_statistics Statistics counters for 'miss'
|
||
|
*
|
||
|
* @Return The statistics for 'miss'.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_get_miss_statistics(t_handle h_cc_node,
|
||
|
ioc_fm_pcd_cc_key_statistics_t *p_miss_statistics);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_find_nget_key_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of
|
||
|
* specific key in a CC Node.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames passed that were
|
||
|
* matched this key; The total frames count will be returned in
|
||
|
* the counter of the first range (as only one frame length range
|
||
|
* was defined). If 'e_FM_PCD_CC_STATS_MODE_RMON' was set for
|
||
|
* this node, the total frame count will be separated to frame
|
||
|
* length counters, based on provided frame length ranges.
|
||
|
* Note that this routine will search the node to locate the
|
||
|
* index of the required key based on received key parameters.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node
|
||
|
* @Param[in] key_size Size of the requested key
|
||
|
* @Param[in] p_key A pointer to the requested key
|
||
|
* @Param[in] p_mask A pointer to the mask if relevant,
|
||
|
* otherwise pointer to NULL
|
||
|
* @Param[out] p_key_statistics Key statistics counters
|
||
|
*
|
||
|
* @Return The specific key statistics.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_match_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_find_nget_key_statistics(t_handle h_cc_node,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
uint8_t *p_mask,
|
||
|
ioc_fm_pcd_cc_key_statistics_t *p_key_statistics);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_next_engine
|
||
|
*
|
||
|
* @Description Gets NextEngine of the relevant key_index.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node.
|
||
|
* @Param[in] key_index key_index in the
|
||
|
* relevant node.
|
||
|
* @Param[out] p_fm_pcd_cc_next_engine_params here updated
|
||
|
* nextEngine parameters
|
||
|
* for the relevant
|
||
|
* key_index of the CC Node
|
||
|
* received as parameter to
|
||
|
* this function
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_get_next_engine(t_handle h_cc_node,
|
||
|
uint16_t key_index,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_match_table_get_indexed_hash_bucket
|
||
|
*
|
||
|
* @Description This routine simulates KeyGen operation on the provided key
|
||
|
* and calculates to which hash bucket it will be mapped.
|
||
|
*
|
||
|
* @Param[in] h_cc_node A handle to the node.
|
||
|
* @Param[in] kg_key_size Key size as it was configured in
|
||
|
* the KG scheme that leads to this
|
||
|
* hash.
|
||
|
* @Param[in] p_kg_key Pointer to the key; must be like
|
||
|
* the key that the KG is
|
||
|
* generated, i.e. the same
|
||
|
* extraction and with mask if
|
||
|
* exist.
|
||
|
* @Param[in] kg_hash_shift Hash-shift as it was configured
|
||
|
* in the KG scheme that leads to
|
||
|
* this hash.
|
||
|
* @Param[out] p_cc_node_bucket_handle Pointer to the bucket of the
|
||
|
* provided key.
|
||
|
* @Param[out] p_bucket_index Index to the bucket of the
|
||
|
* provided key
|
||
|
* @Param[out] p_last_index Pointer to last index in the
|
||
|
* bucket of the provided key.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set()
|
||
|
*/
|
||
|
uint32_t fm_pcd_match_table_get_indexed_hash_bucket(t_handle h_cc_node,
|
||
|
uint8_t kg_key_size,
|
||
|
uint8_t *p_kg_key,
|
||
|
uint8_t kg_hash_shift,
|
||
|
t_handle *p_cc_node_bucket_handle,
|
||
|
uint8_t *p_bucket_index,
|
||
|
uint16_t *p_last_index);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_set
|
||
|
*
|
||
|
* @Description This routine initializes a hash table structure.
|
||
|
* KeyGen hash result determines the hash bucket.
|
||
|
* Next, KeyGen key is compared against all keys of this bucket
|
||
|
* (exact match).
|
||
|
* Number of sets (number of buckets) of the hash equals to the
|
||
|
* number of 1-s in 'hashResMask' in the provided parameters.
|
||
|
* Number of hash table ways is then calculated by dividing
|
||
|
* 'max_num_of_keys' equally between the hash sets. This is the
|
||
|
* maximal number of keys that a hash bucket may hold.
|
||
|
* The hash table is initialized empty and keys may be added to
|
||
|
* it following the initialization. Keys masks are not supported
|
||
|
* in current hash table implementation.
|
||
|
* The initialized hash table can be integrated as a node in a CC
|
||
|
* tree.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_param A structure of parameters defining the hash
|
||
|
* table
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_hash_table_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_hash_table_params_t *p_param);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_delete
|
||
|
*
|
||
|
* @Description This routine deletes the provided hash table and released all
|
||
|
* its allocated resources.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_delete(t_handle h_hash_tbl);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_add_key
|
||
|
*
|
||
|
* @Description This routine adds the provided key (including next engine
|
||
|
* parameters of this key) to the hash table.
|
||
|
* The key is added as the last key of the bucket that it is
|
||
|
* mapped to.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[in] key_size Key size of added key
|
||
|
* @Param[in] p_key_params A pointer to the parameters includes
|
||
|
* new key with next engine parameters; The pointer
|
||
|
* to the key mask must be NULL, as masks are not
|
||
|
* supported in hash table implementation.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_add_key(t_handle h_hash_tbl,
|
||
|
uint8_t key_size,
|
||
|
ioc_fm_pcd_cc_key_params_t *p_key_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_remove_key
|
||
|
*
|
||
|
* @Description This routine removes the requested key (including next engine
|
||
|
* parameters of this key) from the hash table.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[in] key_size Key size of the one to remove.
|
||
|
* @Param[in] p_key A pointer to the requested key to remove.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_remove_key(t_handle h_hash_tbl,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_modify_next_engine
|
||
|
*
|
||
|
* @Description This routine modifies the next engine for the provided key.
|
||
|
* The key should be previously added to the hash table.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[in] key_size Key size of the key to modify.
|
||
|
* @Param[in] p_key A pointer to the requested key
|
||
|
* to modify.
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine A structure for defining
|
||
|
* new next engine parameters.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
* When configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_modify_next_engine(t_handle h_hash_tbl,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_modify_miss_next_engine
|
||
|
*
|
||
|
* @Description This routine modifies the next engine on key match miss.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[in] p_fm_pcd_cc_next_engine A structure for defining
|
||
|
* new next engine parameters.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
* When configuring nextEngine = e_FM_PCD_CC, note that
|
||
|
* p_fm_pcd_cc_next_engine_params->ccParams.h_cc_node must be
|
||
|
* different from the currently changed table.
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_modify_miss_next_engine(t_handle h_hash_tbl,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_get_miss_next_engine
|
||
|
*
|
||
|
* @Description Gets NextEngine in case of key match miss.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[out] p_fm_pcd_cc_next_engine_params Next engine parameters
|
||
|
* for the specified hash
|
||
|
* table.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_get_miss_next_engine(t_handle h_hash_tbl,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_fm_pcd_cc_next_engine_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_find_nget_key_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of
|
||
|
* specific key in a hash table.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames passed that were
|
||
|
* matched this key; The total frames count will be returned in
|
||
|
* the counter of the first range (as only one frame length range
|
||
|
* was defined). If 'e_FM_PCD_CC_STATS_MODE_RMON' was set for
|
||
|
* this node, the total frame count will be separated to frame
|
||
|
* length counters, based on provided frame length ranges. Note
|
||
|
* that this routine will identify the bucket of this key in the
|
||
|
* hash table and will search the bucket to locate the index of
|
||
|
* the required key based on received key parameters.
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[in] key_size Size of the requested key
|
||
|
* @Param[in] p_key A pointer to the requested key
|
||
|
* @Param[out] p_key_statistics Key statistics counters
|
||
|
*
|
||
|
* @Return The specific key statistics.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_find_nget_key_statistics(t_handle h_hash_tbl,
|
||
|
uint8_t key_size,
|
||
|
uint8_t *p_key,
|
||
|
ioc_fm_pcd_cc_key_statistics_t *p_key_statistics);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_hash_table_get_miss_statistics
|
||
|
*
|
||
|
* @Description This routine may be used to get statistics counters of 'miss'
|
||
|
* entry of the a hash table.
|
||
|
*
|
||
|
* If 'e_FM_PCD_CC_STATS_MODE_FRAME' and
|
||
|
* 'e_FM_PCD_CC_STATS_MODE_BYTE_AND_FRAME' were set for this
|
||
|
* node, these counters reflect how many frames were not matched
|
||
|
* to any existing key and therefore passed through the miss
|
||
|
* entry;
|
||
|
*
|
||
|
* @Param[in] h_hash_tbl A handle to a hash table
|
||
|
* @Param[out] p_miss_statistics Statistics counters for 'miss'
|
||
|
*
|
||
|
* @Return The statistics for 'miss'.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_hash_table_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_hash_table_get_miss_statistics(t_handle h_hash_tbl,
|
||
|
ioc_fm_pcd_cc_key_statistics_t *p_miss_statistics);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_set
|
||
|
*
|
||
|
* @Description This routine should be called for defining a manipulation
|
||
|
* node. A manipulation node must be defined before the CC node
|
||
|
* that precedes it.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_fm_pcd_manip_params A structure of parameters
|
||
|
* defining the manipulation
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_manip_node_set(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_manip_params_t *p_fm_pcd_manip_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_delete
|
||
|
*
|
||
|
* @Description Delete an existing manipulation node.
|
||
|
*
|
||
|
* @Param[in] h_manip_node A handle to a manipulation node.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_manip_node_delete(t_handle h_manip_node);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_get_statistics
|
||
|
*
|
||
|
* @Description Retrieve the manipulation statistics.
|
||
|
*
|
||
|
* @Param[in] h_manip_node A handle to a manipulation node.
|
||
|
* @Param[out] p_fm_pcd_manip_stats A structure for retrieving the
|
||
|
* manipulation statistics
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_manip_get_statistics(t_handle h_manip_node,
|
||
|
ioc_fm_pcd_manip_stats_t *p_fm_pcd_manip_stats);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_manip_node_replace
|
||
|
*
|
||
|
* @Description Change existing manipulation node to be according to new
|
||
|
* requirement.
|
||
|
*
|
||
|
* @Param[in] h_manip_node A handle to a manipulation node.
|
||
|
* @Param[out] p_manip_params A structure of parameters defining the
|
||
|
* change requirement
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_manip_node_set().
|
||
|
*/
|
||
|
uint32_t fm_pcd_manip_node_replace(t_handle h_manip_node,
|
||
|
ioc_fm_pcd_manip_params_t *p_manip_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_set_group
|
||
|
*
|
||
|
* @Description Initialize a Frame Replicator group.
|
||
|
*
|
||
|
* @Param[in] h_fm_pcd FM PCD module descriptor.
|
||
|
* @Param[in] p_frm_replic_group_param A structure of parameters for
|
||
|
* the initialization of the frame
|
||
|
* replicator group.
|
||
|
*
|
||
|
* @Return A handle to the initialized object on success; NULL code
|
||
|
* otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_init().
|
||
|
*/
|
||
|
t_handle fm_pcd_frm_replic_set_group(t_handle h_fm_pcd,
|
||
|
ioc_fm_pcd_frm_replic_group_params_t *p_frm_replic_group_param);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_delete_group
|
||
|
*
|
||
|
* @Description Delete a Frame Replicator group.
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group().
|
||
|
*/
|
||
|
uint32_t fm_pcd_frm_replic_delete_group(t_handle h_frm_replic_group);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_add_member
|
||
|
*
|
||
|
* @Description Add the member in the index defined by the member_index.
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
* @Param[in] member_index member index for adding.
|
||
|
* @Param[in] p_member_params A pointer to the new member parameters.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group() of this
|
||
|
* group.
|
||
|
*/
|
||
|
uint32_t fm_pcd_frm_replic_add_member(t_handle h_frm_replic_group,
|
||
|
uint16_t member_index,
|
||
|
ioc_fm_pcd_cc_next_engine_params_t *p_member_params);
|
||
|
|
||
|
/*
|
||
|
* @Function fm_pcd_frm_replic_remove_member
|
||
|
*
|
||
|
* @Description Remove the member defined by the index from the relevant
|
||
|
* group.
|
||
|
*
|
||
|
* @Param[in] h_frm_replic_group A handle to the frame replicator group.
|
||
|
* @Param[in] member_index member index for removing.
|
||
|
*
|
||
|
* @Return E_OK on success; Error code otherwise.
|
||
|
*
|
||
|
* @Cautions Allowed only following fm_pcd_frm_replic_set_group() of this
|
||
|
* group.
|
||
|
*/
|
||
|
uint32_t fm_pcd_frm_replic_remove_member(t_handle h_frm_replic_group,
|
||
|
uint16_t member_index);
|
||
|
|
||
|
/** @} */ /* end of FM_PCD_Runtime_build_grp group */
|
||
|
/** @} */ /* end of FM_PCD_Runtime_grp group */
|
||
|
/** @} */ /* end of FM_PCD_grp group */
|
||
|
/** @} */ /* end of FM_grp group */
|
||
|
|
||
|
#endif /* __FM_PCD_EXT_H */
|