/* * Copyright (c) 2018 HUACHENTEL and/or its affiliates. * Copyright (c) 2018 PANTHEON.tech * 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 __SC_VPP_COMMM_H__ #define __SC_VPP_COMMM_H__ #include #include #include DEFINE_VAPI_MSG_IDS_VPE_API_JSON; #include #include #include //for SC_LOG_DBG extern vapi_mode_e g_vapi_mode; #define VPP_INTFC_NAME_LEN 64 #define VPP_TAPV2_NAME_LEN VPP_INTFC_NAME_LEN #define VPP_IP4_ADDRESS_LEN 4 #define VPP_IP6_ADDRESS_LEN 16 #define VPP_IP4_ADDRESS_STRING_LEN 16 #define VPP_IP6_ADDRESS_STRING_LEN 46 #define VPP_MAC_ADDRESS_LEN 8 #define VPP_TAG_LEN VPP_INTFC_NAME_LEN #define VPP_IKEV2_PROFILE_NAME_LEN VPP_INTFC_NAME_LEN #define VPP_IKEV2_PSK_LEN VPP_INTFC_NAME_LEN #define VPP_IKEV2_ID_LEN 32 #ifndef SC_THIS_FUNC #ifdef __FUNCTION__ #define SC_THIS_FUNC __FUNCTION__ #else #define SC_THIS_FUNC __func__ #endif #endif #ifndef SC_NOLOG #define SC_LOG_DBG SRP_LOG_DBG #define SC_LOG_ERR SRP_LOG_ERR #define SC_LOG_DBG_MSG SRP_LOG_DBG_MSG #define SC_LOG_ERR_MSG SRP_LOG_ERR_MSG #else #define SC_LOG_DBG //printf #define SC_LOG_DBG //SRP_LOG_DBG #define SC_LOG_ERR //SRP_LOG_ERR #define SC_LOG_DBG_MSG //SRP_LOG_DBG_MSG #define SC_LOG_ERR_MSG //SRP_LOG_ERR_MSG #endif #define SC_INVOKE_BEGIN SC_LOG_DBG("inovke %s bein.",SC_THIS_FUNC); #define SC_INVOKE_END SC_LOG_DBG("inovke %s end,with return OK.",SC_THIS_FUNC); #define SC_INVOKE_ENDX(...) SC_LOG_DBG("inovke %s end,with %s.",SC_THIS_FUNC, ##__VA_ARGS__) /**********************************MACROS**********************************/ #define ARG_CHECK(retval, arg) \ do \ { \ if (NULL == (arg)) \ { \ SC_LOG_ERR_MSG(#arg ":NULL pointer passed."); \ return (retval); \ } \ } \ while (0) #define ARG_CHECK2(retval, arg1, arg2) \ ARG_CHECK(retval, arg1); \ ARG_CHECK(retval, arg2) #define ARG_CHECK3(retval, arg1, arg2, arg3) \ ARG_CHECK(retval, arg1); \ ARG_CHECK(retval, arg2); \ ARG_CHECK(retval, arg3) #define ARG_CHECK4(retval, arg1, arg2, arg3, arg4) \ ARG_CHECK(retval, arg1); \ ARG_CHECK(retval, arg2); \ ARG_CHECK(retval, arg3); \ ARG_CHECK(retval, arg4) /** * when use tihs must fist DEFINE_VAPI_MSG_IDS_VXLAN_API_JSON */ #define SC_VPP_VAPI_RECV \ do { \ size_t size; \ int recv_vapimsgid = -1; \ rv = vapi_recv (g_vapi_ctx_instance, (void *) &resp, &size, 0, 0); \ recv_vapimsgid = vapi_lookup_vapi_msg_id_t(g_vapi_ctx_instance, ntohs(resp->header._vl_msg_id) ); \ if(recv_vapimsgid <= vapi_msg_id_get_next_index_reply \ || recv_vapimsgid >= vapi_get_message_count ()) { \ SC_LOG_DBG("***recv error msgid[%d] not in [0-%d) ,try again!***\n", \ recv_vapimsgid, vapi_get_message_count ()); \ } else { \ SC_LOG_DBG("recv msgid [%d]\n", recv_vapimsgid); \ break; \ } \ } while(1); #define SC_REGISTER_RPC_EVT_HANDLER(rpc_evt_handle) \ do { \ sr_error_t rc = rpc_evt_handle(session, &subscription); \ if (SR_ERR_OK != rc) \ { \ SC_LOG_ERR("load plugin failed: %s", sr_strerror(rc)); \ sr_unsubscribe(session, subscription); \ SC_INVOKE_ENDX(sr_strerror(rc)); \ return rc; \ } \ } while(0); #define VAPI_RETVAL_CB(api_name) \ static vapi_error_e \ api_name##_cb (vapi_ctx_t ctx, void *caller_ctx, vapi_error_e rv, bool is_last, \ vapi_payload_##api_name##_reply * reply) \ { \ return vapi_retval_cb(__FUNCTION__, reply->retval); \ } #define VAPI_COPY_CB(api_name) \ static vapi_error_e \ api_name##_cb (vapi_ctx_t ctx, void *caller_ctx, vapi_error_e rv, bool is_last, \ vapi_payload_##api_name##_reply * reply) \ { \ if (caller_ctx) \ { \ vapi_payload_##api_name##_reply * passed = (vapi_payload_##api_name##_reply *)caller_ctx; \ *passed = *reply; \ } \ return VAPI_OK; \ }\ #define VAPI_CALL_MODE(call_code, vapi_mode) \ do \ { \ if (VAPI_MODE_BLOCKING == (vapi_mode)) \ { \ rv = call_code; \ } \ else \ { \ while (VAPI_EAGAIN == (rv = call_code)); \ rv = vapi_dispatch (g_vapi_ctx_instance); \ } \ } \ while (0) #define VAPI_CALL(call_code) VAPI_CALL_MODE(call_code, g_vapi_mode) //returns true on success bool sc_aton(const char *cp, u8 * buf, size_t length); char * sc_ntoa(const u8 * buf); vapi_error_e vapi_retval_cb(const char* func_name, i32 retval); /////////////////////////// //VPP接口 int sc_connect_vpp(); int sc_disconnect_vpp(); int sc_end_with(const char* str, const char* end); extern vapi_ctx_t g_vapi_ctx_instance; #endif //__SC_VPP_COMMM_H__