X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvat%2Fvat.h;h=32de90e44117665bf8ecfa2df227c5049781e489;hb=04943b4c42db300d0d895644f32da79a6d411c51;hp=bcaddfe01267db2351c0e67e64d24424c335136a;hpb=053204ab039d34a990ff0e14c32ce3b294fcce0e;p=vpp.git diff --git a/src/vat/vat.h b/src/vat/vat.h index bcaddfe0126..32de90e4411 100644 --- a/src/vat/vat.h +++ b/src/vat/vat.h @@ -127,6 +127,8 @@ typedef struct u64 bytes; } ip6_nbr_counter_t; +struct vat_registered_features_t; + typedef struct { /* vpe input queue */ @@ -158,7 +160,7 @@ typedef struct uword *help_by_name; /* macro table */ - macro_main_t macro_main; + clib_macro_main_t macro_main; /* Errors by number */ uword *error_string_by_error_number; @@ -228,6 +230,8 @@ typedef struct elog_main_t elog_main; + struct vat_registered_features_t *feature_function_registrations; + /* Convenience */ vlib_main_t *vlib_main; } vat_main_t; @@ -267,6 +271,31 @@ void api_cli_output (void *, const char *fmt, ...); void fformat_append_cr (FILE *, const char *fmt, ...); #endif + +typedef clib_error_t *(vat_feature_function_t) (vat_main_t * vam); +typedef struct vat_registered_features_t +{ + vat_feature_function_t *function; + struct vat_registered_features_t *next; +} vat_registered_features_t; + + +#define VAT_REGISTER_FEATURE_FUNCTION(x) \ + vat_registered_features_t _vat_feature_function_##x; \ +static void __vlib_add_config_function_##x (void) \ + __attribute__((__constructor__)) ; \ +static void __vlib_add_config_function_##x (void) \ +{ \ + vat_main_t * vam = &vat_main; \ + _vat_feature_function_##x.next = vam->feature_function_registrations; \ + vam->feature_function_registrations = &_vat_feature_function_##x; \ +} \ + vat_registered_features_t _vat_feature_function_##x = \ + { \ + .function = x, \ + } + + #endif /* __included_vat_h__ */ /*