Skip to content
Snippets Groups Projects
m2ap_decoder.c 6.7 KiB
Newer Older
/*
 * 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 m2ap_decoder.c
 * \brief m2ap decoder procedures 
 * \author Javier Morgade <javier.morgade@ieee.org>
 * \date 2019
 * \version 0.1
 */

#include <stdio.h>

#include "assertions.h"
#include "intertask_interface.h"
#include "m2ap_common.h"
#include "m2ap_decoder.h"

static int m2ap_decode_initiating_message(M2AP_M2AP_PDU_t *pdu)
{
  DevAssert(pdu != NULL);

  switch(pdu->choice.initiatingMessage.procedureCode) {
    case M2AP_ProcedureCode_id_sessionStart:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_sessionStop:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_m2Setup:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_mbmsSchedulingInformation:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;


   
//    case M2AP_ProcedureCode_id_handoverPreparation:
//      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
//      M2AP_INFO("m2ap__decode_initiating_message!\n");
//      break;
//
//    case M2AP_ProcedureCode_id_uEContextRelease:
//      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
//      M2AP_INFO("m2ap__decode_initiating_message!\n");
//      break;
//
//    case M2AP_ProcedureCode_id_handoverCancel:
//      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
//      M2AP_INFO("m2ap__decode_initiating_message!\n");
//      break;
//
    default:
      M2AP_ERROR("Unknown procedure ID (%d) for initiating message\n",
                  (int)pdu->choice.initiatingMessage.procedureCode);
      AssertFatal( 0, "Unknown procedure ID (%d) for initiating message\n",
                   (int)pdu->choice.initiatingMessage.procedureCode);
      return -1;
  }

  return 0;
}

static int m2ap_decode_successful_outcome(M2AP_M2AP_PDU_t *pdu)
{
  DevAssert(pdu != NULL);

  switch(pdu->choice.successfulOutcome.procedureCode) {
    case M2AP_ProcedureCode_id_sessionStart:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_successfuloutcome_message!\n");
      break;
    case M2AP_ProcedureCode_id_sessionStop:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_succesfuloutcome_message!\n");
      break;
    case M2AP_ProcedureCode_id_m2Setup:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_succesfuloutcome_message!\n");
      break;
    case M2AP_ProcedureCode_id_mbmsSchedulingInformation:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_succesfuloutcome_message!\n");
      break;


//    case M2AP_ProcedureCode_id_handoverPreparation:
//      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
//      M2AP_INFO("m2ap__decode_successfuloutcome_message!\n");
//      break;
//
    default:
      M2AP_ERROR("Unknown procedure ID (%d) for successfull outcome message\n",
                  (int)pdu->choice.successfulOutcome.procedureCode);
      return -1;
  }

  return 0;
}

static int m2ap_decode_unsuccessful_outcome(M2AP_M2AP_PDU_t *pdu)
{
  DevAssert(pdu != NULL);

  switch(pdu->choice.unsuccessfulOutcome.procedureCode) {
    case M2AP_ProcedureCode_id_sessionStart:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_sessionStop:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_m2Setup:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;
    case M2AP_ProcedureCode_id_mbmsSchedulingInformation:
      //asn_encode_to_new_buffer(NULL, ATS_CANONICAL_XER, &asn_DEF_M2AP_M2AP_PDU, pdu);
      M2AP_INFO("m2ap__decode_initiating_message!\n");
      break;


    default:
       M2AP_ERROR("Unknown procedure ID (%d) for unsuccessfull outcome message\n",
                  (int)pdu->choice.unsuccessfulOutcome.procedureCode);
      return -1;
  }

  return 0;
}

int m2ap_decode_pdu(M2AP_M2AP_PDU_t *pdu, const uint8_t *const buffer, uint32_t length)
{
  asn_dec_rval_t dec_ret;

  DevAssert(buffer != NULL);

  dec_ret = aper_decode(NULL,
                        &asn_DEF_M2AP_M2AP_PDU,
                        (void **)&pdu,
                        buffer,
                        length,
                        0,
                        0);
  if (asn1_xer_print) {
    xer_fprint(stdout, &asn_DEF_M2AP_M2AP_PDU, pdu);
  }

  if (dec_ret.code != RC_OK) {
    M2AP_ERROR("Failed to decode pdu\n");
    return -1;
  }

  switch(pdu->present) {
    case M2AP_M2AP_PDU_PR_initiatingMessage:
      return m2ap_decode_initiating_message(pdu);

    case M2AP_M2AP_PDU_PR_successfulOutcome:
      return m2ap_decode_successful_outcome(pdu);

    case M2AP_M2AP_PDU_PR_unsuccessfulOutcome:
      return m2ap_decode_unsuccessful_outcome(pdu);

    default:
      M2AP_DEBUG("Unknown presence (%d) or not implemented\n", (int)pdu->present);
      break;
  }


  return -1;
}