/* SPDX-License-Identifier: BSD-3-Clause * Copyright(c) 2020 Intel Corporation */ #ifndef __INCLUDE_RTE_SWX_TABLE_H__ #define __INCLUDE_RTE_SWX_TABLE_H__ #ifdef __cplusplus extern "C" { #endif /** * @file * RTE SWX Table * * Table interface. */ #include #include /** Match type. */ enum rte_swx_table_match_type { /** Wildcard Match (WM). */ RTE_SWX_TABLE_MATCH_WILDCARD, /** Longest Prefix Match (LPM). */ RTE_SWX_TABLE_MATCH_LPM, /** Exact Match (EM). */ RTE_SWX_TABLE_MATCH_EXACT, }; /** Table creation parameters. */ struct rte_swx_table_params { /** Table match type. */ enum rte_swx_table_match_type match_type; /** Key size in bytes. */ uint32_t key_size; /** Offset of the first byte of the key within the key buffer. */ uint32_t key_offset; /** Mask of *key_size* bytes logically laid over the bytes at positions * *key_offset* .. (*key_offset* + *key_size* - 1) of the key buffer in * order to specify which bits from the key buffer are part of the key * and which ones are not. A bit value of 1 in the *key_mask0* means the * respective bit in the key buffer is part of the key, while a bit * value of 0 means the opposite. A NULL value means that all the bits * are part of the key, i.e. the *key_mask0* is an all-ones mask. */ uint8_t *key_mask0; /** Maximum size (in bytes) of the action data. The data stored in the * table for each entry is equal to *action_data_size* plus 8 bytes, * which are used to store the action ID. */ uint32_t action_data_size; /** Maximum number of keys to be stored in the table together with their * associated data. */ uint32_t n_keys_max; }; /** Table entry. */ struct rte_swx_table_entry { /** Used to facilitate the membership of this table entry to a * linked list. */ TAILQ_ENTRY(rte_swx_table_entry) node; /** Key value for the current entry. Array of *key_size* bytes or NULL * if the *key_size* for the current table is 0. */ uint8_t *key; /** Key mask for the current entry. Array of *key_size* bytes that is * logically and'ed with *key_mask0* of the current table. A NULL value * means that all the key bits already enabled by *key_mask0* are part * of the key of the current entry. */ uint8_t *key_mask; /** Placeholder for a possible compressed version of the *key* and * *key_mask* of the current entry. Typically a hash signature, its main * purpose is to the linked list search operation. Should be ignored by * the API functions below. */ uint64_t key_signature; /** Action ID for the current entry. */ uint64_t action_id; /** Action data for the current entry. Its size is defined by the action * specified by the *action_id*. It must be NULL when the action data * size of the *action_id* action is NULL. It must never exceed the * *action_data_size* of the table. */ uint8_t *action_data; }; /** List of table entries. */ TAILQ_HEAD(rte_swx_table_entry_list, rte_swx_table_entry); /** * Table memory footprint get * * @param[in] params * Table create parameters. * @param[in] entries * Table entries. * @param[in] args * Any additional table create arguments. It may be NULL. * @return * Table memory footprint in bytes, if successful, or zero, on error. */ typedef uint64_t (*rte_swx_table_footprint_get_t)(struct rte_swx_table_params *params, struct rte_swx_table_entry_list *entries, const char *args); /** * Table mailbox size get * * The mailbox is used to store the context of a lookup operation that is in * progress and it is passed as a parameter to the lookup operation. This allows * for multiple concurrent lookup operations into the same table. * * @return * Table memory footprint in bytes, on success, or zero, on error. */ typedef uint64_t (*rte_swx_table_mailbox_size_get_t)(void); /** * Table create * * @param[in] params * Table creation parameters. * @param[in] entries * Entries to be added to the table at creation time. * @param[in] args * Any additional table create arguments. It may be NULL. * @param[in] numa_node * Non-Uniform Memory Access (NUMA) node. * @return * Table handle, on success, or NULL, on error. */ typedef void * (*rte_swx_table_create_t)(struct rte_swx_table_params *params, struct rte_swx_table_entry_list *entries, const char *args, int numa_node); /** * Table entry add * * @param[in] table * Table handle. * @param[in] entry * Entry to be added to the table. * @return * 0 on success or the following error codes otherwise: * -EINVAL: Invalid table handle, entry or entry field; * -ENOSPC: Table full. */ typedef int (*rte_swx_table_add_t)(void *table, struct rte_swx_table_entry *entry); /** * Table entry delete * * @param[in] table * Table handle. * @param[in] entry * Entry to be deleted from the table. The entry *action_id* and *action_data* * fields are ignored. * @return * 0 on success or the following error codes otherwise: * -EINVAL: Invalid table handle, entry or entry field; * -ENOSPC: Table full. */ typedef int (*rte_swx_table_delete_t)(void *table, struct rte_swx_table_entry *entry); /** * Table lookup * * The table lookup operation searches a given key in the table and upon its * completion it returns an indication of whether the key is found in the table * (lookup hit) or not (lookup miss). In case of lookup hit, the action_id and * the action_data associated with the key are also returned. * * Multiple invocations of this function may be required in order to complete a * single table lookup operation for a given table and a given lookup key. The * completion of the table lookup operation is flagged by a return value of 1; * in case of a return value of 0, the function must be invoked again with * exactly the same arguments. * * The mailbox argument is used to store the context of an on-going table lookup * operation. The mailbox mechanism allows for multiple concurrent table lookup * operations into the same table. * * The typical reason an implementation may choose to split the table lookup * operation into multiple steps is to hide the latency of the inherent memory * read operations: before a read operation with the source data likely not in * the CPU cache, the source data prefetch is issued and the table lookup * operation is postponed in favor of some other unrelated work, which the CPU * executes in parallel with the source data being fetched into the CPU cache; * later on, the table lookup operation is resumed, this time with the source * data likely to be read from the CPU cache with no CPU pipeline stall, which * significantly improves the table lookup performance. * * @param[in] table * Table handle. * @param[in] mailbox * Mailbox for the current table lookup operation. * @param[in] key * Lookup key. Its size mult be equal to the table *key_size*. If the latter * is zero, then the lookup key must be NULL. * @param[out] action_id * ID of the action associated with the *key*. Must point to a valid 64-bit * variable. Only valid when the function returns 1 and *hit* is set to true. * @param[out] action_data * Action data for the *action_id* action. Must point to a valid array of * table *action_data_size* bytes. Only valid when the function returns 1 and * *hit* is set to true. * @param[out] hit * Only valid when the function returns 1. Set to non-zero (true) on table * lookup hit and to zero (false) on table lookup miss. * @return * 0 when the table lookup operation is not yet completed, and 1 when the * table lookup operation is completed. No other return values are allowed. */ typedef int (*rte_swx_table_lookup_t)(void *table, void *mailbox, uint8_t **key, uint64_t *action_id, uint8_t **action_data, int *hit); /** * Table free * * @param[in] table * Table handle. */ typedef void (*rte_swx_table_free_t)(void *table); /** Table operations. */ struct rte_swx_table_ops { /** Table memory footprint get. Set to NULL when not supported. */ rte_swx_table_footprint_get_t footprint_get; /** Table mailbox size get. When NULL, the mailbox size is 0. */ rte_swx_table_mailbox_size_get_t mailbox_size_get; /** Table create. Must be non-NULL. */ rte_swx_table_create_t create; /** Incremental table entry add. Set to NULL when not supported, in * which case the existing table has to be destroyed and a new table * built from scratch with the new entry included. */ rte_swx_table_add_t add; /** Incremental table entry delete. Set to NULL when not supported, in * which case the existing table has to be destroyed and a new table * built from scratch with the entry excluded. */ rte_swx_table_delete_t del; /** Table lookup. Must be non-NULL. */ rte_swx_table_lookup_t lkp; /** Table free. Must be non-NULL. */ rte_swx_table_free_t free; }; #ifdef __cplusplus } #endif #endif