1. 05 Mar, 2019 5 commits
    • Konstantinos Alexandris's avatar
      x2: bug fixes · 470ca65f
      Konstantinos Alexandris authored
      - free correctly in rrc_eNB_free_mem_UE_context
      - check for existence of ue_context.handover_info in rrc_enb_process_itti_msg
      - check return value sctp_peeloff in sctp_handle_new_association_req_multi
        and exit in case of failure
      470ca65f
    • Konstantinos Alexandris's avatar
    • Konstantinos Alexandris's avatar
    • Konstantinos Alexandris's avatar
    • Konstantinos Alexandris's avatar
      bugfix: fix realtime issues with RRC (race condition) · 0b368829
      Konstantinos Alexandris authored
      When testing x2 handover, we found a race issue between the
      RRC thread and the phy/mac thread (which is calling rrc_rx_tx).
      
      The UE context was updated by the RRC thread but in the middle of
      the update (which consists of several function calls and variables'
      updates) the context was accessed by rrc_rx_tx. At this point, the
      context was in an inconsistent state.
      
      The solution is to access RRC data in the RRC thread only.
      The function rrc_rx_tx now just sends an ITTI message to the
      RRC thread. When receiving this message, the RRC thread does
      the processing that was done by the function rrc_rx_tx (in
      the new function rrc_subframe_process).
      
      This way, the race condition disappears.
      
      However we now send an ITTI message from the phy/mac thread to
      the RRC thread at each subframe. That might increase the processing
      time of the eNB. So maybe it's not the best solution. It may also
      improve the realtime performance because less work is done by the
      phy/mac realtime thread. To be checked somehow.
      
      Also, it may be possible that some other RRC functions are still
      called by the phy/mac thread, which should also be checked and
      replaced by ITTI messages (if this solution is considered to be
      correct).
      0b368829
  2. 04 Mar, 2019 2 commits
  3. 01 Mar, 2019 2 commits
  4. 28 Feb, 2019 5 commits
  5. 27 Feb, 2019 2 commits
    • Cedric Roux's avatar
      bugfix: fix PDCP sequence management (plus some cleanup) · 8e890ebe
      Cedric Roux authored
      With the introduction of X2AP into develop, the UEs now have to regularly
      send measurement reports.
      
      In the logs of the eNB, we see:
      
      [OSA]   Mismatch found in integrity for algorithm 2,
              got e0.a0.c2.66, expecting a5.9c.cb.57
      [PDCP]   [OSA][RB 1] eNB failed to validate MAC-I of incoming PDU
      
      This is a bug in the PDCP layer that uses wrong parameters to compute the
      integrity.
      
      This commit fixes this bug.
      
      The function pdcp_is_rx_seq_number_valid was removed. Its processing
      has been directly integrated into the function pdcp_data_ind.
      
      The function pdcp_mark_current_pdu_as_received is not called anymore.
      Its processing was not used later on, so as of today, not calling it does
      not introduce any functional change.
      
      The function pdcp_validate_security takes now as parameters both
      SN and HFN. Same for the function pdcp_get_next_count_rx.
      
      Useless constants PDCP_SN_5BIT, PDCP_SN_7BIT and PDCP_SN_12BIT have been
      removed.
      
      The compilation option ENABLE_SECURITY has been removed. It's now always
      on. (This may impact some use cases.)
      
      The PDCP for DRB using RLC AM is not correct. It was not correct before
      this commit (apart from the integrity bug). We should deal with a list
      of PDUs and transmit packets to upper layers as detailed in the specs.
      Today we transmit the PDU as soon as we get it. We don't care about
      duplicates, in-order delivery, timeouts.
      
      Also, we don't deal with "PDCP re-establishment". Not sure how that impacts
      the software.
      
      And, last but not least, there is still no ROHC.
      8e890ebe
    • Raphael Defosseux's avatar
  6. 26 Feb, 2019 2 commits
  7. 25 Feb, 2019 4 commits
  8. 22 Feb, 2019 6 commits
  9. 21 Feb, 2019 1 commit
  10. 20 Feb, 2019 5 commits
  11. 19 Feb, 2019 5 commits
  12. 18 Feb, 2019 1 commit