/* * Copyright (c) 2015 Cisco and/or its affiliates. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef included_vlib_parse_h #define included_vlib_parse_h #include #include #include typedef struct { /* Word aligned value. */ union { u8 as_u8[32 - 1 * sizeof (u16)]; void *as_pointer; uword as_uword; word as_word; u64 as_u64; } value; /* 16 bit type at end so that 30 bytes of value are aligned. */ u16 type; } __attribute ((packed)) vlib_parse_value_t; /* Instance of a type. */ typedef struct { u32 type; u32 origin; u32 help_index; union { void * as_pointer; uword as_uword; } value; } vlib_parse_item_t; typedef struct { /* Index of item for this node. */ u32 item; /* Graph index of peer (sibling) node (linked list of peers). */ u32 peer; /* Graph index of deeper (child) node (linked list of children). */ u32 deeper; } vlib_parse_graph_t; #define foreach_parse_match_type \ _(MATCH_DONE) \ _(MATCH_RULE) \ _(MATCH_FAIL) \ _(MATCH_FULL) \ _(MATCH_VALUE) \ _(MATCH_PARTIAL) \ _(MATCH_AMBIGUOUS) \ _(MATCH_EVAL_FAIL) typedef enum { #define _(a) VLIB_PARSE_##a, foreach_parse_match_type #undef _ } vlib_parse_match_t; struct vlib_parse_type; struct vlib_parse_main; typedef vlib_parse_match_t (vlib_parse_match_function_t) (struct vlib_parse_main *, struct vlib_parse_type *, vlib_lex_token_t *, vlib_parse_value_t *); typedef void (vlib_parse_value_cleanup_function_t) (vlib_parse_value_t *); typedef struct vlib_parse_type { /* Type name. */ char * name; vlib_parse_match_function_t * match_function; vlib_parse_value_cleanup_function_t * value_cleanup_function; format_function_t * format_value; u32 rule_index; } vlib_parse_type_t; typedef struct { char * initializer; void * eof_match; int rule_length; } parse_registration_t; typedef struct vlib_parse_main { /* (type, origin, help, value) tuples */ vlib_parse_item_t * parse_items; mhash_t parse_item_hash; /* (item, peer, deeper) tuples */ vlib_parse_graph_t * parse_graph; u32 root_index; u8 * register_input; /* parser types */ vlib_parse_type_t * parse_types; uword * parse_type_by_name_hash; /* Vector of MATCH_VALUEs */ vlib_parse_value_t * parse_value; u32 * match_items; /* Parse registrations */ parse_registration_t ** parse_registrations; /* Token vector */ vlib_lex_token_t * tokens; u32 current_token_index; vlib_lex_main_t * lex_main; vlib_main_t * vlib_main; } vlib_parse_main_t; vlib_parse_main_t vlib_parse_main; typedef vlib_parse_match_t (vlib_parse_eval_function_t) (vlib_parse_main_t *, vlib_parse_item_t *, vlib_parse_value_t *); vlib_parse_match_t vlib_parse_eval (u8 * input); format_function_t format_vlib_parse_value; /* FIXME need these to be global? */ vlib_parse_match_function_t rule_match, eof_match, word_match, number_match; #define _PARSE_REGISTRATION_DATA(x) \ VLIB_ELF_SECTION_DATA(x##_registration,parse_registration_t,parse_registrations) #define PARSE_INIT(x, s, e) \ static _PARSE_REGISTRATION_DATA(x) = { \ .initializer = s, \ .eof_match = e, \ }; #define _PARSE_TYPE_REGISTRATION_DATA(x) \ VLIB_ELF_SECTION_DATA(x##_type_registration,vlib_parse_type_t, \ parse_type_registrations) #define PARSE_TYPE_INIT(n, m, c, f) \ static _PARSE_TYPE_REGISTRATION_DATA(n) = { \ .name = #n, \ .match_function = m, \ .value_cleanup_function = c, \ .format_value = f, \ }; #endif /* included_vlib_parse_h */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */