f1ap_handlers.c 5.04 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
/*
 * 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
 */

/*! \file f1ap_handlers.c
 * \brief f1ap messages handlers
 * \author EURECOM/NTUST
 * \date 2018
 * \version 0.1
 * \company Eurecom
 * \email: navid.nikaein@eurecom.fr, bing-kai.hong@eurecom.fr
 * \note
 * \warning
 */

#include "f1ap_common.h"
#include "f1ap_handlers.h"
35
#include "f1ap_decoder.h"
36 37
#include "f1ap_cu_interface_management.h"
#include "f1ap_du_interface_management.h"
38
#include "f1ap_cu_rrc_message_transfer.h"
39
#include "f1ap_du_rrc_message_transfer.h"
40 41
#include "f1ap_cu_ue_context_management.h"
#include "f1ap_du_ue_context_management.h"
42

Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
43
/* Handlers matrix. Only f1 related procedure present here */
44
f1ap_message_decoded_callback f1ap_messages_callback[][3] = {
45

Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
46

47
  { 0, 0, 0 }, /* Reset */
48
  { CU_handle_F1_SETUP_REQUEST, DU_handle_F1_SETUP_RESPONSE, DU_handle_F1_SETUP_FAILURE }, /* F1Setup */
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
49
  { 0, 0, 0 }, /* ErrorIndication */
50
  { 0, 0, 0 }, /* gNBDUConfigurationUpdate */
51
  { DU_handle_gNB_CU_CONFIGURATION_UPDATE, CU_handle_gNB_CU_CONFIGURATION_UPDATE_ACKNOWLEDGE, CU_handle_gNB_CU_CONFIGURATION_UPDATE_FAILURE }, /* gNBCUConfigurationUpdate */
52
  { DU_handle_UE_CONTEXT_SETUP_REQUEST, CU_handle_UE_CONTEXT_SETUP_RESPONSE, 0 }, /* UEContextSetup */
53
  { DU_handle_UE_CONTEXT_RELEASE_COMMAND, CU_handle_UE_CONTEXT_RELEASE_COMPLETE, 0 }, /* UEContextRelease */
54
  { 0, 0, 0 }, /* UEContextModification */
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
55 56
  { 0, 0, 0 }, /* UEContextModificationRequired */
  { 0, 0, 0 }, /* UEMobilityCommand */
57
  { CU_handle_UE_CONTEXT_RELEASE_REQUEST, 0, 0 }, /* UEContextReleaseRequest */
58
  { CU_handle_INITIAL_UL_RRC_MESSAGE_TRANSFER, 0, 0 }, /* InitialULRRCMessageTransfer */
59 60
  { DU_handle_DL_RRC_MESSAGE_TRANSFER, 0, 0 }, /* DLRRCMessageTransfer */
  { CU_handle_UL_RRC_MESSAGE_TRANSFER, 0, 0 }, /* ULRRCMessageTransfer */
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
61 62 63 64 65 66
  { 0, 0, 0 }, /* privateMessage */
  { 0, 0, 0 }, /* UEInactivityNotification */
  { 0, 0, 0 }, /* GNBDUResourceCoordination */
  { 0, 0, 0 }, /* SystemInformationDeliveryCommand */
  { 0, 0, 0 }, /* Paging */
  { 0, 0, 0 }, /* Notify */
67
  { 0, 0, 0 }, /* WriteReplaceWarning */
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
68 69 70
  { 0, 0, 0 }, /* PWSCancel */
  { 0, 0, 0 }, /* PWSRestartIndication */
  { 0, 0, 0 }, /* PWSFailureIndication */
71 72
};

73
const char *f1ap_direction2String(int f1ap_dir) {
74 75 76 77 78 79 80
  static const char *f1ap_direction_String[] = {
    "", /* Nothing */
    "Initiating message", /* initiating message */
    "Successfull outcome", /* successfull outcome */
    "UnSuccessfull outcome", /* successfull outcome */
  };
  return(f1ap_direction_String[f1ap_dir]);
81 82
}

83
int f1ap_handle_message(instance_t instance, uint32_t assoc_id, int32_t stream,
84 85
                        const uint8_t *const data, const uint32_t data_length) {
  F1AP_F1AP_PDU_t pdu= {0};
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
86
  int ret;
87 88
  DevAssert(data != NULL);

Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
89
  if (f1ap_decode_pdu(&pdu, data, data_length) < 0) {
90
    LOG_E(F1AP, "Failed to decode PDU\n");
91 92 93 94
    return -1;
  }

  /* Checking procedure Code and direction of message */
95
  if (pdu.choice.initiatingMessage->procedureCode >= sizeof(f1ap_messages_callback) / (3 * sizeof(
96
        f1ap_message_decoded_callback))
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
97
      || (pdu.present > F1AP_F1AP_PDU_PR_unsuccessfulOutcome)) {
98
    LOG_E(F1AP, "[SCTP %d] Either procedureCode %ld or direction %d exceed expected\n",
99
          assoc_id, pdu.choice.initiatingMessage->procedureCode, pdu.present);
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
100
    ASN_STRUCT_FREE_CONTENTS_ONLY(asn_DEF_F1AP_F1AP_PDU, &pdu);
101 102 103 104 105 106
    return -1;
  }

  /* No handler present.
   * This can mean not implemented or no procedure for eNB (wrong direction).
   */
107
  if (f1ap_messages_callback[pdu.choice.initiatingMessage->procedureCode][pdu.present - 1] == NULL) {
108
    LOG_E(F1AP, "[SCTP %d] No handler for procedureCode %ld in %s\n",
109 110
          assoc_id, pdu.choice.initiatingMessage->procedureCode,
          f1ap_direction2String(pdu.present - 1));
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
111
    ASN_STRUCT_FREE_CONTENTS_ONLY(asn_DEF_F1AP_F1AP_PDU, &pdu);
112 113 114 115
    return -1;
  }

  /* Calling the right handler */
116
  LOG_I(F1AP, "Calling handler with instance %ld\n",instance);
117
  ret = (*f1ap_messages_callback[pdu.choice.initiatingMessage->procedureCode][pdu.present - 1])
118
        (instance, assoc_id, stream, &pdu);
Bing-Kai Hong's avatar
F1:  
Bing-Kai Hong committed
119 120
  ASN_STRUCT_FREE_CONTENTS_ONLY(asn_DEF_F1AP_F1AP_PDU, &pdu);
  return ret;
121
}