Commit 014010e5 authored by gauthier's avatar gauthier

modified version of message chart generator (msc), now events are stored in a...

modified version of message chart generator (msc), now events are stored in a contention-free and concurency-free collection (lfds611), resulting in a uniq dump file per executable.
MSC is using an ITTI timer (bad dependancy for executables that are not yet "ITTIzed").


git-svn-id: http://svn.eurecom.fr/openair4G/trunk@7620 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent 738aadeb
...@@ -398,7 +398,7 @@ add_boolean_option(OAISIM False "specific to oaisim") ...@@ -398,7 +398,7 @@ add_boolean_option(OAISIM False "specific to oaisim")
add_boolean_option(OAI_NW_DRIVER_USE_NETLINK True "????") add_boolean_option(OAI_NW_DRIVER_USE_NETLINK True "????")
add_boolean_option(USE_MME False "this flag is used only one time in lte-softmodem.c") add_boolean_option(USE_MME False "this flag is used only one time in lte-softmodem.c")
add_list_string_option(PACKAGE_NAME "NotDefined" "As per attribute name") add_list_string_option(PACKAGE_NAME "NotDefined" "As per attribute name")
add_boolean_option(MESSAGE_CHART_GENERATOR True "For generating sequence diagrams") add_boolean_option(MESSAGE_CHART_GENERATOR False "For generating sequence diagrams")
add_boolean_option(MESSAGE_CHART_GENERATOR_RLC_MAC False "trace RLC-MAC exchanges in sequence diagrams") add_boolean_option(MESSAGE_CHART_GENERATOR_RLC_MAC False "trace RLC-MAC exchanges in sequence diagrams")
add_boolean_option(MESSAGE_CHART_GENERATOR_PHY False "trace some PHY exchanges in sequence diagrams") add_boolean_option(MESSAGE_CHART_GENERATOR_PHY False "trace some PHY exchanges in sequence diagrams")
######################## ########################
...@@ -1327,7 +1327,7 @@ set(lfds ${OPENAIR2_DIR}/UTIL/LFDS/liblfds6.1.1/liblfds611/src/) ...@@ -1327,7 +1327,7 @@ set(lfds ${OPENAIR2_DIR}/UTIL/LFDS/liblfds6.1.1/liblfds611/src/)
file(GLOB lfds_queue ${lfds}/lfds611_queue/*.c) file(GLOB lfds_queue ${lfds}/lfds611_queue/*.c)
file(GLOB lfds_ring ${lfds}/lfds611_ringbuffer/*.c) file(GLOB lfds_ring ${lfds}/lfds611_ringbuffer/*.c)
file(GLOB lfds_slist ${lfds}/lfds611_slist/*.c) file(GLOB lfds_slist ${lfds}/lfds611_slist/*.c)
file(GLOB lfds_stack ${lfds}/lfds611_stack/*.c/) file(GLOB lfds_stack ${lfds}/lfds611_stack/*.c)
file(GLOB lfds_freelist ${lfds}/lfds611_freelist/*.c) file(GLOB lfds_freelist ${lfds}/lfds611_freelist/*.c)
include_directories(${lfds}) include_directories(${lfds})
...@@ -1462,16 +1462,21 @@ add_executable(lte-softmodem ...@@ -1462,16 +1462,21 @@ add_executable(lte-softmodem
${XFORMS_SOURCE} ${XFORMS_SOURCE}
${XFORMS_SOURCE_SOFTMODEM} ${XFORMS_SOURCE_SOFTMODEM}
) )
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (lte-softmodem
-Wl,--start-group
RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN SECU_OSA UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS MSC L2 ${RAL_LIB} ${NAS_LIB} ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group )
else (MESSAGE_CHART_GENERATOR)
target_link_libraries (lte-softmodem target_link_libraries (lte-softmodem
-Wl,--start-group -Wl,--start-group
RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN SECU_OSA UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} ${ITTI_LIB} ${MIH_LIB} RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN SECU_OSA UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group ) -Wl,--end-group )
endif(MESSAGE_CHART_GENERATOR)
target_link_libraries (lte-softmodem ${LIBXML2_LIBRARIES}) target_link_libraries (lte-softmodem ${LIBXML2_LIBRARIES})
target_link_libraries (lte-softmodem pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} sctp ${option_HW_lib} ${XFORMS_LIBRARIES} ) target_link_libraries (lte-softmodem pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} sctp ${option_HW_lib} ${XFORMS_LIBRARIES} )
target_link_libraries (lte-softmodem ${LIBBOOST_LIBRARIES}) target_link_libraries (lte-softmodem ${LIBBOOST_LIBRARIES})
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (lte-softmodem MSC)
endif()
# EPC is ??? nodes implementation in one process # EPC is ??? nodes implementation in one process
################################ ################################
...@@ -1483,15 +1488,21 @@ add_executable(mme_gw ...@@ -1483,15 +1488,21 @@ add_executable(mme_gw
${OPENAIRCN_DIR}/SCTP/sctp_primitives_server.c ${OPENAIRCN_DIR}/SCTP/sctp_primitives_server.c
${OPENAIRCN_DIR}/NAS/nas_main.c ${OPENAIRCN_DIR}/NAS/nas_main.c
) )
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (mme_gw
-Wl,--start-group
NAS S1AP_LIB S1AP_EPC GTPV1U GTPV2C SCTP_SERVER UDP_SERVER SECU_CN SECU_OSA S6A SGW MME_APP LFDS MSC ${ITTI_LIB} CN_UTILS HASHTABLE
-Wl,--end-group
pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
)
else (MESSAGE_CHART_GENERATOR)
target_link_libraries (mme_gw target_link_libraries (mme_gw
-Wl,--start-group -Wl,--start-group
NAS S1AP_LIB S1AP_EPC GTPV1U GTPV2C SCTP_SERVER UDP_SERVER SECU_CN SECU_OSA S6A SGW MME_APP LFDS ${ITTI_LIB} CN_UTILS HASHTABLE NAS S1AP_LIB S1AP_EPC GTPV1U GTPV2C SCTP_SERVER UDP_SERVER SECU_CN SECU_OSA S6A SGW MME_APP LFDS ${ITTI_LIB} CN_UTILS HASHTABLE
-Wl,--end-group -Wl,--end-group
pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
) )
if (MESSAGE_CHART_GENERATOR) endif(MESSAGE_CHART_GENERATOR)
target_link_libraries (mme_gw MSC)
endif()
# Default parameters # Default parameters
# Does not work on simple install (fqdn in /etc/hosts 127.0.1.1) # Does not work on simple install (fqdn in /etc/hosts 127.0.1.1)
...@@ -1572,15 +1583,21 @@ add_executable(oai_sgw ...@@ -1572,15 +1583,21 @@ add_executable(oai_sgw
${OPENAIRCN_DIR}/OAI_SGW/oai_sgw_log.c ${OPENAIRCN_DIR}/OAI_SGW/oai_sgw_log.c
${OPENAIRCN_DIR}/OAI_SGW/oai_sgw.c ${OPENAIRCN_DIR}/OAI_SGW/oai_sgw.c
) )
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oai_sgw
-Wl,--start-group
GTPV1U SECU_CN SECU_OSA S6A SGW CN_UTILS LFDS MSC ${ITTI_LIB}
-Wl,--end-group
pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
)
else (MESSAGE_CHART_GENERATOR)
target_link_libraries (oai_sgw target_link_libraries (oai_sgw
-Wl,--start-group -Wl,--start-group
GTPV1U SECU_CN SECU_OSA S6A SGW CN_UTILS LFDS ${ITTI_LIB} GTPV1U SECU_CN SECU_OSA S6A SGW CN_UTILS LFDS ${ITTI_LIB}
-Wl,--end-group -Wl,--end-group
pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
) )
if (MESSAGE_CHART_GENERATOR) endif(MESSAGE_CHART_GENERATOR)
target_link_libraries (oai_sgw MSC)
endif()
# USIM process # USIM process
################# #################
...@@ -1632,18 +1649,23 @@ add_executable(oaisim ...@@ -1632,18 +1649,23 @@ add_executable(oaisim
${XFORMS_SOURCE} ${XFORMS_SOURCE}
) )
target_include_directories(oaisim PUBLIC ${OPENAIR_TARGETS}/SIMU/USER) target_include_directories(oaisim PUBLIC ${OPENAIR_TARGETS}/SIMU/USER)
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim
-Wl,--start-group
RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS MSC L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group )
else(MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim target_link_libraries (oaisim
-Wl,--start-group -Wl,--start-group
RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB} RRC_LIB S1AP_LIB S1AP_ENB GTPV1U SECU_CN UTIL HASHTABLE SCTP_CLIENT UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group ) -Wl,--end-group )
endif(MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim ${LIBXML2_LIBRARIES} ${LAPACK_LIBRARIES}) target_link_libraries (oaisim ${LIBXML2_LIBRARIES} ${LAPACK_LIBRARIES})
target_link_libraries (oaisim pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} sctp ${option_HW_lib} target_link_libraries (oaisim pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} sctp ${option_HW_lib}
${ATLAS_LIBRARIES} ${XFORMS_LIBRARIES} ${OPENPGM_LIBRARIES}) ${ATLAS_LIBRARIES} ${XFORMS_LIBRARIES} ${OPENPGM_LIBRARIES})
#Force link with forms, regardless XFORMS option #Force link with forms, regardless XFORMS option
target_link_libraries (oaisim forms) target_link_libraries (oaisim forms)
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim MSC)
endif()
# A all in one network simulator # A all in one network simulator
...@@ -1668,18 +1690,22 @@ add_executable(oaisim_nos1 ...@@ -1668,18 +1690,22 @@ add_executable(oaisim_nos1
${XFORMS_SOURCE} ${XFORMS_SOURCE}
) )
target_include_directories(oaisim_nos1 PUBLIC ${OPENAIR_TARGETS}/SIMU/USER) target_include_directories(oaisim_nos1 PUBLIC ${OPENAIR_TARGETS}/SIMU/USER)
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim_nos1
-Wl,--start-group
RRC_LIB SECU_CN UTIL HASHTABLE UDP SCHED_LIB PHY LFDS MSC L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group )
else(MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim_nos1 target_link_libraries (oaisim_nos1
-Wl,--start-group -Wl,--start-group
RRC_LIB SECU_CN UTIL HASHTABLE UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB} RRC_LIB SECU_CN UTIL HASHTABLE UDP SCHED_LIB PHY LFDS L2 ${RAL_LIB} ${NAS_LIB} SIMU SIMU_ETH SECU_OSA ${ITTI_LIB} ${MIH_LIB}
-Wl,--end-group ) -Wl,--end-group )
endif(MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim_nos1 ${LIBXML2_LIBRARIES} ${LAPACK_LIBRARIES}) target_link_libraries (oaisim_nos1 ${LIBXML2_LIBRARIES} ${LAPACK_LIBRARIES})
target_link_libraries (oaisim_nos1 pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${option_HW_lib} target_link_libraries (oaisim_nos1 pthread m ${CONFIG_LIBRARIES} rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${option_HW_lib}
${ATLAS_LIBRARIES} ${XFORMS_LIBRARIES} ${OPENPGM_LIBRARIES}) ${ATLAS_LIBRARIES} ${XFORMS_LIBRARIES} ${OPENPGM_LIBRARIES})
#Force link with forms, regardless XFORMS option #Force link with forms, regardless XFORMS option
target_link_libraries (oaisim_nos1 forms) target_link_libraries (oaisim_nos1 forms)
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim_nos1 MSC)
endif()
# Unitary tests for each piece of L1: example, mbmssim is MBMS L1 simulator # Unitary tests for each piece of L1: example, mbmssim is MBMS L1 simulator
...@@ -1721,13 +1747,21 @@ add_executable(test_s1c_mme ...@@ -1721,13 +1747,21 @@ add_executable(test_s1c_mme
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c.c ${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c.c
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario.h ${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario.h
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario1.c ${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario1.c
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario.c
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_scenario.h
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_s1ap.c
${OPENAIRCN_DIR}/TEST/oaisim_mme_test_s1c_s1ap.h
${OPENAIR2_DIR}/ENB_APP/enb_config.c ${OPENAIR2_DIR}/ENB_APP/enb_config.c
${OPENAIR2_DIR}/ENB_APP/enb_config.h ${OPENAIR2_DIR}/ENB_APP/enb_config.h
${s1ap_h} ${OPENAIR2_DIR}/COMMON/commonDef.h
${OPENAIR2_DIR}/COMMON/messages_def.h
${OPENAIR2_DIR}/COMMON/messages_types.h
${OPENAIRCN_DIR}/S1AP/s1ap_eNB_defs.h
${S1AP_DIR}/s1ap_eNB_management_procedures.c
${OPENAIR_BIN_DIR}/messages_xml.h ${OPENAIR_BIN_DIR}/messages_xml.h
) )
target_link_libraries (test_s1c_mme target_link_libraries (test_s1c_mme
-Wl,--start-group SECU_CN S1AP_LIB S1AP_ENB SCTP_CLIENT UTIL LFDS ${ITTI_LIB} -Wl,--end-group pthread m rt crypt sctp ${LIBXML2_LIBRARIES} ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore -Wl,--start-group SECU_CN S1AP_LIB SCTP_CLIENT UTIL LFDS ${ITTI_LIB} -Wl,--end-group pthread m rt crypt sctp ${LIBXML2_LIBRARIES} ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
) )
...@@ -1738,21 +1772,18 @@ target_link_libraries (test_s1c_mme ...@@ -1738,21 +1772,18 @@ target_link_libraries (test_s1c_mme
# ??? # ???
########################### ###########################
add_executable(oaisim_mme #add_executable(oaisim_mme
${OPENAIR_BIN_DIR}/messages_xml.h # ${OPENAIR_BIN_DIR}/messages_xml.h
${OPENAIRCN_DIR}/OAISIM_MME/oai_mme_log.c # ${OPENAIRCN_DIR}/OAISIM_MME/oai_mme_log.c
${OPENAIRCN_DIR}/OAISIM_MME/oaisim_mme.c # ${OPENAIRCN_DIR}/OAISIM_MME/oaisim_mme.c
${OPENAIRCN_DIR}/NAS/nas_main.c # ${OPENAIRCN_DIR}/NAS/nas_main.c
) #)
target_link_libraries (oaisim_mme #target_link_libraries (oaisim_mme
-Wl,--start-group # -Wl,--start-group
NAS S1AP_LIB S1AP_EPC GTPV1U GTPV2C SCTP_SERVER UDP_SERVER SECU_CN SECU_OSA S6A S11 SGW MME_APP LFDS MSC ${ITTI_LIB} CN_UTILS HASHTABLE # NAS S1AP_LIB S1AP_EPC GTPV1U GTPV2C SCTP_SERVER UDP_SERVER SECU_CN SECU_OSA S6A S11 SGW MME_APP LFDS MSC ${ITTI_LIB} CN_UTILS HASHTABLE
-Wl,--end-group # -Wl,--end-group
pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore # pthread m sctp rt crypt ${CRYPTO_LIBRARIES} ${OPENSSL_LIBRARIES} ${NETTLE_LIBRARIES} ${CONFIG_LIBRARIES} fdproto fdcore
) #)
if (MESSAGE_CHART_GENERATOR)
target_link_libraries (oaisim_mme MSC)
endif()
################################################## ##################################################
# Generated specific cases is not regular code # Generated specific cases is not regular code
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX True ) set ( LINUX True )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX True ) set ( LINUX True )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX False ) set ( LINUX False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -10,4 +10,8 @@ set(RANDOM_BF False) ...@@ -10,4 +10,8 @@ set(RANDOM_BF False)
set(PBS_SIM False) set(PBS_SIM False)
set(PERFECT_CE True) set(PERFECT_CE True)
set(MESSAGE_CHART_GENERATOR False)
set(MESSAGE_CHART_GENERATOR_RLC_MAC False)
set(MESSAGE_CHART_GENERATOR_PHY False)
include(${CMAKE_CURRENT_SOURCE_DIR}/../../CMakeLists.txt) include(${CMAKE_CURRENT_SOURCE_DIR}/../../CMakeLists.txt)
...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True) ...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True)
set(HARD_RT False) set(HARD_RT False)
set(JUMBO_FRAME True) set(JUMBO_FRAME True)
set(LARGE_SCALE False) set(LARGE_SCALE False)
set(LINK_PDCP_TO_GTPV1U False) set(LINK_ENB_PDCP_TO_GTPV1U False)
set(LINUX_LIST False) set(LINUX_LIST False)
set(LINUX True) set(LINUX True)
set(LOCALIZATION False) set(LOCALIZATION False)
...@@ -25,6 +25,9 @@ set(LOG_NO_THREAD True) ...@@ -25,6 +25,9 @@ set(LOG_NO_THREAD True)
set(LOWLATENCY False) set(LOWLATENCY False)
set(MAC_CONTEXT 1) set(MAC_CONTEXT 1)
set(MAX_NUM_CCs 1) set(MAX_NUM_CCs 1)
set(MESSAGE_CHART_GENERATOR False )
set(MESSAGE_CHART_GENERATOR_RLC_MAC False )
set(MESSAGE_CHART_GENERATOR_PHY False )
set(MIH_C_MEDIEVAL_EXTENSIONS True) set(MIH_C_MEDIEVAL_EXTENSIONS True)
set(MSG_PRINT False) set(MSG_PRINT False)
set(MU_RECEIVER False) set(MU_RECEIVER False)
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX True ) set ( LINUX True )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True) ...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True)
set(HARD_RT False) set(HARD_RT False)
set(JUMBO_FRAME True) set(JUMBO_FRAME True)
set(LARGE_SCALE False) set(LARGE_SCALE False)
set(LINK_PDCP_TO_GTPV1U False) set(LINK_ENB_PDCP_TO_GTPV1U False)
set(LINUX_LIST False) set(LINUX_LIST False)
set(LINUX True) set(LINUX True)
set(LOCALIZATION False) set(LOCALIZATION False)
...@@ -25,6 +25,9 @@ set(LOG_NO_THREAD True) ...@@ -25,6 +25,9 @@ set(LOG_NO_THREAD True)
set(LOWLATENCY False) set(LOWLATENCY False)
set(MAC_CONTEXT 1) set(MAC_CONTEXT 1)
set(MAX_NUM_CCs 1) set(MAX_NUM_CCs 1)
set(MESSAGE_CHART_GENERATOR False)
set(MESSAGE_CHART_GENERATOR_RLC_MAC False)
set(MESSAGE_CHART_GENERATOR_PHY False)
set(MIH_C_MEDIEVAL_EXTENSIONS True) set(MIH_C_MEDIEVAL_EXTENSIONS True)
set(MSG_PRINT False) set(MSG_PRINT False)
set(MU_RECEIVER False) set(MU_RECEIVER False)
...@@ -34,7 +37,6 @@ set(NAS_UE True) ...@@ -34,7 +37,6 @@ set(NAS_UE True)
set(NEW_FFT True) set(NEW_FFT True)
set(NO_RRM True) set(NO_RRM True)
set(OAI_EMU True) set(OAI_EMU True)
set(OAI_EMU True)
set(OAI_NW_DRIVER_TYPE_ETHERNET False) set(OAI_NW_DRIVER_TYPE_ETHERNET False)
set(OPENAIR1 False) set(OPENAIR1 False)
set(OPENAIR2 True) set(OPENAIR2 True)
......
...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True) ...@@ -17,7 +17,7 @@ set(ENABLE_VCD_FIFO True)
set(HARD_RT False) set(HARD_RT False)
set(JUMBO_FRAME True) set(JUMBO_FRAME True)
set(LARGE_SCALE False) set(LARGE_SCALE False)
set(LINK_PDCP_TO_GTPV1U False) set(LINK_ENB_PDCP_TO_GTPV1U False)
set(LINUX_LIST False) set(LINUX_LIST False)
set(LINUX True) set(LINUX True)
set(LOCALIZATION False) set(LOCALIZATION False)
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL True ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL True )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX True ) set ( LINUX True )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False ) ...@@ -15,11 +15,7 @@ set ( ENABLE_RAL False )
set ( ENABLE_SECURITY False ) set ( ENABLE_SECURITY False )
set ( ENABLE_STANDALONE_EPC False ) set ( ENABLE_STANDALONE_EPC False )
set ( ENABLE_USE_CPU_EXECUTION_TIME True ) set ( ENABLE_USE_CPU_EXECUTION_TIME True )
set ( ENABLE_USE_GTPU_IN_KERNEL False )
set ( ENABLE_USE_MME False ) set ( ENABLE_USE_MME False )
set ( ENABLE_USE_NETFILTER_FOR_SGI False )
set ( ENABLE_USE_PCAP_FOR_SGI False )
set ( ENABLE_USE_RAW_SOCKET_FOR_SGI False )
set ( ENABLE_VCD_FIFO True ) set ( ENABLE_VCD_FIFO True )
set ( ENB_MODE True ) set ( ENB_MODE True )
set ( EPC_BUILD False ) set ( EPC_BUILD False )
...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True ) ...@@ -28,7 +24,6 @@ set ( JUMBO_FRAME True )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_ENB_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINK_ENB_PDCP_TO_IP_DRIVER False ) set ( LINK_ENB_PDCP_TO_IP_DRIVER False )
set ( LINK_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX True ) set ( LINUX True )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True ) ...@@ -36,6 +31,9 @@ set ( LOG_NO_THREAD True )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS True ) set ( MIH_C_MEDIEVAL_EXTENSIONS True )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -459,13 +459,13 @@ function main() { ...@@ -459,13 +459,13 @@ function main() {
echo "set(RRC_ASN1_VERSION \"${REL}\")" >> $cmake_file echo "set(RRC_ASN1_VERSION \"${REL}\")" >> $cmake_file
echo "set(ENABLE_VCD_FIFO $VCD_TIMING )" >> $cmake_file echo "set(ENABLE_VCD_FIFO $VCD_TIMING )" >> $cmake_file
echo 'include(${CMAKE_CURRENT_SOURCE_DIR}/../CMakeLists.txt)' >> $cmake_file echo 'include(${CMAKE_CURRENT_SOURCE_DIR}/../CMakeLists.txt)' >> $cmake_file
[ "$CLEAN" = "1" ] && rm -rf $DIR/oaisim_mme_build_oai/build #[ "$CLEAN" = "1" ] && rm -rf $DIR/oaisim_mme_build_oai/build
mkdir -p $DIR/oaisim_mme_build_oai/build #mkdir -p $DIR/oaisim_mme_build_oai/build
cd $DIR/oaisim_mme_build_oai/build #cd $DIR/oaisim_mme_build_oai/build
cmake .. #cmake ..
compilations \ #compilations \
oaisim_mme_build_oai oaisim_mme \ # oaisim_mme_build_oai oaisim_mme \
oaisim_mme $dbin/oaisim_mme.$REL # oaisim_mme $dbin/oaisim_mme.$REL
fi fi
# EPC compilation # EPC compilation
......
...@@ -26,7 +26,7 @@ set ( FLAG_GTPV1U_KERNEL_THREAD_SOCK_NO_WAIT False) ...@@ -26,7 +26,7 @@ set ( FLAG_GTPV1U_KERNEL_THREAD_SOCK_NO_WAIT False)
set ( HARD_RT False ) set ( HARD_RT False )
set ( JUMBO_FRAME False ) set ( JUMBO_FRAME False )
set ( LARGE_SCALE False ) set ( LARGE_SCALE False )
set ( LINK_PDCP_TO_GTPV1U False ) set ( LINK_ENB_PDCP_TO_GTPV1U False )
set ( LINUX_LIST False ) set ( LINUX_LIST False )
set ( LINUX False ) set ( LINUX False )
set ( LOCALIZATION False ) set ( LOCALIZATION False )
......
...@@ -31,9 +31,9 @@ set ( LOG_NO_THREAD 1 ) ...@@ -31,9 +31,9 @@ set ( LOG_NO_THREAD 1 )
set ( LOWLATENCY False ) set ( LOWLATENCY False )
set ( MAC_CONTEXT 1 ) set ( MAC_CONTEXT 1 )
set ( MAX_NUM_CCs 1 ) set ( MAX_NUM_CCs 1 )
set ( MESSAGE_CHART_GENERATOR True ) set ( MESSAGE_CHART_GENERATOR False )
set ( MESSAGE_CHART_GENERATOR_RLC_MAC True ) set ( MESSAGE_CHART_GENERATOR_RLC_MAC False )
set ( MESSAGE_CHART_GENERATOR_PHY True ) set ( MESSAGE_CHART_GENERATOR_PHY False )
set ( MIH_C_MEDIEVAL_EXTENSIONS False ) set ( MIH_C_MEDIEVAL_EXTENSIONS False )
set ( MSG_PRINT False ) set ( MSG_PRINT False )
set ( MU_RECEIVER False ) set ( MU_RECEIVER False )
......
...@@ -130,7 +130,6 @@ function main() ...@@ -130,7 +130,6 @@ function main()
-m | --mscgen) -m | --mscgen)
MSC_DIR=$2 MSC_DIR=$2
# can omit file name if last arg on the line
if [ -d "$MSC_DIR" ]; then if [ -d "$MSC_DIR" ]; then
echo "setting mscgen log files to dir: $MSC_DIR" echo "setting mscgen log files to dir: $MSC_DIR"
run_mscgen=1 run_mscgen=1
...@@ -146,10 +145,10 @@ function main() ...@@ -146,10 +145,10 @@ function main()
exe_arguments="$exe_arguments -V /tmp/oai_gtk_wave.vcd" exe_arguments="$exe_arguments -V /tmp/oai_gtk_wave.vcd"
shift ; shift ;
;; ;;
-W | ----wireshark-l2) -W | --wireshark-l2)
echo "setting l2 pcap dump output" echo "setting l2 pcap dump output"
exe_arguments="$exe_arguments -P wireshark" exe_arguments="$exe_arguments -P wireshark"
shift 2; shift 1;
;; ;;
*) *)
echo "Unknown option $1" echo "Unknown option $1"
...@@ -196,11 +195,11 @@ function main() ...@@ -196,11 +195,11 @@ function main()
fi fi
if [ $run_gdb -eq 0 ]; then if [ $run_gdb -eq 0 ]; then
exec $SUDO $OPENAIR_DIR/targets/bin/oaisim_nos1 $exe_arguments | tee /tmp/enb_ue_nos1.log.txt exec $SUDO $OPENAIR_DIR/targets/bin/oaisim_nos1.Rel10 $exe_arguments | tee /tmp/enb_ue_nos1.log.txt
else else
touch ~/.gdb_enb_ue_nos1 touch ~/.gdb_enb_ue_nos1
chmod 777 ~/.gdb_enb_ue_nos1 chmod 777 ~/.gdb_enb_ue_nos1
echo "file $OPENAIR_DIR/targets/bin/oaisim_nos1" > ~/.gdb_enb_ue_nos1 echo "file $OPENAIR_DIR/targets/bin/oaisim_nos1.Rel10" > ~/.gdb_enb_ue_nos1
echo "set args $exe_arguments" >> ~/.gdb_enb_ue_nos1 echo "set args $exe_arguments" >> ~/.gdb_enb_ue_nos1
echo "run" >> ~/.gdb_enb_ue_nos1 echo "run" >> ~/.gdb_enb_ue_nos1
cat ~/.gdb_enb_ue_nos1 cat ~/.gdb_enb_ue_nos1
......
...@@ -880,7 +880,7 @@ int itti_init(task_id_t task_max, thread_id_t thread_max, MessagesIds messages_i ...@@ -880,7 +880,7 @@ int itti_init(task_id_t task_max, thread_id_t thread_max, MessagesIds messages_i
ret = lfds611_queue_new(&itti_desc.tasks[task_id].message_queue, itti_desc.tasks_info[task_id].queue_size); ret = lfds611_queue_new(&itti_desc.tasks[task_id].message_queue, itti_desc.tasks_info[task_id].queue_size);
if (ret < 0) { if (0 == ret) {
AssertFatal (0, "lfds611_queue_new failed for task %s!\n", itti_get_task_name(task_id)); AssertFatal (0, "lfds611_queue_new failed for task %s!\n", itti_get_task_name(task_id));
} }
} }
......
...@@ -93,7 +93,8 @@ int timer_handle_signal(siginfo_t *info) ...@@ -93,7 +93,8 @@ int timer_handle_signal(siginfo_t *info)
/* Get back pointer to timer list element */ /* Get back pointer to timer list element */
timer_p = (struct timer_elm_s *)info->si_ptr; timer_p = (struct timer_elm_s *)info->si_ptr;
TMR_DEBUG("Timer with id 0x%lx has expired\n", (long)timer_p->timer); // LG: To many traces for msc timer:
// TMR_DEBUG("Timer with id 0x%lx has expired\n", (long)timer_p->timer);
task_id = timer_p->task_id; task_id = timer_p->task_id;
instance = timer_p->instance; instance = timer_p->instance;
......
This diff is collapsed.
...@@ -30,12 +30,13 @@ ...@@ -30,12 +30,13 @@
#ifndef MSC_H_ #ifndef MSC_H_
#define MSC_H_ #define MSC_H_
#include <stdarg.h> #include <stdarg.h>
#include <stdint.h>
typedef enum { typedef enum {
MIN_MSC_ENV = 0, MIN_MSC_ENV = 0,
MSC_E_UTRAN = MIN_MSC_ENV, MSC_E_UTRAN = MIN_MSC_ENV,
MSC_E_UTRAN_LIPA, MSC_E_UTRAN_LIPA,
MSC_EPC, MSC_MME_GW,
MSC_MME, MSC_MME,
MSC_SP_GW, MSC_SP_GW,
MAX_MSC_ENV MAX_MSC_ENV
...@@ -81,44 +82,31 @@ typedef enum { ...@@ -81,44 +82,31 @@ typedef enum {
(CTXT_Pp)->frame, \ (CTXT_Pp)->frame, \
(CTXT_Pp)->subframe (CTXT_Pp)->subframe
#if defined(MESSAGE_CHART_GENERATOR) #if defined(MESSAGE_CHART_GENERATOR)
int msc_init(msc_env_t envP); int msc_init(const msc_env_t envP, const int max_threadsP);
void msc_start_use(void);
void msc_end(void); void msc_end(void);
void msc_log_declare_proto(const msc_proto_t protoP); void msc_log_declare_proto(const msc_proto_t protoP);
void msc_log_event(const msc_proto_t protoP,char *format, ...); void msc_log_event(const msc_proto_t protoP,char *format, ...);
void msc_log_rx_message( void msc_log_message(
const char * const message_operationP,
const msc_proto_t receiverP, const msc_proto_t receiverP,
const msc_proto_t senderP, const msc_proto_t senderP,
const char* bytesP, const uint8_t* const bytesP,
const unsigned int num_bytes, const unsigned int num_bytes,
char *format, ...); char *format, ...);
void msc_log_rx_discarded_message(
const msc_proto_t receiverP, #define MSC_INIT(arg1,arg2) msc_init(arg1,arg2)
const msc_proto_t senderP, #define MSC_START_USE msc_start_use
const char* bytesP,
const unsigned int num_bytes,
char *format, ...);
void msc_log_tx_message(
const msc_proto_t senderP,
const msc_proto_t receiverP,
const char* bytesP,
const unsigned int num_bytes,
char *format, ...);
void msc_log_tx_message_failed(
const msc_proto_t senderP,
const msc_proto_t receiverP,
const char* bytesP,
const unsigned int num_bytes,
char *format, ...);
#define MSC_INIT(mScPaRaMs) msc_init(mScPaRaMs)
#define MSC_END msc_end #define MSC_END msc_end
#define MSC_LOG_EVENT(mScPaRaMs, fORMAT, aRGS...) msc_log_event(mScPaRaMs, fORMAT, ##aRGS) #define MSC_LOG_EVENT(mScPaRaMs, fORMAT, aRGS...) msc_log_event(mScPaRaMs, fORMAT, ##aRGS)
#define MSC_LOG_RX_MESSAGE(mScPaRaMs, fORMAT, aRGS...) msc_log_rx_message(mScPaRaMs, fORMAT, ##aRGS) #define MSC_LOG_RX_MESSAGE(rECEIVER, sENDER, bYTES, nUMbYTES, fORMAT, aRGS...) msc_log_message("<-",rECEIVER, sENDER, bYTES, nUMbYTES, fORMAT, ##aRGS)
#define MSC_LOG_RX_DISCARDED_MESSAGE(mScPaRaMs, fORMAT, aRGS...) msc_log_rx_discarded_message(mScPaRaMs, fORMAT, ##aRGS) #define MSC_LOG_RX_DISCARDED_MESSAGE(rECEIVER, sENDER, bYTES, nUMbYTES, fORMAT, aRGS...) msc_log_message("x-",rECEIVER, sENDER, bYTES, nUMbYTES, fORMAT, ##aRGS)
#define MSC_LOG_TX_MESSAGE(mScPaRaMs, fORMAT, aRGS...) msc_log_tx_message(mScPaRaMs, fORMAT, ##aRGS) #define MSC_LOG_TX_MESSAGE(sENDER, rECEIVER, bYTES, nUMbYTES, fORMAT, aRGS...) msc_log_message("->",sENDER, rECEIVER, bYTES, nUMbYTES, fORMAT, ##aRGS)
#define MSC_LOG_TX_MESSAGE_FAILED(mScPaRaMs, fORMAT, aRGS...) msc_log_tx_message_failed(mScPaRaMs, fORMAT, ##aRGS) #define MSC_LOG_TX_MESSAGE_FAILED(sENDER, rECEIVER, bYTES, nUMbYTES, fORMAT, aRGS...) msc_log_message("-x",sENDER, rECEIVER, bYTES, nUMbYTES, fORMAT, ##aRGS)
#else #else
#define MSC_INIT(mScPaRaMs) #define MSC_INIT(arg1,arg2)
#define MSC_END #define MSC_START_USE(mScPaRaMs)
#define MSC_END(mScPaRaMs)
#define MSC_LOG_EVENT(mScPaRaMs, fORMAT, aRGS...) #define MSC_LOG_EVENT(mScPaRaMs, fORMAT, aRGS...)
#define MSC_LOG_RX_MESSAGE(mScPaRaMs, fORMAT, aRGS...) #define MSC_LOG_RX_MESSAGE(mScPaRaMs, fORMAT, aRGS...)
#define MSC_LOG_RX_DISCARDED_MESSAGE(mScPaRaMs, fORMAT, aRGS...) #define MSC_LOG_RX_DISCARDED_MESSAGE(mScPaRaMs, fORMAT, aRGS...)
......
...@@ -51,3 +51,5 @@ TASK_DEF(TASK_SCTP, TASK_PRIORITY_MED, 200) ...@@ -51,3 +51,5 @@ TASK_DEF(TASK_SCTP, TASK_PRIORITY_MED, 200)
TASK_DEF(TASK_SPGW_APP, TASK_PRIORITY_MED, 200) TASK_DEF(TASK_SPGW_APP, TASK_PRIORITY_MED, 200)
/// UDP task /// UDP task
TASK_DEF(TASK_UDP, TASK_PRIORITY_MED, 200) TASK_DEF(TASK_UDP, TASK_PRIORITY_MED, 200)
//MESSAGE GENERATOR TASK
TASK_DEF(TASK_MSC, TASK_PRIORITY_MED, 200)
...@@ -52,9 +52,9 @@ ...@@ -52,9 +52,9 @@
# error "Kernel version is not defined!!!! Exiting." # error "Kernel version is not defined!!!! Exiting."
#endif #endif
#define TRACE_IN_KERN_LOG 1 #define GTPU_TRACE_IN_KERN_LOG 0
#if defined(TRACE_IN_KERN_LOG) #if defined(GTPU_TRACE_IN_KERN_LOG)
#define PR_INFO(fORMAT, aRGS...) pr_info(fORMAT, ##aRGS) #define PR_INFO(fORMAT, aRGS...) pr_info(fORMAT, ##aRGS)
#else #else
#define PR_INFO(fORMAT, aRGS...) #define PR_INFO(fORMAT, aRGS...)
......
...@@ -1000,6 +1000,7 @@ void *gtpv1u_eNB_task(void *args) ...@@ -1000,6 +1000,7 @@ void *gtpv1u_eNB_task(void *args)
rc = gtpv1u_eNB_init(); rc = gtpv1u_eNB_init();
AssertFatal(rc == 0, "gtpv1u_eNB_init Failed"); AssertFatal(rc == 0, "gtpv1u_eNB_init Failed");
itti_mark_task_ready(TASK_GTPV1_U); itti_mark_task_ready(TASK_GTPV1_U);
MSC_START_USE();
while(1) { while(1) {
/* Trying to fetch a message from the message queue. /* Trying to fetch a message from the message queue.
......
...@@ -50,6 +50,7 @@ ...@@ -50,6 +50,7 @@
#include "NwLog.h" #include "NwLog.h"
#include "gtpv1u_sgw_defs.h" #include "gtpv1u_sgw_defs.h"
#include "NwGtpv1uPrivate.h" #include "NwGtpv1uPrivate.h"
#include "msc.h"
//static NwGtpv1uStackHandleT gtpv1u_stack = 0; //static NwGtpv1uStackHandleT gtpv1u_stack = 0;
static gtpv1u_data_t gtpv1u_sgw_data; static gtpv1u_data_t gtpv1u_sgw_data;
...@@ -390,6 +391,7 @@ static NwGtpv1uRcT gtpv1u_stop_timer_wrapper( ...@@ -390,6 +391,7 @@ static NwGtpv1uRcT gtpv1u_stop_timer_wrapper(
static void *gtpv1u_thread(void *args) static void *gtpv1u_thread(void *args)
{ {
itti_mark_task_ready(TASK_GTPV1_U); itti_mark_task_ready(TASK_GTPV1_U);
MSC_START_USE();
while(1) { while(1) {
/* Trying to fetch a message from the message queue. /* Trying to fetch a message from the message queue.
......
...@@ -51,6 +51,7 @@ void *mme_app_thread(void *args); ...@@ -51,6 +51,7 @@ void *mme_app_thread(void *args);
void *mme_app_thread(void *args) void *mme_app_thread(void *args)
{ {
itti_mark_task_ready(TASK_MME_APP); itti_mark_task_ready(TASK_MME_APP);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p = NULL; MessageDef *received_message_p = NULL;
......
...@@ -60,6 +60,7 @@ Description Timer utilities ...@@ -60,6 +60,7 @@ Description Timer utilities
#endif #endif
#include "nas_timer.h" #include "nas_timer.h"
#include "commonDef.h" #include "commonDef.h"
#include "msc.h"
/****************************************************************************/ /****************************************************************************/
/**************** E X T E R N A L D E F I N I T I O N S ****************/ /**************** E X T E R N A L D E F I N I T I O N S ****************/
......
...@@ -34,8 +34,8 @@ ...@@ -34,8 +34,8 @@
#include "intertask_interface.h" #include "intertask_interface.h"
#include "mme_config.h" #include "mme_config.h"
#include "nas_defs.h" #include "nas_defs.h"
#include "msc.h"
#if !defined(DISABLE_USE_NAS) #if !defined(DISABLE_USE_NAS)
# include "nas_network.h" # include "nas_network.h"
...@@ -52,6 +52,7 @@ ...@@ -52,6 +52,7 @@
static void *nas_intertask_interface(void *args_p) static void *nas_intertask_interface(void *args_p)
{ {
itti_mark_task_ready(TASK_NAS_MME); itti_mark_task_ready(TASK_NAS_MME);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p; MessageDef *received_message_p;
......
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
# include "user_api.h" # include "user_api.h"
# include "nas_parser.h" # include "nas_parser.h"
# include "nas_proc.h" # include "nas_proc.h"
# include "msc.h"
# define NAS_UE_AUTOSTART 1 # define NAS_UE_AUTOSTART 1
...@@ -76,7 +77,7 @@ void *nas_ue_task(void *args_p) ...@@ -76,7 +77,7 @@ void *nas_ue_task(void *args_p)
int result; int result;
itti_mark_task_ready (TASK_NAS_UE); itti_mark_task_ready (TASK_NAS_UE);
MSC_START_USE();
/* Initialize UE NAS (EURECOM-NAS) */ /* Initialize UE NAS (EURECOM-NAS) */
{ {
/* Initialize user interface (to exchange AT commands with user process) */ /* Initialize user interface (to exchange AT commands with user process) */
......
...@@ -67,15 +67,15 @@ ...@@ -67,15 +67,15 @@
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
/* Parse the command line for options and set the mme_config accordingly. */
CHECK_INIT_RETURN(config_parse_opt_line(argc, argv, &mme_config) < 0);
/* Calling each layer init function */
CHECK_INIT_RETURN(log_init(&mme_config, oai_epc_log_specific));
CHECK_INIT_RETURN(itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX, CHECK_INIT_RETURN(itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX,
tasks_info, messages_info, messages_definition_xml, tasks_info, messages_info, messages_definition_xml,
mme_config.itti_config.log_file)); mme_config.itti_config.log_file));
/* Parse the command line for options and set the mme_config accordingly. */
CHECK_INIT_RETURN(config_parse_opt_line(argc, argv, &mme_config) < 0);
/* Calling each layer init function */
CHECK_INIT_RETURN(log_init(&mme_config, oai_epc_log_specific));
CHECK_INIT_RETURN(nas_init(&mme_config)); CHECK_INIT_RETURN(nas_init(&mme_config));
CHECK_INIT_RETURN(sctp_init(&mme_config)); CHECK_INIT_RETURN(sctp_init(&mme_config));
CHECK_INIT_RETURN(udp_init(&mme_config)); CHECK_INIT_RETURN(udp_init(&mme_config));
......
...@@ -56,7 +56,7 @@ ...@@ -56,7 +56,7 @@
#include "s1ap_eNB_itti_messaging.h" #include "s1ap_eNB_itti_messaging.h"
#include "s1ap_eNB_ue_context.h" // test, to be removed #include "s1ap_eNB_ue_context.h" // test, to be removed
#include "msc.h"
#include "assertions.h" #include "assertions.h"
#include "conversions.h" #include "conversions.h"
...@@ -264,6 +264,7 @@ void *s1ap_eNB_task(void *arg) ...@@ -264,6 +264,7 @@ void *s1ap_eNB_task(void *arg)
s1ap_eNB_prepare_internal_data(); s1ap_eNB_prepare_internal_data();
itti_mark_task_ready(TASK_S1AP); itti_mark_task_ready(TASK_S1AP);
MSC_START_USE();
while (1) { while (1) {
itti_receive_msg(TASK_S1AP, &received_msg); itti_receive_msg(TASK_S1AP, &received_msg);
......
...@@ -48,6 +48,7 @@ ...@@ -48,6 +48,7 @@
#include "s1ap_mme_nas_procedures.h" #include "s1ap_mme_nas_procedures.h"
#include "s1ap_mme_retransmission.h" #include "s1ap_mme_retransmission.h"
#include "msc.h"
#define S1AP_DEBUG_LIST #define S1AP_DEBUG_LIST
#ifdef S1AP_DEBUG_LIST #ifdef S1AP_DEBUG_LIST
...@@ -95,6 +96,7 @@ void *s1ap_mme_thread(void *args) ...@@ -95,6 +96,7 @@ void *s1ap_mme_thread(void *args)
MessageDef *received_message_p; MessageDef *received_message_p;
itti_mark_task_ready(TASK_S1AP); itti_mark_task_ready(TASK_S1AP);
MSC_START_USE();
while(1) { while(1) {
/* Trying to fetch a message from the message queue. /* Trying to fetch a message from the message queue.
......
...@@ -45,6 +45,7 @@ ...@@ -45,6 +45,7 @@
#include "s6a_messages.h" #include "s6a_messages.h"
#include "assertions.h" #include "assertions.h"
#include "msc.h"
#if defined(DISABLE_USE_HSS) #if defined(DISABLE_USE_HSS)
# error "Disabling HSS support is currently not supported \ # error "Disabling HSS support is currently not supported \
...@@ -67,6 +68,7 @@ static void fd_gnutls_debug(int level, const char *str) ...@@ -67,6 +68,7 @@ static void fd_gnutls_debug(int level, const char *str)
void *s6a_thread(void *args) void *s6a_thread(void *args)
{ {
itti_mark_task_ready(TASK_S6A); itti_mark_task_ready(TASK_S6A);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p = NULL; MessageDef *received_message_p = NULL;
......
...@@ -55,6 +55,7 @@ ...@@ -55,6 +55,7 @@
#include "sctp_default_values.h" #include "sctp_default_values.h"
#include "sctp_common.h" #include "sctp_common.h"
#include "sctp_eNB_itti_messaging.h" #include "sctp_eNB_itti_messaging.h"
#include "msc.h"
/* Used to format an uint32_t containing an ipv4 address */ /* Used to format an uint32_t containing an ipv4 address */
#define IPV4_ADDR "%u.%u.%u.%u" #define IPV4_ADDR "%u.%u.%u.%u"
...@@ -805,6 +806,7 @@ void *sctp_eNB_task(void *arg) ...@@ -805,6 +806,7 @@ void *sctp_eNB_task(void *arg)
STAILQ_INIT(&sctp_cnx_list); STAILQ_INIT(&sctp_cnx_list);
itti_mark_task_ready(TASK_SCTP); itti_mark_task_ready(TASK_SCTP);
MSC_START_USE();
while (1) { while (1) {
itti_receive_msg(TASK_SCTP, &received_msg); itti_receive_msg(TASK_SCTP, &received_msg);
......
...@@ -60,6 +60,7 @@ ...@@ -60,6 +60,7 @@
#include "sctp_common.h" #include "sctp_common.h"
#include "sctp_itti_messaging.h" #include "sctp_itti_messaging.h"
#include "msc.h"
#define SCTP_DUMP_LIST #define SCTP_DUMP_LIST
...@@ -553,6 +554,7 @@ void *sctp_receiver_thread(void *args_p) ...@@ -553,6 +554,7 @@ void *sctp_receiver_thread(void *args_p)
FD_SET(sctp_arg_p->sd, &master); FD_SET(sctp_arg_p->sd, &master);
fdmax = sctp_arg_p->sd; /* so far, it's this one*/ fdmax = sctp_arg_p->sd; /* so far, it's this one*/
MSC_START_USE();
while(1) { while(1) {
...@@ -616,6 +618,7 @@ void *sctp_receiver_thread(void *args_p) ...@@ -616,6 +618,7 @@ void *sctp_receiver_thread(void *args_p)
static void *sctp_intertask_interface(void *args_p) static void *sctp_intertask_interface(void *args_p)
{ {
itti_mark_task_ready(TASK_SCTP); itti_mark_task_ready(TASK_SCTP);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p; MessageDef *received_message_p;
......
...@@ -49,6 +49,7 @@ ...@@ -49,6 +49,7 @@
#include "hashtable.h" #include "hashtable.h"
#include "spgw_config.h" #include "spgw_config.h"
#include "pgw_lite_paa.h" #include "pgw_lite_paa.h"
#include "msc.h"
spgw_config_t spgw_config; spgw_config_t spgw_config;
sgw_app_t sgw_app; sgw_app_t sgw_app;
...@@ -57,6 +58,7 @@ pgw_app_t pgw_app; ...@@ -57,6 +58,7 @@ pgw_app_t pgw_app;
static void *sgw_lite_intertask_interface(void *args_p) static void *sgw_lite_intertask_interface(void *args_p)
{ {
itti_mark_task_ready(TASK_SPGW_APP); itti_mark_task_ready(TASK_SPGW_APP);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p; MessageDef *received_message_p;
......
...@@ -61,13 +61,19 @@ ...@@ -61,13 +61,19 @@
static void get_options (int argc, char **argv); static void get_options (int argc, char **argv);
static uint32_t eNB_app_register(const uint32_t enb_id_start, const uint32_t enb_id_end, const Enb_properties_array_t *enb_properties); static uint32_t eNB_app_register(const uint32_t enb_id_start, const uint32_t enb_id_end, const Enb_properties_array_t *enb_properties);
static void *eNB_app_task (void *args_p); static void *eNB_app_task (void *args_p);
static void mme_test_s1_start_test(instance_t instance); void mme_test_s1_start_test(instance_t instance);
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
static char *conf_config_file_name = NULL; static char *conf_config_file_name = NULL;
static char *itti_dump_file = NULL; static char *itti_dump_file = NULL;
const Enb_properties_array_t *enb_properties = NULL; const Enb_properties_array_t *enb_properties = NULL;
int16_t glog_level = LOG_INFO; int16_t glog_level = LOG_INFO;
int16_t glog_verbosity = LOG_MED; int16_t glog_verbosity = LOG_MED;
s1c_test_t s1c_test = {
0, // scenario_index
0, // tx_next_message_index
0, // rx_next_message_index
0 // assoc_id
};
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
static void get_options (int argc, char **argv) static void get_options (int argc, char **argv)
...@@ -228,7 +234,7 @@ static void *eNB_app_task(void *args_p) ...@@ -228,7 +234,7 @@ static void *eNB_app_task(void *args_p)
/* Check if all register eNB requests have been processed */ /* Check if all register eNB requests have been processed */
if (register_enb_pending == 0) { if (register_enb_pending == 0) {
if (registered_enb == enb_nb) { if (registered_enb == enb_nb) {
mme_test_s1_start_test(); mme_test_s1_start_test(instance);
} else { } else {
...@@ -288,10 +294,10 @@ void mme_test_s1_start_test(instance_t instance) ...@@ -288,10 +294,10 @@ void mme_test_s1_start_test(instance_t instance)
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
{ {
s1ap_eNB_itti_send_sctp_data_req(instance, s1ap_eNB_itti_send_sctp_data_req(instance,
int32_t assoc_id, s1c_test.assoc_id,
s1ap_scenario1[scenario_message_index].buffer, s1ap_scenarios[s1c_test.scenario_index][s1c_test.tx_next_message_index].buffer,
s1ap_scenario1[scenario_message_index].buf_len, s1ap_scenarios[s1c_test.scenario_index][s1c_test.tx_next_message_index].buf_len,
s1ap_scenario1[scenario_message_index].sctp_stream_id); s1ap_scenarios[s1c_test.scenario_index][s1c_test.tx_next_message_index].sctp_stream_id);
} }
......
...@@ -28,4 +28,12 @@ ...@@ -28,4 +28,12 @@
*******************************************************************************/ *******************************************************************************/
typedef struct s1c_test_s {
int scenario_index;
int tx_next_message_index;
int rx_next_message_index;
int32_t assoc_id;
}s1c_test_t;
void mme_test_s1_start_test(instance_t instance);
void mme_test_s1_notify_sctp_data_ind(uint32_t assoc_id, int32_t stream, const uint8_t * const data, const uint32_t data_length); void mme_test_s1_notify_sctp_data_ind(uint32_t assoc_id, int32_t stream, const uint8_t * const data, const uint32_t data_length);
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
Address : Eurecom, Campus SophiaTech, 450 Route des Chappes, CS 50193 - 06904 Biot Sophia Antipolis cedex, FRANCE Address : Eurecom, Campus SophiaTech, 450 Route des Chappes, CS 50193 - 06904 Biot Sophia Antipolis cedex, FRANCE
*******************************************************************************/ *******************************************************************************/
#include <stdlib.h>
#include <stdint.h> #include <stdint.h>
#define MME_TEST_S1_MAX_BUF_LENGTH (1024) #define MME_TEST_S1_MAX_BUF_LENGTH (1024)
...@@ -36,14 +37,15 @@ typedef enum entity_s{ ...@@ -36,14 +37,15 @@ typedef enum entity_s{
ENB ENB
} entity_t; } entity_t;
typedef struct s1ap_test_s{ typedef struct s1ap_message_test_s{
char *procedure_name; char *procedure_name;
uint8_t buffer[MME_TEST_S1_MAX_BUF_LENGTH]; uint8_t buffer[MME_TEST_S1_MAX_BUF_LENGTH];
uint16_t dont_check[MME_TEST_S1_MAX_BYTES_TEST]; // bytes index test that can be omitted uint16_t dont_check[MME_TEST_S1_MAX_BYTES_TEST]; // bytes index test that can be omitted
uint32_t buf_len; uint32_t buf_len;
entity_t originating; entity_t originating;
uint16_t sctp_stream_id; uint16_t sctp_stream_id;
} s1ap_test_t; uint32_t assoc_id;
} s1ap_message_test_t;
void fail (const char *format, ...); void fail (const char *format, ...);
void success (const char *format, ...); void success (const char *format, ...);
......
...@@ -26,12 +26,13 @@ ...@@ -26,12 +26,13 @@
Address : Eurecom, Campus SophiaTech, 450 Route des Chappes, CS 50193 - 06904 Biot Sophia Antipolis cedex, FRANCE Address : Eurecom, Campus SophiaTech, 450 Route des Chappes, CS 50193 - 06904 Biot Sophia Antipolis cedex, FRANCE
*******************************************************************************/ *******************************************************************************/
#include <stdlib.h>
#include "oaisim_mme_test_s1c_scenario.h" #include "oaisim_mme_test_s1c_scenario.h"
// Description succesfull attach of UE, release UE. // Description succesfull attach of UE, release UE.
s1ap_test_t s1ap_scenario1[] = { s1ap_message_test_t s1ap_scenario1[] = {
{ {
.procedure_name = "id-initialUEMessage", .procedure_name = "id-initialUEMessage",
.buffer = { .buffer = {
......
...@@ -51,6 +51,7 @@ ...@@ -51,6 +51,7 @@
#include "UTIL/LOG/log.h" #include "UTIL/LOG/log.h"
#include "UTIL/LOG/vcd_signal_dumper.h" #include "UTIL/LOG/vcd_signal_dumper.h"
#include "msc.h"
#define IPV4_ADDR "%u.%u.%u.%u" #define IPV4_ADDR "%u.%u.%u.%u"
...@@ -304,6 +305,7 @@ void *udp_eNB_task(void *args_p) ...@@ -304,6 +305,7 @@ void *udp_eNB_task(void *args_p)
udp_enb_init(NULL); udp_enb_init(NULL);
itti_mark_task_ready(TASK_UDP); itti_mark_task_ready(TASK_UDP);
MSC_START_USE();
while(1) { while(1) {
itti_receive_msg(TASK_UDP, &received_message_p); itti_receive_msg(TASK_UDP, &received_message_p);
......
...@@ -53,6 +53,7 @@ ...@@ -53,6 +53,7 @@
#include "assertions.h" #include "assertions.h"
#include "conversions.h" #include "conversions.h"
#include "msc.h"
#define UDP_DEBUG(x, args...) do { fprintf(stdout, "[UDP] [D]"x, ##args); } while(0) #define UDP_DEBUG(x, args...) do { fprintf(stdout, "[UDP] [D]"x, ##args); } while(0)
#define UDP_ERROR(x, args...) do { fprintf(stderr, "[UDP] [E]"x, ##args); } while(0) #define UDP_ERROR(x, args...) do { fprintf(stderr, "[UDP] [E]"x, ##args); } while(0)
...@@ -330,6 +331,7 @@ static void *udp_intertask_interface(void *args_p) ...@@ -330,6 +331,7 @@ static void *udp_intertask_interface(void *args_p)
struct epoll_event *events = NULL; struct epoll_event *events = NULL;
itti_mark_task_ready(TASK_UDP); itti_mark_task_ready(TASK_UDP);
MSC_START_USE();
while(1) { while(1) {
MessageDef *received_message_p = NULL; MessageDef *received_message_p = NULL;
......
...@@ -41,6 +41,7 @@ ...@@ -41,6 +41,7 @@
#include <arpa/inet.h> /* To provide inet_addr */ #include <arpa/inet.h> /* To provide inet_addr */
#include "intertask_interface.h"
#include "assertions.h" #include "assertions.h"
#include "msc.h" #include "msc.h"
#include "mme_config.h" #include "mme_config.h"
...@@ -693,7 +694,7 @@ int config_parse_opt_line(int argc, char *argv[], mme_config_t *mme_config_p) ...@@ -693,7 +694,7 @@ int config_parse_opt_line(int argc, char *argv[], mme_config_t *mme_config_p)
case 'm': { case 'm': {
fprintf(stdout, "Logging Message chart(mscgen)\n"); fprintf(stdout, "Logging Message chart(mscgen)\n");
MSC_INIT(MSC_EPC); MSC_INIT(MSC_MME_GW, THREAD_MAX+TASK_MAX);
} }
break; break;
......
...@@ -77,3 +77,6 @@ TASK_DEF(TASK_RRC_UE, TASK_PRIORITY_MED, 200) ...@@ -77,3 +77,6 @@ TASK_DEF(TASK_RRC_UE, TASK_PRIORITY_MED, 200)
TASK_DEF(TASK_NAS_UE, TASK_PRIORITY_MED, 200) TASK_DEF(TASK_NAS_UE, TASK_PRIORITY_MED, 200)
TASK_DEF(TASK_RAL_UE, TASK_PRIORITY_MED, 200) TASK_DEF(TASK_RAL_UE, TASK_PRIORITY_MED, 200)
//MESSAGE GENERATOR TASK
TASK_DEF(TASK_MSC, TASK_PRIORITY_MED, 200)
...@@ -67,6 +67,8 @@ ...@@ -67,6 +67,8 @@
#include "pdcp.h" #include "pdcp.h"
#include "pdcp_primitives.h" #include "pdcp_primitives.h"
#include "msc.h"
#define PDCP_QUEUE_NB_ELEMENTS 200 #define PDCP_QUEUE_NB_ELEMENTS 200
...@@ -219,7 +221,7 @@ void *pdcp_netlink_thread_fct(void *arg) ...@@ -219,7 +221,7 @@ void *pdcp_netlink_thread_fct(void *arg)
pdcp_thread_read_state = 0; pdcp_thread_read_state = 0;
memset(nl_rx_buf, 0, NL_MAX_PAYLOAD); memset(nl_rx_buf, 0, NL_MAX_PAYLOAD);
LOG_I(PDCP, "[NETLINK_THREAD] binding to fd %d\n",nas_sock_fd); LOG_I(PDCP, "[NETLINK_THREAD] binding to fd %d\n",nas_sock_fd);
MSC_START_USE();
while (1) { while (1) {
len = recvmsg(nas_sock_fd, &nas_msg_rx, 0); len = recvmsg(nas_sock_fd, &nas_msg_rx, 0);
......
...@@ -44,6 +44,7 @@ ...@@ -44,6 +44,7 @@
#include "PHY/extern.h" //for PHY_vars #include "PHY/extern.h" //for PHY_vars
#include "UTIL/LOG/log.h" #include "UTIL/LOG/log.h"
#include "UTIL/LOG/vcd_signal_dumper.h" #include "UTIL/LOG/vcd_signal_dumper.h"
#include "msc.h"
#define OPENAIR_THREAD_STACK_SIZE 8192 #define OPENAIR_THREAD_STACK_SIZE 8192
#define OPENAIR_THREAD_PRIORITY 255 #define OPENAIR_THREAD_PRIORITY 255
...@@ -64,6 +65,7 @@ static void *pdcp_thread_main(void* param) ...@@ -64,6 +65,7 @@ static void *pdcp_thread_main(void* param)
uint8_t eNB_flag = !UE_flag; uint8_t eNB_flag = !UE_flag;
LOG_I(PDCP,"This is pdcp_thread eNB_flag = %d\n",eNB_flag); LOG_I(PDCP,"This is pdcp_thread eNB_flag = %d\n",eNB_flag);
MSC_START_USE();
while (!oai_exit) { while (!oai_exit) {
......
...@@ -1048,6 +1048,8 @@ static void* eNB_thread_tx( void* param ) ...@@ -1048,6 +1048,8 @@ static void* eNB_thread_tx( void* param )
// set default return value // set default return value
eNB_thread_tx_status[proc->subframe] = 0; eNB_thread_tx_status[proc->subframe] = 0;
MSC_START_USE();
#ifdef RTAI #ifdef RTAI
RT_TASK *task; RT_TASK *task;
char task_name[8]; char task_name[8];
...@@ -1235,6 +1237,8 @@ static void* eNB_thread_rx( void* param ) ...@@ -1235,6 +1237,8 @@ static void* eNB_thread_rx( void* param )
// set default return value // set default return value
eNB_thread_rx_status[proc->subframe] = 0; eNB_thread_rx_status[proc->subframe] = 0;
MSC_START_USE();
#ifdef RTAI #ifdef RTAI
RT_TASK *task; RT_TASK *task;
char task_name[8]; char task_name[8];
...@@ -2473,8 +2477,6 @@ int main( int argc, char **argv ) ...@@ -2473,8 +2477,6 @@ int main( int argc, char **argv )
get_options (argc, argv); //Command-line options get_options (argc, argv); //Command-line options
// initialize mscgen log
MSC_INIT(MSC_E_UTRAN);
// initialize the log (see log.h for details) // initialize the log (see log.h for details)
set_glog(glog_level, glog_verbosity); set_glog(glog_level, glog_verbosity);
...@@ -2560,6 +2562,9 @@ int main( int argc, char **argv ) ...@@ -2560,6 +2562,9 @@ int main( int argc, char **argv )
itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX, tasks_info, messages_info, messages_definition_xml, itti_dump_file); itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX, tasks_info, messages_info, messages_definition_xml, itti_dump_file);
#endif #endif
// initialize mscgen log after ITTI
MSC_INIT(MSC_E_UTRAN, THREAD_MAX+TASK_MAX);
#ifdef OPENAIR2 #ifdef OPENAIR2
if (opt_type != OPT_NONE) { if (opt_type != OPT_NONE) {
......
...@@ -2,7 +2,9 @@ ...@@ -2,7 +2,9 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# The aim of this script is to collect some traces from oai stack and generate a sequence diagram image (png or jpeg). # The aim of this script is to collect some traces from oai stack and generate a sequence diagram image (png or jpeg).
#
# It is supposed that a protocol name (MSC_NEW_STR) starts with...its name (RRC, MAC, NAS, S1AP, etc) then is followed by an underscore and whatever (RRC_UE, RRC_eNB)
# Like this it is possible to distinguish between PDUS, SDUs or other messages only by reading source ans destination
import sys import sys
import subprocess import subprocess
...@@ -20,6 +22,9 @@ parser = argparse.ArgumentParser() ...@@ -20,6 +22,9 @@ parser = argparse.ArgumentParser()
parser.add_argument("--diag_rlc_um", "-u", type=str,help="Try to find RLC protocol diagnostics", default="no") parser.add_argument("--diag_rlc_um", "-u", type=str,help="Try to find RLC protocol diagnostics", default="no")
parser.add_argument("--dir", "-d", type=str,help="Directory where msc logs can be found", default="/tmp") parser.add_argument("--dir", "-d", type=str,help="Directory where msc logs can be found", default="/tmp")
parser.add_argument("--profile", "-p", type=str,help="E_UTRAN, EPC", default="EPC") parser.add_argument("--profile", "-p", type=str,help="E_UTRAN, EPC", default="EPC")
parser.add_argument("--no_message", "-M", type=str,help="Trace PDUs, not messages, SDUs", default="no")
parser.add_argument("--no_pdu", "-P", type=str,help="Trace messages, SDUs, not PDUs", default="no")
parser.add_argument("--no_event", "-E", type=str,help="Do not trace events", default="no")
args = parser.parse_args() args = parser.parse_args()
MSCGEN_OUTPUT_TYPE = "png" MSCGEN_OUTPUT_TYPE = "png"
...@@ -30,8 +35,10 @@ MSC_MSG_STR = '[MESSAGE]' ...@@ -30,8 +35,10 @@ MSC_MSG_STR = '[MESSAGE]'
MSC_BOX_STR = '[EVENT]' MSC_BOX_STR = '[EVENT]'
# This list is filled as follow : g_proto_names[module_id_int] = (proto_name) # This list is filled as follow : g_proto_names[module_id_int] = (proto_name), example RRC_UE
g_proto_names = [] g_proto_names = []
# This list is filled as follow : g_proto_names[module_id_int] = (basename proto_name) example: RRC
g_proto_types = []
...@@ -83,38 +90,14 @@ g_sequence_generator = 0 ...@@ -83,38 +90,14 @@ g_sequence_generator = 0
g_filenames = [] g_filenames = []
if "E_UTRAN" == args.profile.strip(): if "E_UTRAN" == args.profile.strip():
g_filenames = [ g_filenames = [
args.dir+'/openair.msc.ip_ue.log', args.dir+'/openair.msc.0.log',
args.dir+'/openair.msc.ip_enb.log', args.dir+'/openair.msc.1.log']
args.dir+'/openair.msc.nas_ue.log',
args.dir+'/openair.msc.pdcp_ue.log',
args.dir+'/openair.msc.rrc_ue.log',
args.dir+'/openair.msc.rlc_ue.log',
args.dir+'/openair.msc.mac_ue.log',
args.dir+'/openair.msc.phy_ue.log',
args.dir+'/openair.msc.phy_enb.log',
args.dir+'/openair.msc.mac_enb.log',
args.dir+'/openair.msc.rlc_enb.log',
args.dir+'/openair.msc.pdcp_enb.log',
args.dir+'/openair.msc.rrc_enb.log',
args.dir+'/openair.msc.s1ap_enb.log',
args.dir+'/openair.msc.gtpu_enb.log',
args.dir+'/openair.msc.gtpu_sgw.utran.log',
args.dir+'/openair.msc.s1ap_mme.utran.log',
args.dir+'/openair.msc.nas_mme.utran.log']
elif "EPC" == args.profile.strip(): elif "EPC" == args.profile.strip():
g_filenames = [ g_filenames = [
args.dir+'/openair.msc.s1ap_enb.epc.log', args.dir+'/openair.msc.2.log',
args.dir+'/openair.msc.mme_app.log', args.dir+'/openair.msc.3.log',
args.dir+'/openair.msc.nas_mme.log', args.dir+'/openair.msc.4.log']
args.dir+'/openair.msc.nas_emm_mme.log',
args.dir+'/openair.msc.nas_esm_mme.log',
args.dir+'/openair.msc.spgwapp_mme.log',
args.dir+'/openair.msc.s11_mme.log',
args.dir+'/openair.msc.s6a_mme.log',
args.dir+'/openair.msc.gtpu_sgw.log',
args.dir+'/openair.msc.s1ap_mme.log',
args.dir+'/openair.msc.hss.log']
def sequence_number_generator(): def sequence_number_generator():
global g_sequence_generator global g_sequence_generator
...@@ -145,8 +128,8 @@ def parse_oai_log_files(): ...@@ -145,8 +128,8 @@ def parse_oai_log_files():
# split file content in lines # split file content in lines
lines = fcontent.splitlines() lines = fcontent.splitlines()
for line in lines: for line in lines:
print ("INPUT LINE: %s " % line)
if line.strip() != "" and not line.strip().startswith('#'): if line.strip() != "" and not line.strip().startswith('#'):
print ("INPUT LINE: %s " % line)
partition = line.split(' ',3) partition = line.split(' ',3)
event_id = int(partition[0]) + event_id_offset event_id = int(partition[0]) + event_id_offset
event_type = partition[1] event_type = partition[1]
...@@ -156,8 +139,13 @@ def parse_oai_log_files(): ...@@ -156,8 +139,13 @@ def parse_oai_log_files():
if len(g_proto_names) <= entity_id: if len(g_proto_names) <= entity_id:
for i in range(len(g_proto_names),(entity_id +1)): for i in range(len(g_proto_names),(entity_id +1)):
g_proto_names.append("NotDeclared") g_proto_names.append("NotDeclared")
g_proto_types.append("NotDeclared")
g_proto_names[entity_id] = entity_name g_proto_names[entity_id] = entity_name
partition_name1 = entity_name.split('_',1);
partition_name2 = partition_name1[0].split('-',1);
partition_name3 = partition_name2[0].split();
g_proto_types[entity_id] = partition_name3
print ("entity name %s , entity type %s" % (g_proto_names[entity_id],g_proto_types[entity_id]) )
# if line is a trace of a message between 2 protocol entities or layers # if line is a trace of a message between 2 protocol entities or layers
elif MSC_MSG_STR == event_type: elif MSC_MSG_STR == event_type:
#print ("partition[3]:%s" % partition[3]) #print ("partition[3]:%s" % partition[3])
...@@ -278,6 +266,7 @@ def get_new_file_descriptor(): ...@@ -278,6 +266,7 @@ def get_new_file_descriptor():
global g_page_index global g_page_index
l_file_name = g_base_file_name + str(g_page_index)+'.txt' l_file_name = g_base_file_name + str(g_page_index)+'.txt'
l_file = open(l_file_name, "wb") l_file = open(l_file_name, "wb")
print "Generating mscgen input file ",l_file_name;
return l_file return l_file
...@@ -301,10 +290,26 @@ msc_chart_write_header(g_file) ...@@ -301,10 +290,26 @@ msc_chart_write_header(g_file)
for event_id_int in sorted(g_messages.iterkeys()): for event_id_int in sorted(g_messages.iterkeys()):
message = g_messages[event_id_int] message = g_messages[event_id_int]
if 'tx' in message['type']: if 'tx' in message['type']:
if "yes" == args.no_message.strip():
if g_proto_types[message['tx']] != g_proto_types[message['rx']]:
continue
if "yes" == args.no_pdu.strip():
if g_proto_types[message['tx']] == g_proto_types[message['rx']]:
continue
g_file.write(" %s=>%s [ label = \"(%d|%s) %s\", linecolour=%s , textcolour=%s ] ;\n" % (g_proto_names[message['tx']], g_proto_names[message['rx']], event_id_int, message['time'], message['message'], message['line_color'], message['text_color'])) g_file.write(" %s=>%s [ label = \"(%d|%s) %s\", linecolour=%s , textcolour=%s ] ;\n" % (g_proto_names[message['tx']], g_proto_names[message['rx']], event_id_int, message['time'], message['message'], message['line_color'], message['text_color']))
elif 'rx' in message['type']: elif 'rx' in message['type']:
if "yes" == args.no_message.strip():
if g_proto_types[message['tx']] != g_proto_types[message['rx']]:
continue
if "yes" == args.no_pdu.strip():
if g_proto_types[message['tx']] == g_proto_types[message['rx']]:
continue
g_file.write(" %s<=%s [ label = \"(%d|%s) %s\", linecolour=%s , textcolour=%s ] ;\n" % (g_proto_names[message['rx']], g_proto_names[message['tx']], event_id_int, message['time'], message['message'], message['line_color'], message['text_color'])) g_file.write(" %s<=%s [ label = \"(%d|%s) %s\", linecolour=%s , textcolour=%s ] ;\n" % (g_proto_names[message['rx']], g_proto_names[message['tx']], event_id_int, message['time'], message['message'], message['line_color'], message['text_color']))
elif 'box' in message['type']: elif 'box' in message['type']:
if "yes" == args.no_event.strip():
continue
g_file.write(" %s note %s [ label = \"%s\", textcolour=%s ] ;\n" % (g_proto_names[message['tx']], g_proto_names[message['rx']], message['message'], message['text_color'])) g_file.write(" %s note %s [ label = \"%s\", textcolour=%s ] ;\n" % (g_proto_names[message['tx']], g_proto_names[message['rx']], message['message'], message['text_color']))
g_message_index = g_message_index + 1 g_message_index = g_message_index + 1
......
...@@ -337,6 +337,7 @@ void oaisim_config(void) ...@@ -337,6 +337,7 @@ void oaisim_config(void)
#if defined(ENABLE_ITTI) #if defined(ENABLE_ITTI)
itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX, tasks_info, messages_info, messages_definition_xml, oai_emulation.info.itti_dump_file); itti_init(TASK_MAX, THREAD_MAX, MESSAGES_ID_MAX, tasks_info, messages_info, messages_definition_xml, oai_emulation.info.itti_dump_file);
MSC_INIT(MSC_E_UTRAN, THREAD_MAX+TASK_MAX);
#endif #endif
// init ocg if enabled, otherwise take the params form the init_oai_emulation() // init ocg if enabled, otherwise take the params form the init_oai_emulation()
...@@ -351,8 +352,7 @@ void oaisim_config(void) ...@@ -351,8 +352,7 @@ void oaisim_config(void)
} }
} }
// init other comps
MSC_INIT(MSC_E_UTRAN);
#ifdef ENABLE_RAL #ifdef ENABLE_RAL
mRAL_init_default_values(); mRAL_init_default_values();
eRAL_init_default_values(); eRAL_init_default_values();
......
...@@ -337,9 +337,9 @@ build_enb(){ ...@@ -337,9 +337,9 @@ build_enb(){
OAISIM_DIRECTIVES="DEBUG=$DEBUG XFORMS=$XFORMS " OAISIM_DIRECTIVES="DEBUG=$DEBUG XFORMS=$XFORMS "
if [ $ENB_S1 -eq 1 ]; then if [ $ENB_S1 -eq 1 ]; then
SOFTMODEM_DIRECTIVES="$SOFTMODEM_DIRECTIVES USE_MME=R10 ENABLE_ITTI=1 LINK_PDCP_TO_GTPV1U=1 SECU=1 " SOFTMODEM_DIRECTIVES="$SOFTMODEM_DIRECTIVES USE_MME=R10 ENABLE_ITTI=1 LINK_ENB_PDCP_TO_GTPV1U=1 SECU=1 "
#OAISIM_DIRECTIVES="$OAISIM_DIRECTIVES USE_MME=R10 ENABLE_ITTI=1 LINK_PDCP_TO_GTPV1U=1 SECU=1 " #OAISIM_DIRECTIVES="$OAISIM_DIRECTIVES USE_MME=R10 ENABLE_ITTI=1 LINK_ENB_PDCP_TO_GTPV1U=1 SECU=1 "
OAISIM_DIRECTIVES="$OAISIM_DIRECTIVES ENABLE_ITTI=1 LINK_PDCP_TO_GTPV1U=1 SECU=1 " OAISIM_DIRECTIVES="$OAISIM_DIRECTIVES ENABLE_ITTI=1 LINK_ENB_PDCP_TO_GTPV1U=1 SECU=1 "
fi fi
if [ $DEBUG -eq 0 ]; then if [ $DEBUG -eq 0 ]; then
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment