#ifndef __TC_EMATCH_H_ #define __TC_EMATCH_H_ #include #include #include #include "utils.h" #include "tc_util.h" #define EMATCHKINDSIZ 16 struct bstr { char *data; unsigned int len; int quoted; struct bstr *next; }; extern struct bstr * bstr_alloc(const char *text); static inline struct bstr * bstr_new(char *data, unsigned int len) { struct bstr *b = calloc(1, sizeof(*b)); if (b == NULL) return NULL; b->data = data; b->len = len; return b; } static inline int bstrcmp(struct bstr *b, const char *text) { int len = strlen(text); int d = b->len - len; if (d == 0) return strncmp(b->data, text, len); return d; } static inline struct bstr *bstr_next(struct bstr *b) { return b->next; } extern unsigned long bstrtoul(const struct bstr *b); extern void bstr_print(FILE *fd, const struct bstr *b, int ascii); struct ematch { struct bstr *args; int index; int inverted; int relation; int child_ref; struct ematch *child; struct ematch *next; }; static inline struct ematch * new_ematch(struct bstr *args, int inverted) { struct ematch *e = calloc(1, sizeof(*e)); if (e == NULL) return NULL; e->args = args; e->inverted = inverted; return e; } extern void print_ematch_tree(const struct ematch *tree); struct ematch_util { char kind[EMATCHKINDSIZ]; int kind_num; int (*parse_eopt)(struct nlmsghdr *,struct tcf_ematch_hdr *, struct bstr *); int (*print_eopt)(FILE *, struct tcf_ematch_hdr *, void *, int); void (*print_usage)(FILE *); struct ematch_util *next; }; static inline int parse_layer(struct bstr *b) { if (*((char *) b->data) == 'l') return TCF_LAYER_LINK; else if (*((char *) b->data) == 'n') return TCF_LAYER_NETWORK; else if (*((char *) b->data) == 't') return TCF_LAYER_TRANSPORT; else return INT_MAX; } extern int em_parse_error(int err, struct bstr *args, struct bstr *carg, struct ematch_util *, char *fmt, ...); extern int print_ematch(FILE *, const struct rtattr *); extern int parse_ematch(int *, char ***, int, struct nlmsghdr *); #endif