/* * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The OpenAirInterface Software Alliance licenses this file to You under * the OAI Public License, Version 1.1 (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.openairinterface.org/?page_id=698 * * 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. *------------------------------------------------------------------------------- * For more information about the OpenAirInterface (OAI) Software Alliance: * contact@openairinterface.org */ #if HAVE_CONFIG_H_ # include "config.h" #endif #include "X2AP_ProtocolIE-Field.h" #include "X2AP_X2AP-PDU.h" #include "X2AP_InitiatingMessage.h" #include "X2AP_SuccessfulOutcome.h" #include "X2AP_UnsuccessfulOutcome.h" #include "X2AP_ProtocolIE-Field.h" #include "X2AP_ProtocolIE-FieldPair.h" #include "X2AP_ProtocolIE-ContainerPair.h" #include "X2AP_ProtocolExtensionField.h" #include "X2AP_ProtocolExtensionContainer.h" #include "X2AP_asn_constant.h" #ifndef X2AP_COMMON_H_ #define X2AP_COMMON_H_ /** @defgroup _x2ap_impl_ X2AP Layer Reference Implementation * @ingroup _ref_implementation_ * @{ */ /* Checking version of ASN1C compiler */ #if (ASN1C_ENVIRONMENT_VERSION < 923) # error "You are compiling x2ap with the wrong version of ASN1C" #endif #ifndef X2AP_PORT # define X2AP_PORT 36422 #endif #ifndef TRUE #define TRUE 1 #define FALSE 0 #endif extern int asn1_xer_print; #if defined(ENB_MODE) # include "common/utils/LOG/log.h" # define X2AP_INFO(x, args...) LOG_I(X2AP, x, ##args) # define X2AP_ERROR(x, args...) LOG_E(X2AP, x, ##args) # define X2AP_WARN(x, args...) LOG_W(X2AP, x, ##args) # define X2AP_DEBUG(x, args...) LOG_D(X2AP, x, ##args) #else # define X2AP_INFO(x, args...) do { fprintf(stdout, "[X2AP][I]"x, ##args); } while(0) # define X2AP_ERROR(x, args...) do { fprintf(stdout, "[X2AP][E]"x, ##args); } while(0) # define X2AP_WARN(x, args...) do { fprintf(stdout, "[X2AP][W]"x, ##args); } while(0) # define X2AP_DEBUG(x, args...) do { fprintf(stdout, "[X2AP][D]"x, ##args); } while(0) #endif #define X2AP_FIND_PROTOCOLIE_BY_ID(IE_TYPE, ie, container, IE_ID, mandatory) \ do {\ IE_TYPE **ptr; \ ie = NULL; \ for (ptr = container->protocolIEs.list.array; \ ptr < &container->protocolIEs.list.array[container->protocolIEs.list.count]; \ ptr++) { \ if((*ptr)->id == IE_ID) { \ ie = *ptr; \ break; \ } \ } \ if (mandatory) DevAssert(ie != NULL); \ } while(0) //Forward declaration struct x2ap_message_s; /** \brief Function callback prototype. **/ typedef int (*x2ap_message_decoded_callback)( uint32_t assocId, uint32_t stream, struct x2ap_message_s *message); /** \brief Encode a successfull outcome message \param buffer pointer to buffer in which data will be encoded \param length pointer to the length of buffer \param procedureCode Procedure code for the message \param criticality Criticality of the message \param td ASN1C type descriptor of the sptr \param sptr Deferenced pointer to the structure to encode @returns size in bytes encded on success or 0 on failure **/ ssize_t x2ap_generate_successfull_outcome( uint8_t **buffer, uint32_t *length, X2AP_ProcedureCode_t procedureCode, X2AP_Criticality_t criticality, asn_TYPE_descriptor_t *td, void *sptr); /** \brief Encode an initiating message \param buffer pointer to buffer in which data will be encoded \param length pointer to the length of buffer \param procedureCode Procedure code for the message \param criticality Criticality of the message \param td ASN1C type descriptor of the sptr \param sptr Deferenced pointer to the structure to encode @returns size in bytes encded on success or 0 on failure **/ ssize_t x2ap_generate_initiating_message( uint8_t **buffer, uint32_t *length, X2AP_ProcedureCode_t procedureCode, X2AP_Criticality_t criticality, asn_TYPE_descriptor_t *td, void *sptr); /** \brief Encode an unsuccessfull outcome message \param buffer pointer to buffer in which data will be encoded \param length pointer to the length of buffer \param procedureCode Procedure code for the message \param criticality Criticality of the message \param td ASN1C type descriptor of the sptr \param sptr Deferenced pointer to the structure to encode @returns size in bytes encded on success or 0 on failure **/ ssize_t x2ap_generate_unsuccessfull_outcome( uint8_t **buffer, uint32_t *length, X2AP_ProcedureCode_t procedureCode, X2AP_Criticality_t criticality, asn_TYPE_descriptor_t *td, void *sptr); /** \brief Handle criticality \param criticality Criticality of the IE @returns void **/ void x2ap_handle_criticality(X2AP_Criticality_t criticality); #endif /* X2AP_COMMON_H_ */