X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fplugins%2Fikev2%2Fikev2_priv.h;h=7609166cb6af65fe4e0133426b79928ba6155e74;hb=b29d523af039ac007238300a7316ba9e3e44ce25;hp=630ba1ba35146f7e4ba229307d0d986a315c7b79;hpb=4c6b1b6da5d884c80363aeba75bc318a06e29031;p=vpp.git diff --git a/src/plugins/ikev2/ikev2_priv.h b/src/plugins/ikev2/ikev2_priv.h index 630ba1ba351..7609166cb6a 100644 --- a/src/plugins/ikev2/ikev2_priv.h +++ b/src/plugins/ikev2/ikev2_priv.h @@ -30,13 +30,173 @@ #include #include -#define IKEV2_DEBUG_PAYLOAD 1 +#define foreach_ikev2_log_level \ + _(0x00, LOG_NONE) \ + _(0x01, LOG_ERROR) \ + _(0x02, LOG_WARNING) \ + _(0x03, LOG_INFO) \ + _(0x04, LOG_DEBUG) \ + _(0x05, LOG_DETAIL) \ -#if IKEV2_DEBUG_PAYLOAD == 1 -#define DBG_PLD(my_args...) clib_warning(my_args) -#else -#define DBG_PLD(my_args...) -#endif + +typedef enum ikev2_log_level_t_ +{ +#define _(n,f) IKEV2_##f = n, + foreach_ikev2_log_level +#undef _ + IKEV2_LOG_MAX +} ikev2_log_level_t; + +/* dataplane logging */ +#define _ikev2_elog(_level, _msg) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= _level)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2 " _msg, \ + .format_args = "", \ + }; \ + ELOG_DATA (&vlib_global_main.elog_main, e); \ + } \ +} while (0) + +#define ikev2_elog_sa_state(_format, _ispi) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= IKEV2_LOG_DEBUG)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2: " _format, \ + .format_args = "i8", \ + }; \ + CLIB_PACKED(struct \ + { \ + u64 ispi; \ + }) *ed; \ + ed = ELOG_DATA (&vlib_global_main.elog_main, e); \ + ed->ispi = _ispi; \ + } \ +} while (0) \ + +#define ikev2_elog_exchange(_format, _ispi, _rspi, _addr) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= IKEV2_LOG_DEBUG)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2: " _format, \ + .format_args = "i8i8i1i1i1i1", \ + }; \ + CLIB_PACKED(struct \ + { \ + u64 ispi; \ + u64 rspi; \ + u8 oct1; \ + u8 oct2; \ + u8 oct3; \ + u8 oct4; \ + }) *ed; \ + ed = ELOG_DATA (&vlib_global_main.elog_main, e); \ + ed->ispi = _ispi; \ + ed->rspi = _rspi; \ + ed->oct4 = (_addr) >> 24; \ + ed->oct3 = (_addr) >> 16; \ + ed->oct2 = (_addr) >> 8; \ + ed->oct1 = (_addr); \ + } \ +} while (0) \ + +#define ikev2_elog_uint(_level, _format, _val) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= _level)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2: " _format, \ + .format_args = "i8", \ + }; \ + CLIB_PACKED(struct \ + { \ + u64 val; \ + }) *ed; \ + ed = ELOG_DATA (&vlib_global_main.elog_main, e); \ + ed->val = _val; \ + } \ +} while (0) + +#define ikev2_elog_uint_peers(_level, _format, _val, _ip1, _ip2) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= _level)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2: " _format, \ + .format_args = "i8i1i1i1i1i1i1i1i1", \ + }; \ + CLIB_PACKED(struct { \ + u64 val; \ + u8 i11; u8 i12; u8 i13; u8 i14; \ + u8 i21; u8 i22; u8 i23; u8 i24; }) *ed; \ + ed = ELOG_DATA (&vlib_global_main.elog_main, e); \ + ed->val = _val; \ + ed->i14 = (_ip1) >> 24; \ + ed->i13 = (_ip1) >> 16; \ + ed->i12 = (_ip1) >> 8; \ + ed->i11 = (_ip1); \ + ed->i24 = (_ip2) >> 24; \ + ed->i23 = (_ip2) >> 16; \ + ed->i22 = (_ip2) >> 8; \ + ed->i21 = (_ip2); \ + } \ +} while (0) + +#define ikev2_elog_peers(_level, _format, _ip1, _ip2) \ +do { \ + ikev2_main_t *km = &ikev2_main; \ + if (PREDICT_FALSE (km->log_level >= _level)) \ + { \ + ELOG_TYPE_DECLARE (e) = \ + { \ + .format = "ikev2: " _format, \ + .format_args = "i1i1i1i1i1i1i1i1", \ + }; \ + CLIB_PACKED(struct { \ + u8 i11; u8 i12; u8 i13; u8 i14; \ + u8 i21; u8 i22; u8 i23; u8 i24; }) *ed; \ + ed = ELOG_DATA (&vlib_global_main.elog_main, e); \ + ed->i14 = (_ip1) >> 24; \ + ed->i13 = (_ip1) >> 16; \ + ed->i12 = (_ip1) >> 8; \ + ed->i11 = (_ip1); \ + ed->i24 = (_ip2) >> 24; \ + ed->i23 = (_ip2) >> 16; \ + ed->i22 = (_ip2) >> 8; \ + ed->i21 = (_ip2); \ + } \ +} while (0) + +#define ikev2_elog_error(_msg) \ + _ikev2_elog(IKEV2_LOG_ERROR, "[error] " _msg) +#define ikev2_elog_warning(_msg) \ + _ikev2_elog(IKEV2_LOG_WARNING, "[warning] " _msg) +#define ikev2_elog_debug(_msg) \ + _ikev2_elog(IKEV2_LOG_DEBUG, "[debug] " _msg) +#define ikev2_elog_detail(_msg) \ + _ikev2_elog(IKEV2_LOG_DETAIL, "[detail] " _msg) + +/* logging for main thread */ +#define ikev2_log_error(...) \ + vlib_log(VLIB_LOG_LEVEL_ERR, ikev2_main.log_class, __VA_ARGS__) +#define ikev2_log_warning(...) \ + vlib_log(VLIB_LOG_LEVEL_WARNING, ikev2_main.log_class, __VA_ARGS__) +#define ikev2_log_debug(...) \ + vlib_log(VLIB_LOG_LEVEL_DEBUG, ikev2_main.log_class, __VA_ARGS__) typedef enum { @@ -198,6 +358,9 @@ typedef struct u64 lifetime_maxdata; u32 lifetime_jitter; u32 handover; + + u32 tun_itf; + u8 udp_encap; } ikev2_profile_t; typedef struct @@ -258,6 +421,14 @@ typedef struct u32 last_init_msg_id; u8 is_profile_index_set; u32 profile_index; + u8 is_tun_itf_set; + u32 tun_itf; + u8 udp_encap; + + f64 old_id_expiration; + u32 current_remote_id_mask; + u32 old_remote_id; + u8 old_remote_id_present; ikev2_child_sa_t *childs; } ikev2_sa_t; @@ -302,6 +473,12 @@ typedef struct /* API message ID base */ u16 msg_id_base; + + /* log class used for main thread */ + vlib_log_class_t log_class; + + /* logging level */ + ikev2_log_level_t log_level; } ikev2_main_t; extern ikev2_main_t ikev2_main; @@ -361,7 +538,7 @@ ikev2_sa_proposal_t *ikev2_parse_sa_payload (ike_payload_header_t * ikep); ikev2_ts_t *ikev2_parse_ts_payload (ike_payload_header_t * ikep); ikev2_delete_t *ikev2_parse_delete_payload (ike_payload_header_t * ikep); ikev2_notify_t *ikev2_parse_notify_payload (ike_payload_header_t * ikep); - +int ikev2_set_log_level (ikev2_log_level_t log_level); #endif /* __included_ikev2_priv_h__ */