7#ifndef _RTE_REGEXDEV_H_
8#define _RTE_REGEXDEV_H_
205#define RTE_REGEXDEV_NAME_MAX_LEN RTE_DEV_NAME_MAX_LEN
207extern int rte_regexdev_logtype;
209#define RTE_REGEXDEV_LOG(level, ...) \
210 rte_log(RTE_LOG_ ## level, rte_regexdev_logtype, "" __VA_ARGS__)
213#define RTE_REGEXDEV_VALID_DEV_ID_OR_ERR_RET(dev_id, retval) do { \
214 if (!rte_regexdev_is_valid_dev(dev_id)) { \
215 RTE_REGEXDEV_LOG(ERR, "Invalid dev_id=%u\n", dev_id); \
220#define RTE_REGEXDEV_VALID_DEV_ID_OR_RET(dev_id) do { \
221 if (!rte_regexdev_is_valid_dev(dev_id)) { \
222 RTE_REGEXDEV_LOG(ERR, "Invalid dev_id=%u\n", dev_id); \
275#define RTE_REGEXDEV_CAPA_RUNTIME_COMPILATION_F (1ULL << 0)
284#define RTE_REGEXDEV_CAPA_SUPP_PCRE_START_ANCHOR_F (1ULL << 1)
295#define RTE_REGEXDEV_CAPA_SUPP_PCRE_ATOMIC_GROUPING_F (1ULL << 2)
307#define RTE_REGEXDEV_SUPP_PCRE_BACKTRACKING_CTRL_F (1ULL << 3)
315#define RTE_REGEXDEV_SUPP_PCRE_CALLOUTS_F (1ULL << 4)
325#define RTE_REGEXDEV_SUPP_PCRE_BACKREFERENCE_F (1ULL << 5)
333#define RTE_REGEXDEV_SUPP_PCRE_GREEDY_F (1ULL << 6)
342#define RTE_REGEXDEV_SUPP_PCRE_MATCH_ALL_F (1ULL << 7)
351#define RTE_REGEXDEV_SUPP_PCRE_LOOKAROUND_ASRT_F (1ULL << 8)
361#define RTE_REGEXDEV_SUPP_PCRE_MATCH_POINT_RST_F (1ULL << 9)
370#define RTE_REGEXDEV_SUPP_NEWLINE_CONVENTIONS_F (1ULL << 10)
382#define RTE_REGEXDEV_SUPP_PCRE_NEWLINE_SEQ_F (1ULL << 11)
390#define RTE_REGEXDEV_SUPP_PCRE_POSSESSIVE_QUALIFIERS_F (1ULL << 12)
400#define RTE_REGEXDEV_SUPP_PCRE_SUBROUTINE_REFERENCES_F (1ULL << 13)
409#define RTE_REGEXDEV_SUPP_PCRE_UTF_8_F (1ULL << 14)
415#define RTE_REGEXDEV_SUPP_PCRE_UTF_16_F (1ULL << 15)
421#define RTE_REGEXDEV_SUPP_PCRE_UTF_32_F (1ULL << 16)
427#define RTE_REGEXDEV_SUPP_PCRE_WORD_BOUNDARY_F (1ULL << 17)
434#define RTE_REGEXDEV_SUPP_PCRE_FORWARD_REFERENCES_F (1ULL << 18)
443#define RTE_REGEXDEV_SUPP_MATCH_AS_END_F (1ULL << 19)
453#define RTE_REGEXDEV_SUPP_CROSS_BUFFER_F (1ULL << 20)
469#define RTE_REGEXDEV_SUPP_MATCH_ALL_F (1ULL << 21)
478#define RTE_REGEXDEV_CAPA_QUEUE_PAIR_OOS_F (1ULL << 22)
488#define RTE_REGEX_PCRE_RULE_ALLOW_EMPTY_F (1ULL << 0)
496#define RTE_REGEX_PCRE_RULE_ANCHORED_F (1ULL << 1)
505#define RTE_REGEX_PCRE_RULE_CASELESS_F (1ULL << 2)
513#define RTE_REGEX_PCRE_RULE_DOTALL_F (1ULL << 3)
521#define RTE_REGEX_PCRE_RULE_DUPNAMES_F (1ULL << 4)
529#define RTE_REGEX_PCRE_RULE_EXTENDED_F (1ULL << 5)
537#define RTE_REGEX_PCRE_RULE_MATCH_UNSET_BACKREF_F (1ULL << 6)
545#define RTE_REGEX_PCRE_RULE_MULTILINE_F (1ULL << 7)
554#define RTE_REGEX_PCRE_RULE_NO_AUTO_CAPTURE_F (1ULL << 8)
564#define RTE_REGEX_PCRE_RULE_UCP_F (1ULL << 9)
572#define RTE_REGEX_PCRE_RULE_UNGREEDY_F (1ULL << 10)
581#define RTE_REGEX_PCRE_RULE_UTF_F (1ULL << 11)
590#define RTE_REGEX_PCRE_RULE_NEVER_BACKSLASH_C_F (1ULL << 12)
651#define RTE_REGEXDEV_CFG_CROSS_BUFFER_SCAN_F (1ULL << 0)
664#define RTE_REGEXDEV_CFG_MATCH_AS_END_F (1ULL << 1)
674#define RTE_REGEXDEV_CFG_MATCH_ALL_F (1ULL << 2)
750#define RTE_REGEX_QUEUE_PAIR_CFG_OOS_F (1ULL << 0)
944 const void *attr_value);
1060 uint32_t rule_db_len);
1088#define RTE_REGEXDEV_XSTATS_NAME_SIZE 64
1152 uint64_t *values, uint16_t nb_values);
1179 uint16_t *
id, uint64_t *value);
1277#define RTE_REGEX_OPS_REQ_GROUP_ID0_VALID_F (1 << 0)
1280#define RTE_REGEX_OPS_REQ_GROUP_ID1_VALID_F (1 << 1)
1283#define RTE_REGEX_OPS_REQ_GROUP_ID2_VALID_F (1 << 2)
1286#define RTE_REGEX_OPS_REQ_GROUP_ID3_VALID_F (1 << 3)
1289#define RTE_REGEX_OPS_REQ_STOP_ON_MATCH_F (1 << 4)
1292#define RTE_REGEX_OPS_REQ_MATCH_HIGH_PRIORITY_F (1 << 5)
1304#define RTE_REGEX_OPS_RSP_PMI_SOJ_F (1 << 0)
1311#define RTE_REGEX_OPS_RSP_PMI_EOJ_F (1 << 1)
1318#define RTE_REGEX_OPS_RSP_MAX_SCAN_TIMEOUT_F (1 << 2)
1325#define RTE_REGEX_OPS_RSP_MAX_MATCH_F (1 << 3)
1332#define RTE_REGEX_OPS_RSP_MAX_PREFIX_F (1 << 4)
1339#define RTE_REGEX_OPS_RSP_RESOURCE_LIMIT_REACHED_F (1 << 4)
1471static inline uint16_t
1475 struct rte_regexdev *dev = &rte_regex_devices[dev_id];
1476#ifdef RTE_LIBRTE_REGEXDEV_DEBUG
1477 RTE_REGEXDEV_VALID_DEV_ID_OR_ERR_RET(dev_id, -EINVAL);
1478 if (*dev->enqueue == NULL)
1480 if (qp_id >= dev->data->dev_conf.nb_queue_pairs) {
1481 RTE_REGEXDEV_LOG(ERR,
"Invalid queue %d\n", qp_id);
1485 return (*dev->enqueue)(dev, qp_id, ops, nb_ops);
1531static inline uint16_t
1535 struct rte_regexdev *dev = &rte_regex_devices[dev_id];
1536#ifdef RTE_LIBRTE_REGEXDEV_DEBUG
1537 RTE_REGEXDEV_VALID_DEV_ID_OR_ERR_RET(dev_id, -EINVAL);
1538 if (*dev->dequeue == NULL)
1540 if (qp_id >= dev->data->dev_conf.nb_queue_pairs) {
1541 RTE_REGEXDEV_LOG(ERR,
"Invalid queue %d\n", qp_id);
1545 return (*dev->dequeue)(dev, qp_id, ops, nb_ops);
__rte_experimental int rte_regexdev_rule_db_compile_activate(uint8_t dev_id)
__rte_experimental int rte_regexdev_close(uint8_t dev_id)
__rte_experimental uint8_t rte_regexdev_count(void)
__rte_experimental int rte_regexdev_get_dev_id(const char *name)
__rte_experimental int rte_regexdev_info_get(uint8_t dev_id, struct rte_regexdev_info *dev_info)
__rte_experimental int rte_regexdev_dump(uint8_t dev_id, FILE *f)
__rte_experimental int rte_regexdev_stop(uint8_t dev_id)
__rte_experimental int rte_regexdev_queue_pair_setup(uint8_t dev_id, uint16_t queue_pair_id, const struct rte_regexdev_qp_conf *qp_conf)
static __rte_experimental uint16_t rte_regexdev_enqueue_burst(uint8_t dev_id, uint16_t qp_id, struct rte_regex_ops **ops, uint16_t nb_ops)
@ RTE_REGEXDEV_ATTR_MAX_PREFIX
@ RTE_REGEXDEV_ATTR_SOCKET_ID
@ RTE_REGEXDEV_ATTR_MAX_SCAN_TIMEOUT
@ RTE_REGEXDEV_ATTR_MAX_MATCHES
__rte_experimental int rte_regexdev_selftest(uint8_t dev_id)
__rte_experimental int rte_regexdev_xstats_reset(uint8_t dev_id, const uint16_t *ids, uint16_t nb_ids)
__rte_experimental int rte_regexdev_xstats_names_get(uint8_t dev_id, struct rte_regexdev_xstats_map *xstats_map)
__rte_experimental int rte_regexdev_xstats_get(uint8_t dev_id, const uint16_t *ids, uint64_t *values, uint16_t nb_values)
__rte_experimental int rte_regexdev_xstats_by_name_get(uint8_t dev_id, const char *name, uint16_t *id, uint64_t *value)
__rte_experimental int rte_regexdev_rule_db_export(uint8_t dev_id, char *rule_db)
__rte_experimental int rte_regexdev_is_valid_dev(uint16_t dev_id)
__rte_experimental int rte_regexdev_rule_db_import(uint8_t dev_id, const char *rule_db, uint32_t rule_db_len)
void(* regexdev_stop_flush_t)(uint8_t dev_id, uint16_t qp_id, struct rte_regex_ops *op)
__rte_experimental int rte_regexdev_attr_get(uint8_t dev_id, enum rte_regexdev_attr_id attr_id, void *attr_value)
__rte_experimental int rte_regexdev_rule_db_update(uint8_t dev_id, const struct rte_regexdev_rule *rules, uint32_t nb_rules)
@ RTE_REGEX_RULE_OP_REMOVE
static __rte_experimental uint16_t rte_regexdev_dequeue_burst(uint8_t dev_id, uint16_t qp_id, struct rte_regex_ops **ops, uint16_t nb_ops)
__rte_experimental int rte_regexdev_configure(uint8_t dev_id, const struct rte_regexdev_config *cfg)
__rte_experimental int rte_regexdev_attr_set(uint8_t dev_id, enum rte_regexdev_attr_id attr_id, const void *attr_value)
__rte_experimental int rte_regexdev_start(uint8_t dev_id)
#define RTE_REGEXDEV_XSTATS_NAME_SIZE
uint16_t nb_actual_matches
struct rte_regexdev_match matches[]
uint32_t nb_rules_per_group
uint32_t max_rules_per_group
uint16_t max_payload_size
enum rte_regexdev_rule_op op
char name[RTE_REGEXDEV_XSTATS_NAME_SIZE]