/** * Copyright 2013-2021 Software Radio Systems Limited * * This file is part of srsRAN. * * srsRAN is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * srsRAN is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * A copy of the GNU Affero General Public License can be found in * the LICENSE file in the top-level directory of this distribution * and at http://www.gnu.org/licenses/. * */ #ifndef SRSRAN_RRC_BEARER_CFG_H #define SRSRAN_RRC_BEARER_CFG_H #include "srsenb/hdr/stack/rrc/rrc_config.h" #include "srsran/asn1/s1ap.h" #include "srsran/interfaces/enb_gtpu_interfaces.h" #include "srsran/interfaces/enb_interfaces.h" #include "srsran/interfaces/enb_rrc_interface_types.h" #include "srsran/srslog/srslog.h" namespace srsenb { class security_cfg_handler { public: explicit security_cfg_handler(const rrc_cfg_t& cfg_) : cfg(&cfg_), logger(srslog::fetch_basic_logger("RRC")) {} security_cfg_handler& operator=(const security_cfg_handler& other) { cfg = other.cfg; k_enb_present = other.k_enb_present; security_capabilities = other.security_capabilities; std::copy(other.k_enb, other.k_enb + 32, k_enb); sec_cfg = other.sec_cfg; ncc = other.ncc; return *this; } bool set_security_capabilities(const asn1::s1ap::ue_security_cap_s& caps); void set_security_key(const asn1::fixed_bitstring<256, false, true>& key); void set_ncc(uint8_t ncc_) { ncc = ncc_; } asn1::rrc::security_algorithm_cfg_s get_security_algorithm_cfg(); const srsran::as_security_config_t& get_as_sec_cfg() const { return sec_cfg; } uint8_t get_ncc() const { return ncc; } bool is_as_sec_cfg_valid() const { return k_enb_present; } void regenerate_keys_handover(uint32_t new_pci, uint32_t new_dl_earfcn); private: void generate_as_keys(); srslog::basic_logger& logger; const rrc_cfg_t* cfg = nullptr; bool k_enb_present = false; asn1::s1ap::ue_security_cap_s security_capabilities = {}; uint8_t k_enb[32] = {}; // Provided by MME srsran::as_security_config_t sec_cfg = {}; uint8_t ncc = 0; }; class bearer_cfg_handler { public: struct erab_t { struct gtpu_tunnel { uint32_t teid_out = 0; uint32_t teid_in = 0; uint32_t addr = 0; }; uint8_t id = 0; asn1::s1ap::erab_level_qos_params_s qos_params; asn1::bounded_bitstring<1, 160, true, true> address; uint32_t teid_out = 0; uint32_t teid_in = 0; std::vector tunnels; }; bearer_cfg_handler(uint16_t rnti_, const rrc_cfg_t& cfg_, gtpu_interface_rrc* gtpu_); /// Called after RRCReestablishmentComplete, to add E-RABs of old rnti void reestablish_bearers(bearer_cfg_handler&& old_rnti_bearers); int add_erab(uint8_t erab_id, const asn1::s1ap::erab_level_qos_params_s& qos, const asn1::bounded_bitstring<1, 160, true, true>& addr, uint32_t teid_out, srsran::const_span nas_pdu, asn1::s1ap::cause_c& cause); int release_erab(uint8_t erab_id); void release_erabs(); int modify_erab(uint8_t erab_id, const asn1::s1ap::erab_level_qos_params_s& qos, srsran::const_span nas_pdu, asn1::s1ap::cause_c& cause); // Methods to apply bearer updates int add_gtpu_bearer(uint32_t erab_id); srsran::expected add_gtpu_bearer(uint32_t erab_id, uint32_t teid_out, uint32_t addr, const gtpu_interface_rrc::bearer_props* props = nullptr); void rem_gtpu_bearer(uint32_t erab_id); void fill_pending_nas_info(asn1::rrc::rrc_conn_recfg_r8_ies_s* msg); const std::map& get_erabs() const { return erabs; } const asn1::rrc::drb_to_add_mod_list_l& get_established_drbs() const { return current_drbs; } std::map > erab_info_list; std::map erabs; private: srslog::basic_logger* logger; uint16_t rnti = 0; const rrc_cfg_t* cfg = nullptr; gtpu_interface_rrc* gtpu = nullptr; // last cfg asn1::rrc::drb_to_add_mod_list_l current_drbs; }; } // namespace srsenb #endif // SRSRAN_RRC_BEARER_CFG_H