25#include "ns3/fatal-error.h" 
   27#include "ns3/object-factory.h" 
   28#include "ns3/object-map.h" 
   29#include "ns3/simulator.h" 
   86    m_rrc->DoSetTemporaryCellRnti(rnti);
 
 
   92    m_rrc->DoNotifyRandomAccessSuccessful();
 
 
   98    m_rrc->DoNotifyRandomAccessFailed();
 
 
  176            .AddAttribute(
"DataRadioBearerMap",
 
  177                          "List of UE RadioBearerInfo for Data Radio Bearers by LCID.",
 
  181            .AddAttribute(
"Srb0",
 
  182                          "SignalingRadioBearerInfo for SRB0",
 
  186            .AddAttribute(
"Srb1",
 
  187                          "SignalingRadioBearerInfo for SRB1",
 
  191            .AddAttribute(
"CellId",
 
  192                          "Serving cell identifier",
 
  196            .AddAttribute(
"C-RNTI",
 
  197                          "Cell Radio Network Temporary Identifier",
 
  203                "Timer for the RRC Connection Establishment procedure " 
  204                "(i.e., the procedure is deemed as failed if it takes longer than this). " 
  205                "Standard values: 100ms, 200ms, 300ms, 400ms, 600ms, 1000ms, 1500ms, 2000ms",
 
  212                "Timer for detecting the Radio link failure " 
  213                "(i.e., the radio link is deemed as failed if this timer expires). " 
  214                "Standard values: 0ms 50ms, 100ms, 200ms, 500ms, 1000ms, 2000ms",
 
  221                "This specifies the maximum number of out-of-sync indications. " 
  222                "Standard values: 1, 2, 3, 4, 6, 8, 10, 20",
 
  228                "This specifies the maximum number of in-sync indications. " 
  229                "Standard values: 1, 2, 3, 4, 5, 6, 8, 10",
 
  233            .AddTraceSource(
"MibReceived",
 
  234                            "trace fired upon reception of Master Information Block",
 
  236                            "ns3::LteUeRrc::MibSibHandoverTracedCallback")
 
  237            .AddTraceSource(
"Sib1Received",
 
  238                            "trace fired upon reception of System Information Block Type 1",
 
  240                            "ns3::LteUeRrc::MibSibHandoverTracedCallback")
 
  241            .AddTraceSource(
"Sib2Received",
 
  242                            "trace fired upon reception of System Information Block Type 2",
 
  244                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  245            .AddTraceSource(
"StateTransition",
 
  246                            "trace fired upon every UE RRC state transition",
 
  248                            "ns3::LteUeRrc::StateTracedCallback")
 
  249            .AddTraceSource(
"InitialCellSelectionEndOk",
 
  250                            "trace fired upon successful initial cell selection procedure",
 
  252                            "ns3::LteUeRrc::CellSelectionTracedCallback")
 
  253            .AddTraceSource(
"InitialCellSelectionEndError",
 
  254                            "trace fired upon failed initial cell selection procedure",
 
  256                            "ns3::LteUeRrc::CellSelectionTracedCallback")
 
  257            .AddTraceSource(
"RandomAccessSuccessful",
 
  258                            "trace fired upon successful completion of the random access procedure",
 
  260                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  261            .AddTraceSource(
"RandomAccessError",
 
  262                            "trace fired upon failure of the random access procedure",
 
  264                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  265            .AddTraceSource(
"ConnectionEstablished",
 
  266                            "trace fired upon successful RRC connection establishment",
 
  268                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  269            .AddTraceSource(
"ConnectionTimeout",
 
  270                            "trace fired upon timeout RRC connection establishment because of T300",
 
  272                            "ns3::LteUeRrc::ImsiCidRntiCountTracedCallback")
 
  273            .AddTraceSource(
"ConnectionReconfiguration",
 
  274                            "trace fired upon RRC connection reconfiguration",
 
  276                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  277            .AddTraceSource(
"HandoverStart",
 
  278                            "trace fired upon start of a handover procedure",
 
  280                            "ns3::LteUeRrc::MibSibHandoverTracedCallback")
 
  281            .AddTraceSource(
"HandoverEndOk",
 
  282                            "trace fired upon successful termination of a handover procedure",
 
  284                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  285            .AddTraceSource(
"HandoverEndError",
 
  286                            "trace fired upon failure of a handover procedure",
 
  288                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  289            .AddTraceSource(
"SCarrierConfigured",
 
  290                            "trace fired after configuring secondary carriers",
 
  292                            "ns3::LteUeRrc::SCarrierConfiguredTracedCallback")
 
  293            .AddTraceSource(
"Srb1Created",
 
  294                            "trace fired after SRB1 is created",
 
  296                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  297            .AddTraceSource(
"DrbCreated",
 
  298                            "trace fired after DRB is created",
 
  300                            "ns3::LteUeRrc::ImsiCidRntiLcIdTracedCallback")
 
  301            .AddTraceSource(
"RadioLinkFailure",
 
  302                            "trace fired upon failure of radio link",
 
  304                            "ns3::LteUeRrc::ImsiCidRntiTracedCallback")
 
  307                "trace fired upon receiving in Sync or out of Sync indications from UE PHY",
 
  309                "ns3::LteUeRrc::PhySyncDetectionTracedCallback");
 
 
  463        if (cellId == cphySap->GetCellId())
 
 
  534    m_srb0->m_srbIdentity = 0;
 
 
  587        params.pdcpSdu = packet;
 
  589        params.lcid = it->second->m_logicalChannelIdentity;
 
  591        NS_LOG_LOGIC(
this << 
" RNTI=" << 
m_rnti << 
" sending packet " << packet << 
" on DRBID " 
  593                          << 
" (" << packet->GetSize() << 
" bytes)");
 
  594        it->second->m_pdcp->GetLtePdcpSapProvider()->TransmitPdcpSdu(params);
 
 
  670        m_rrcSapUser->SendRrcConnectionReconfigurationCompleted(msg);
 
 
  868                      "Cell identity in SIB1 does not match with the originating cell");
 
  883                      "Cell identity in SIB1 does not match with the originating cell");
 
 
  905    bool triggering = 
true;
 
  906    for (
auto newMeasIt = params.m_ueMeasurementsList.begin();
 
  907         newMeasIt != params.m_ueMeasurementsList.end();
 
  910        if (params.m_componentCarrierId != 0)
 
  919                           params.m_componentCarrierId);
 
 
  947    m_srb0->m_rlc->SetLteRlcSapUser(params.srb0SapUser);
 
  950        m_srb1->m_pdcp->SetLtePdcpSapUser(params.srb1SapUser);
 
 
  982            rc.connEstFailCount =
 
  987                                                           << 
"of connEstFailCount");
 
 
 1025                        "Sync indications should be zero " 
 1026                        "when a new RRC connection is established. Current value = " 
 
 1041    NS_LOG_INFO(
"DoRecvRrcConnectionReconfiguration haveNonCriticalExtension:" 
 1059                cmacSapProvider->Reset();
 
 1063                cphySapProvider->Reset();
 
 1078                "handover is only supported with non-contention-based random access procedure");
 
 1101                                  << 
" Handover. Configuring secondary carriers");
 
 1130            m_rrcSapUser->SendRrcConnectionReconfigurationCompleted(msg2);
 
 
 1230    uint16_t maxRsrpCellId = 0;
 
 1231    double maxRsrp = -std::numeric_limits<double>::infinity();
 
 1232    double minRsrp = -140.0; 
 
 1240        if (maxRsrp < it->
second.rsrp && it->second.rsrp > minRsrp)
 
 1245                maxRsrpCellId = it->first;
 
 1246                maxRsrp = it->second.rsrp;
 
 1251    if (maxRsrpCellId == 0)
 
 1253        NS_LOG_WARN(
this << 
" Cell search is unable to detect surrounding cell to attach to");
 
 1258                          << 
" is the strongest untried surrounding cell");
 
 
 1271    uint16_t cellId = 
m_lastSib1.cellAccessRelatedInfo.cellIdentity;
 
 1275    bool isSuitableCell = 
false;
 
 1276    bool isAcceptableCell = 
false;
 
 1278    double qRxLevMeas = storedMeasIt->second.rsrp;
 
 1281    NS_LOG_LOGIC(
this << 
" cell selection to cellId=" << cellId << 
" qrxlevmeas=" << qRxLevMeas
 
 1283                      << 
" qrxlevmin=" << qRxLevMin << 
" dBm");
 
 1285    if (qRxLevMeas - qRxLevMin > 0)
 
 1287        isAcceptableCell = 
true;
 
 1290        bool cellCsgIndication = 
m_lastSib1.cellAccessRelatedInfo.csgIndication;
 
 1292        isSuitableCell = (!cellCsgIndication || cellCsgId == 
m_csgWhiteList);
 
 1295                          << 
"/" << cellCsgIndication);
 
 1330        if (isAcceptableCell)
 
 
 1360        uint8_t ccId = scell.sCellIndex;
 
 1362        uint16_t physCellId = scell.cellIdentification.physCellId;
 
 1364            scell.radioResourceConfigCommonSCell.ulConfiguration.ulFreqInfo.ulBandwidth;
 
 1366            scell.radioResourceConfigCommonSCell.ulConfiguration.ulFreqInfo.ulCarrierFreq;
 
 1367        uint16_t dlBand = scell.radioResourceConfigCommonSCell.nonUlConfiguration.dlBandwidth;
 
 1368        uint32_t dlEarfcn = scell.cellIdentification.dlCarrierFreq;
 
 1369        uint8_t txMode = scell.radioResourceConfigDedicatedSCell.physicalConfigDedicatedSCell
 
 1370                             .antennaInfo.transmissionMode;
 
 1371        uint16_t srsIndex = scell.radioResourceConfigDedicatedSCell.physicalConfigDedicatedSCell
 
 1372                                .soundingRsUlConfigDedicated.srsConfigIndex;
 
 1378            scell.radioResourceConfigCommonSCell.nonUlConfiguration.pdschConfigCommon
 
 1379                .referenceSignalPower);
 
 1385            scell.radioResourceConfigDedicatedSCell.physicalConfigDedicatedSCell
 
 1386                .pdschConfigDedicated;
 
 
 1426                          "unexpected state " << 
m_state);
 
 1427            NS_ASSERT_MSG(stamIt->srbIdentity == 1, 
"only SRB1 supported");
 
 1429            const uint8_t lcid = 1; 
 
 1438            pdcp->SetLcId(lcid);
 
 1440            pdcp->SetLteRlcSapProvider(rlc->GetLteRlcSapProvider());
 
 1441            rlc->SetLteRlcSapUser(pdcp->GetLteRlcSapUser());
 
 1446            m_srb1->m_srbIdentity = 1;
 
 1449            m_srb1->m_logicalChannelConfig.priority = stamIt->logicalChannelConfig.priority;
 
 1450            m_srb1->m_logicalChannelConfig.prioritizedBitRateKbps =
 
 1451                stamIt->logicalChannelConfig.prioritizedBitRateKbps;
 
 1452            m_srb1->m_logicalChannelConfig.bucketSizeDurationMs =
 
 1453                stamIt->logicalChannelConfig.bucketSizeDurationMs;
 
 1454            m_srb1->m_logicalChannelConfig.logicalChannelGroup =
 
 1455                stamIt->logicalChannelConfig.logicalChannelGroup;
 
 1458            lcConfig.
priority = stamIt->logicalChannelConfig.priority;
 
 1475            NS_LOG_INFO(
"request to modify SRB1 (skipping as currently not implemented)");
 
 1483                         << (
uint32_t)dtamIt->drbIdentity << 
" LC " 
 1484                         << (
uint32_t)dtamIt->logicalChannelIdentity);
 
 1486                      "LCID value " << dtamIt->logicalChannelIdentity << 
" is reserved for SRBs");
 
 1488        auto drbMapIt = 
m_drbMap.find(dtamIt->drbIdentity);
 
 1500                switch (dtamIt->rlcConfig.choice)
 
 1521            rlc->SetLcId(dtamIt->logicalChannelIdentity);
 
 1524            drbInfo->m_rlc = rlc;
 
 1525            drbInfo->m_epsBearerIdentity = dtamIt->epsBearerIdentity;
 
 1526            drbInfo->m_logicalChannelIdentity = dtamIt->logicalChannelIdentity;
 
 1527            drbInfo->m_drbIdentity = dtamIt->drbIdentity;
 
 1535                pdcp->SetLcId(dtamIt->logicalChannelIdentity);
 
 1537                pdcp->SetLteRlcSapProvider(rlc->GetLteRlcSapProvider());
 
 1538                rlc->SetLteRlcSapUser(pdcp->GetLteRlcSapUser());
 
 1539                drbInfo->m_pdcp = pdcp;
 
 1550            lcConfig.
priority = dtamIt->logicalChannelConfig.priority;
 
 1557                              << (uint16_t)dtamIt->logicalChannelIdentity);
 
 1559            std::vector<LteUeCcmRrcSapProvider::LcsConfig> lcOnCcMapping =
 
 1562                                           rlc->GetLteMacSapUser());
 
 1564            NS_LOG_DEBUG(
"Size of lcOnCcMapping vector " << lcOnCcMapping.size());
 
 1565            auto itLcOnCcMapping = lcOnCcMapping.begin();
 
 1567                          "Component carrier manager failed to add LC for data radio bearer");
 
 1569            for (itLcOnCcMapping = lcOnCcMapping.begin(); itLcOnCcMapping != lcOnCcMapping.end();
 
 1573                                     << (uint16_t)itLcOnCcMapping->lcConfig.logicalChannelGroup
 
 1574                                     << 
" ComponentCarrierId " 
 1575                                     << (uint16_t)itLcOnCcMapping->componentCarrierId);
 
 1576                uint8_t index = itLcOnCcMapping->componentCarrierId;
 
 1578                    itLcOnCcMapping->lcConfig;
 
 1599        uint8_t drbid = *dtdmIt;
 
 
 1623        uint8_t measObjectId = *it;
 
 1629            if (measIdIt->second.measObjectId == measObjectId)
 
 1631                uint8_t measId = measIdIt->second.measId;
 
 1634                                  << 
" because referring to measObjectId " 
 1651        NS_ASSERT_MSG(it->measObjectEutra.cellsToRemoveList.empty(),
 
 1652                      "cellsToRemoveList not supported");
 
 1653        NS_ASSERT_MSG(it->measObjectEutra.cellsToAddModList.empty(),
 
 1654                      "cellsToAddModList not supported");
 
 1655        NS_ASSERT_MSG(it->measObjectEutra.cellsToRemoveList.empty(),
 
 1656                      "blackCellsToRemoveList not supported");
 
 1657        NS_ASSERT_MSG(it->measObjectEutra.blackCellsToAddModList.empty(),
 
 1658                      "blackCellsToAddModList not supported");
 
 1659        NS_ASSERT_MSG(it->measObjectEutra.haveCellForWhichToReportCGI == 
false,
 
 1660                      "cellForWhichToReportCGI is not supported");
 
 1662        uint8_t measObjectId = it->measObjectId;
 
 1663        auto measObjectIt = 
m_varMeasConfig.measObjectList.find(measObjectId);
 
 1667            measObjectIt->second = *it;
 
 1672                if (measIdIt->second.measObjectId == measObjectId)
 
 1674                    uint8_t measId = measIdIt->second.measId;
 
 1676                                      << 
" referring to measObjectId " << (
uint32_t)measObjectId);
 
 1692        uint8_t reportConfigId = *it;
 
 1698            if (measIdIt->second.reportConfigId == reportConfigId)
 
 1700                uint8_t measId = measIdIt->second.measId;
 
 1703                                  << 
" because referring to reportConfigId " 
 1722                      "only trigger type EVENT is supported");
 
 1724        uint8_t reportConfigId = it->reportConfigId;
 
 1725        auto reportConfigIt = 
m_varMeasConfig.reportConfigList.find(reportConfigId);
 
 1729                                           << 
" exists, updating entry");
 
 1735                if (measIdIt->second.reportConfigId == reportConfigId)
 
 1737                    uint8_t measId = measIdIt->second.measId;
 
 1739                                      << 
" referring to reportConfigId " 
 1782        uint8_t measId = *it;
 
 1796                          << 
" (measObjectId=" << (
uint32_t)it->measObjectId
 
 1797                          << 
", reportConfigId=" << (
uint32_t)it->reportConfigId << 
")");
 
 1806            measReportIt->second.periodicReportTimer.Cancel();
 
 1810                      ->second.reportConfigEutra.triggerType !=
 
 1814        std::list<PendingTrigger_t> s;
 
 
 1839                             bool useLayer3Filtering,
 
 1840                             uint8_t componentCarrierId)
 
 1842    NS_LOG_FUNCTION(
this << cellId << +componentCarrierId << rsrp << rsrq << useLayer3Filtering);
 
 1848        if (useLayer3Filtering)
 
 1851            storedMeasIt->second.rsrp = (1 - 
m_varMeasConfig.aRsrp) * storedMeasIt->second.rsrp +
 
 1854            if (std::isnan(storedMeasIt->second.rsrq))
 
 1857                storedMeasIt->second.rsrq = rsrq; 
 
 1861                storedMeasIt->second.rsrq =
 
 1868            storedMeasIt->second.rsrp = rsrp;
 
 1869            storedMeasIt->second.rsrq = rsrq;
 
 1880        std::pair<uint16_t, MeasValues> val(cellId, v);
 
 1882        NS_ASSERT_MSG(ret.second == 
true, 
"element already existed");
 
 1883        storedMeasIt = ret.first;
 
 1887                      << 
", carrier component Id " << componentCarrierId << 
", new RSRP " << rsrp
 
 1888                      << 
" stored " << storedMeasIt->second.rsrp << 
", new RSRQ " << rsrq
 
 1889                      << 
" stored " << storedMeasIt->second.rsrq);
 
 
 1899    NS_ASSERT(measIdIt->first == measIdIt->second.measId);
 
 1901    auto reportConfigIt = 
m_varMeasConfig.reportConfigList.find(measIdIt->second.reportConfigId);
 
 1905    auto measObjectIt = 
m_varMeasConfig.measObjectList.find(measIdIt->second.measObjectId);
 
 1915                  "only triggerType == event is supported");
 
 1919    bool eventEntryCondApplicable = 
false;
 
 1920    bool eventLeavingCondApplicable = 
false;
 
 1931    uint16_t servingCellId = 0;
 
 1934        if (cphySapProvider->GetDlEarfcn() == measObjectEutra.
carrierFreq)
 
 1936            servingCellId = cphySapProvider->GetCellId();
 
 1940    if (servingCellId == 0)
 
 1945    switch (reportConfigEutra.
eventId)
 
 1980        bool entryCond = ms - hys > thresh;
 
 1984            if (!isMeasIdInReportList)
 
 1986                concernedCellsEntry.push_back(servingCellId);
 
 1987                eventEntryCondApplicable = 
true;
 
 1995                NS_ASSERT(measReportIt->second.cellsTriggeredList.find(servingCellId) !=
 
 1996                          measReportIt->second.cellsTriggeredList.end());
 
 2005        bool leavingCond = ms + hys < thresh;
 
 2009            if (isMeasIdInReportList)
 
 2016                          measReportIt->second.cellsTriggeredList.end());
 
 2017                concernedCellsLeaving.push_back(
m_cellId);
 
 2018                eventLeavingCondApplicable = 
true;
 
 2026        NS_LOG_LOGIC(
this << 
" event A1: serving cell " << servingCellId << 
" ms=" << ms
 
 2027                          << 
" thresh=" << thresh << 
" entryCond=" << entryCond
 
 2028                          << 
" leavingCond=" << leavingCond);
 
 2065        bool entryCond = ms + hys < thresh;
 
 2069            if (!isMeasIdInReportList)
 
 2071                concernedCellsEntry.push_back(servingCellId);
 
 2072                eventEntryCondApplicable = 
true;
 
 2080                NS_ASSERT(measReportIt->second.cellsTriggeredList.find(servingCellId) !=
 
 2081                          measReportIt->second.cellsTriggeredList.end());
 
 2090        bool leavingCond = ms - hys > thresh;
 
 2094            if (isMeasIdInReportList)
 
 2100                NS_ASSERT(measReportIt->second.cellsTriggeredList.find(servingCellId) !=
 
 2101                          measReportIt->second.cellsTriggeredList.end());
 
 2102                concernedCellsLeaving.push_back(servingCellId);
 
 2103                eventLeavingCondApplicable = 
true;
 
 2111        NS_LOG_LOGIC(
this << 
" event A2: serving cell " << servingCellId << 
" ms=" << ms
 
 2112                          << 
" thresh=" << thresh << 
" entryCond=" << entryCond
 
 2113                          << 
" leavingCond=" << leavingCond);
 
 2125        double ofn = measObjectEutra
 
 2129        double ofp = measObjectEutra
 
 2159            uint16_t cellId = storedMeasIt->first;
 
 2175                mn = storedMeasIt->second.rsrp;
 
 2178                mn = storedMeasIt->second.rsrq;
 
 2186                isMeasIdInReportList && (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2187                                         measReportIt->second.cellsTriggeredList.end());
 
 2190            bool entryCond = mn + ofn + ocn - hys > mp + ofp + ocp + off;
 
 2196                    concernedCellsEntry.push_back(cellId);
 
 2197                    eventEntryCondApplicable = 
true;
 
 2206            bool leavingCond = mn + ofn + ocn + hys < mp + ofp + ocp + off;
 
 2212                    concernedCellsLeaving.push_back(cellId);
 
 2213                    eventLeavingCondApplicable = 
true;
 
 2221            NS_LOG_LOGIC(
this << 
" event A3: neighbor cell " << cellId << 
" mn=" << mn
 
 2222                              << 
" mp=" << mp << 
" offset=" << off << 
" entryCond=" << entryCond
 
 2223                              << 
" leavingCond=" << leavingCond);
 
 2236        double ofn = measObjectEutra
 
 2265            uint16_t cellId = storedMeasIt->first;
 
 2274                mn = storedMeasIt->second.rsrp;
 
 2277                mn = storedMeasIt->second.rsrq;
 
 2285                isMeasIdInReportList && (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2286                                         measReportIt->second.cellsTriggeredList.end());
 
 2289            bool entryCond = mn + ofn + ocn - hys > thresh;
 
 2295                    concernedCellsEntry.push_back(cellId);
 
 2296                    eventEntryCondApplicable = 
true;
 
 2305            bool leavingCond = mn + ofn + ocn + hys < thresh;
 
 2311                    concernedCellsLeaving.push_back(cellId);
 
 2312                    eventLeavingCondApplicable = 
true;
 
 2320            NS_LOG_LOGIC(
this << 
" event A4: neighbor cell " << cellId << 
" mn=" << mn
 
 2321                              << 
" thresh=" << thresh << 
" entryCond=" << entryCond
 
 2322                              << 
" leavingCond=" << leavingCond);
 
 2337        double ofn = measObjectEutra
 
 2372        bool entryCond = mp + hys < thresh1;
 
 2380                uint16_t cellId = storedMeasIt->first;
 
 2389                    mn = storedMeasIt->second.rsrp;
 
 2392                    mn = storedMeasIt->second.rsrq;
 
 2400                    isMeasIdInReportList && (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2401                                             measReportIt->second.cellsTriggeredList.end());
 
 2405                entryCond = mn + ofn + ocn - hys > thresh2;
 
 2411                        concernedCellsEntry.push_back(cellId);
 
 2412                        eventEntryCondApplicable = 
true;
 
 2420                NS_LOG_LOGIC(
this << 
" event A5: neighbor cell " << cellId << 
" mn=" << mn
 
 2421                                  << 
" mp=" << mp << 
" thresh2=" << thresh2
 
 2422                                  << 
" thresh1=" << thresh1 << 
" entryCond=" << entryCond);
 
 2428                              << 
" thresh1=" << thresh1 << 
" entryCond=" << entryCond);
 
 2436        if (isMeasIdInReportList)
 
 2439            bool leavingCond = mp - hys > thresh1;
 
 2451                        uint16_t cellId = storedMeasIt->first;
 
 2457                        if (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2458                            measReportIt->second.cellsTriggeredList.end())
 
 2460                            concernedCellsLeaving.push_back(cellId);
 
 2461                            eventLeavingCondApplicable = 
true;
 
 2473                        uint16_t cellId = storedMeasIt->first;
 
 2479                        if (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2480                            measReportIt->second.cellsTriggeredList.end())
 
 2485                                mn = storedMeasIt->second.rsrp;
 
 2488                                mn = storedMeasIt->second.rsrq;
 
 2497                            leavingCond = mn + ofn + ocn + hys < thresh2;
 
 2509                            concernedCellsLeaving.push_back(cellId);
 
 2510                            eventLeavingCondApplicable = 
true;
 
 2512                            NS_LOG_LOGIC(
this << 
" event A5: neighbor cell " << cellId
 
 2513                                              << 
" mn=" << mn << 
" mp=" << mp
 
 2514                                              << 
" thresh2=" << thresh2 << 
" thresh1=" << thresh1
 
 2515                                              << 
" leavingCond=" << leavingCond);
 
 2521                                  << 
" thresh1=" << thresh1 << 
" leavingCond=" << leavingCond);
 
 2536                    uint16_t cellId = storedMeasIt->first;
 
 2542                    if (measReportIt->second.cellsTriggeredList.find(cellId) !=
 
 2543                        measReportIt->second.cellsTriggeredList.end())
 
 2548                            mn = storedMeasIt->second.rsrp;
 
 2551                            mn = storedMeasIt->second.rsrq;
 
 2559                        leavingCond = mn + ofn + ocn + hys < thresh2;
 
 2563                            concernedCellsLeaving.push_back(cellId);
 
 2564                            eventLeavingCondApplicable = 
true;
 
 2567                        NS_LOG_LOGIC(
this << 
" event A5: neighbor cell " << cellId << 
" mn=" << mn
 
 2568                                          << 
" mp=" << mp << 
" thresh2=" << thresh2 << 
" thresh1=" 
 2569                                          << thresh1 << 
" leavingCond=" << leavingCond);
 
 2583    NS_LOG_LOGIC(
this << 
" eventEntryCondApplicable=" << eventEntryCondApplicable
 
 2584                      << 
" eventLeavingCondApplicable=" << eventLeavingCondApplicable);
 
 2586    if (eventEntryCondApplicable)
 
 2601                                          concernedCellsEntry);
 
 2604            enteringTriggerIt->second.push_back(t);
 
 2608    if (eventLeavingCondApplicable)
 
 2611        bool reportOnLeave =
 
 2628                                          concernedCellsLeaving,
 
 2632            leavingTriggerIt->second.push_back(t);
 
 
 2645    if (!it1->second.empty())
 
 2647        for (
auto it2 = it1->second.begin(); it2 != it1->second.end(); ++it2)
 
 2650            NS_LOG_LOGIC(
this << 
" canceling entering time-to-trigger event at " 
 2655        it1->second.clear();
 
 
 2667    auto it2 = it1->second.begin();
 
 2668    while (it2 != it1->second.end())
 
 2672        it2->concernedCells.remove_if([cellId](
auto cell) { 
return cellId == cell; });
 
 2674        if (it2->concernedCells.empty())
 
 2676            NS_LOG_LOGIC(
this << 
" canceling entering time-to-trigger event at " 
 2679            it2 = it1->second.erase(it2);
 
 
 2696    if (!it1->second.empty())
 
 2698        for (
auto it2 = it1->second.begin(); it2 != it1->second.end(); ++it2)
 
 2701            NS_LOG_LOGIC(
this << 
" canceling leaving time-to-trigger event at " 
 2706        it1->second.clear();
 
 
 2718    auto it2 = it1->second.begin();
 
 2719    while (it2 != it1->second.end())
 
 2723        it2->concernedCells.remove_if([cellId](
auto cell) { 
return cellId == cell; });
 
 2725        if (it2->concernedCells.empty())
 
 2727            NS_LOG_LOGIC(
this << 
" canceling leaving time-to-trigger event at " 
 2730            it2 = it1->second.erase(it2);
 
 
 2751        std::pair<uint8_t, VarMeasReport> val(measId, r);
 
 2753        NS_ASSERT_MSG(ret.second == 
true, 
"element already existed");
 
 2754        measReportIt = ret.first;
 
 2759    for (
auto it = enteringCells.begin(); it != enteringCells.end(); ++it)
 
 2761        measReportIt->second.cellsTriggeredList.insert(*it);
 
 2764    NS_ASSERT(!measReportIt->second.cellsTriggeredList.empty());
 
 2767    if (!measReportIt->second.periodicReportTimer.IsPending())
 
 2769        measReportIt->second.numberOfReportsSent = 0;
 
 2770        measReportIt->second.periodicReportTimer =
 
 2779    if (!enteringTriggerIt->second.empty())
 
 2787        enteringTriggerIt->second.pop_front();
 
 2789        if (!enteringTriggerIt->second.empty())
 
 2796            for (
auto it = enteringCells.begin(); it != enteringCells.end(); ++it)
 
 
 2813    for (
auto it = leavingCells.begin(); it != leavingCells.end(); ++it)
 
 2815        measReportIt->second.cellsTriggeredList.erase(*it);
 
 2824    if (measReportIt->second.cellsTriggeredList.empty())
 
 2826        measReportIt->second.periodicReportTimer.Cancel();
 
 2832    if (!leavingTriggerIt->second.empty())
 
 2840        leavingTriggerIt->second.pop_front();
 
 2842        if (!leavingTriggerIt->second.empty())
 
 2849            for (
auto it = leavingCells.begin(); it != leavingCells.end(); ++it)
 
 
 2866        NS_LOG_LOGIC(
this << 
" deleting existing report for measId " << (uint16_t)measId);
 
 2867        measReportIt->second.periodicReportTimer.Cancel();
 
 
 2884    auto reportConfigIt = 
m_varMeasConfig.reportConfigList.find(measIdIt->second.reportConfigId);
 
 2890    measResults.
measId = measId;
 
 2908                         << servingMeasIt->second.rsrp
 
 2912                         << servingMeasIt->second.rsrq << 
" dB)");
 
 2916             componentCarrierId++)
 
 2924                measResultServFreq.
servFreqId = componentCarrierId;
 
 2937        if (!(measReportIt->second.cellsTriggeredList.empty()))
 
 2939            std::multimap<double, uint16_t> sortedNeighCells;
 
 2940            for (
auto cellsTriggeredIt = measReportIt->second.cellsTriggeredList.begin();
 
 2941                 cellsTriggeredIt != measReportIt->second.cellsTriggeredList.end();
 
 2944                uint16_t cellId = *cellsTriggeredIt;
 
 2948                    double triggerValue;
 
 2952                        triggerValue = neighborMeasIt->second.rsrp;
 
 2955                        triggerValue = neighborMeasIt->second.rsrq;
 
 2961                    sortedNeighCells.insert(std::pair<double, uint16_t>(triggerValue, cellId));
 
 2965            std::multimap<double, uint16_t>::reverse_iterator sortedNeighCellsIt;
 
 2967            for (sortedNeighCellsIt = sortedNeighCells.rbegin(), count = 0;
 
 2968                 sortedNeighCellsIt != sortedNeighCells.rend() &&
 
 2970                 ++sortedNeighCellsIt, ++count)
 
 2972                uint16_t cellId = sortedNeighCellsIt->second;
 
 2987                                 << neighborMeasIt->second.rsrp << 
" dBm)" 
 2989                                 << neighborMeasIt->second.rsrq << 
" dB)");
 
 2996            NS_LOG_WARN(
this << 
" cellsTriggeredList is empty");
 
 3004        measReportIt->second.numberOfReportsSent++;
 
 3005        measReportIt->second.periodicReportTimer.Cancel();
 
 3007        Time reportInterval;
 
 3038            reportInterval = 
Seconds(360);
 
 3041            reportInterval = 
Seconds(720);
 
 3044            reportInterval = 
Seconds(1800);
 
 3047            reportInterval = 
Seconds(3600);
 
 3056        measReportIt->second.periodicReportTimer =
 
 3060        m_rrcSapUser->SendMeasurementReport(measurementReport);
 
 
 3186            NS_LOG_INFO(
"Starting initial cell selection after RLF");
 
 
 3254    NS_LOG_INFO(
this << 
" Total Number of Sync indications from PHY " 
 
 3275    NS_LOG_DEBUG(
"The number of sync indication received by RRC from PHY: " 
 
 3292    std::ostringstream ss;
 
 
 3303        return os << 
"IDLE_START";
 
 3305        return os << 
"IDLE_CELL_SEARCH";
 
 3307        return os << 
"IDLE_WAIT_MIB_SIB1";
 
 3309        return os << 
"IDLE_WAIT_MIB";
 
 3311        return os << 
"IDLE_WAIT_SIB1";
 
 3313        return os << 
"IDLE_CAMPED_NORMALLY";
 
 3315        return os << 
"IDLE_WAIT_SIB2";
 
 3317        return os << 
"IDLE_RANDOM_ACCESS";
 
 3319        return os << 
"IDLE_CONNECTING";
 
 3321        return os << 
"CONNECTED_NORMALLY";
 
 3323        return os << 
"CONNECTED_HANDOVER";
 
 3325        return os << 
"CONNECTED_PHY_PROBLEM";
 
 3327        return os << 
"CONNECTED_REESTABLISHING";
 
 3329        return os << 
"NUM_STATES";
 
 3331    return os << 
"UNKNOWN(" << 
static_cast<uint32_t>(state) << 
")";
 
 
static uint8_t Dbm2RsrpRange(double dbm)
convert an RSRP value in dBm to the corresponding range as per 3GPP TS 36.133 section 9....
static double RsrpRange2Dbm(uint8_t range)
converts an RSRP range to dBm as per 3GPP TS 36.133 section 9.1.4 RSRP Measurement Report Mapping
static double RsrqRange2Db(uint8_t range)
converts an RSRQ range to dB as per 3GPP TS 36.133 section 9.1.7 RSRQ Measurement Report Mapping
static double IeValue2ActualQRxLevMin(int8_t qRxLevMinIeValue)
Returns the actual value of an Q-RxLevMin parameter.
static double IeValue2ActualHysteresis(uint8_t hysteresisIeValue)
Returns the actual value of a hysteresis parameter.
static uint8_t Db2RsrqRange(double db)
convert an RSRQ value in dB to the corresponding range as per 3GPP TS 36.133 section 9....
static double IeValue2ActualA3Offset(int8_t a3OffsetIeValue)
Returns the actual value of an a3-Offset parameter.
This class implements the Access Stratum (AS) Service Access Point (SAP), i.e., the interface between...
This class implements the Access Stratum (AS) Service Access Point (SAP), i.e., the interface between...
Service Access Point (SAP) offered by the MAC to the RLC See Femto Forum MAC Scheduler Interface Spec...
Service Access Point (SAP) offered by the MAC to the RLC See Femto Forum MAC Scheduler Interface Spec...
static TypeId GetTypeId()
Get the type ID.
This abstract base class defines the API to interact with the Radio Link Control (LTE_RLC) in LTE,...
static TypeId GetTypeId()
Get the type ID.
static TypeId GetTypeId()
Get the type ID.
static double ConvertPdschConfigDedicated2Double(PdschConfigDedicated pdschConfigDedicated)
Convert PDSCH config dedicated function.
Service Access Point (SAP) offered by the UE component carrier manager to the UE RRC.
Service Access Point (SAP) offered by the UE RRC to the UE CCM.
Service Access Point (SAP) offered by the UE MAC to the UE RRC.
Service Access Point (SAP) offered by the UE MAC to the UE RRC.
Service Access Point (SAP) offered by the UE PHY to the UE RRC for control purposes.
Service Access Point (SAP) offered by the UE PHY to the UE RRC for control purposes.
friend class MemberLteUeCcmRrcSapUser< LteUeRrc >
allow MemberLteUeCcmRrcSapUser<LteUeRrc> class friend access
void DoRecvRrcConnectionReconfiguration(LteRrcSap::RrcConnectionReconfiguration msg)
Part of the RRC protocol.
uint8_t m_lastRrcTransactionIdentifier
last RRC transaction identifier
bool m_connectionPending
True if a connection request by upper layers is pending.
bool m_hasReceivedSib1
True if SIB1 was received for the current cell.
void SendMeasurementReport(uint8_t measId)
Produce a proper measurement report from the given measurement identity's reporting entry in m_varMea...
std::map< uint8_t, std::list< PendingTrigger_t > > m_enteringTriggerQueue
List of triggers that were raised because entering condition have been true, but are still delayed fr...
void DoCompleteSetup(LteUeRrcSapProvider::CompleteSetupParameters params)
Part of the RRC protocol.
void DoNotifyOutOfSync()
Do notify out of sync function.
LteUeCcmRrcSapUser * GetLteCcmRrcSapUser()
Get the Component Carrier Management SAP offered by this RRC.
void DoRecvRrcConnectionReject(LteRrcSap::RrcConnectionReject msg)
Part of the RRC protocol.
uint16_t m_previousCellId
the cell id of the previous cell UE was attached to
Ptr< LteSignalingRadioBearerInfo > m_srb1Old
SRB1 configuration before RRC connection reconfiguration.
static TypeId GetTypeId()
Get the type ID.
void SwitchToState(State s)
Switch the UE RRC to the given state.
void DoDisconnect()
Disconnect function.
LteMacSapProvider * m_macSapProvider
MAC SAP provider.
void DoNotifyRandomAccessFailed()
Notify random access failed function.
TracedCallback< uint64_t, uint16_t, uint16_t, uint16_t > m_mibReceivedTrace
The MibReceived trace source.
LteUeCmacSapUser * GetLteUeCmacSapUser()
This function is overloaded to maintain backward compatibility.
void SetLteUeCmacSapProvider(LteUeCmacSapProvider *s)
set the CMAC SAP this RRC should interact with
uint64_t m_imsi
The unique UE identifier.
uint8_t m_n311
The 'N311' attribute.
Ptr< LteSignalingRadioBearerInfo > m_srb0
The Srb0 attribute.
uint8_t m_connEstFailCountLimit
the counter value for T300 timer expiration received from the eNB
LteUeCphySapUser * GetLteUeCphySapUser()
void DoConnect()
Connect function.
TracedCallback< uint64_t, uint16_t, uint16_t > m_handoverEndErrorTrace
The HandoverEndError trace source.
State
The states of the UE RRC entity.
@ CONNECTED_REESTABLISHING
TracedCallback< uint64_t, uint16_t, uint16_t, State, State > m_stateTransitionTrace
The StateTransition trace source.
VarMeasConfig m_varMeasConfig
Includes the accumulated configuration of the measurements to be performed by the UE.
friend class MemberLteUeRrcSapProvider< LteUeRrc >
allow MemberLteUeRrcSapProvider<LteUeRrc> class friend access
void ApplyMeasConfig(LteRrcSap::MeasConfig mc)
Update the current measurement configuration m_varMeasConfig.
LteRrcSap::PdschConfigDedicated m_pdschConfigDedicated
the PDSCH config dedicated
uint8_t m_n310
The 'N310' attribute.
void SetUseRlcSm(bool val)
TracedCallback< uint64_t, uint16_t > m_initialCellSelectionEndErrorTrace
The InitialCellSelectionEndError trace source.
EventId m_radioLinkFailureDetected
Time limit (given by m_t310) before the radio link is considered to have failed.
void DoRecvRrcConnectionReestablishmentReject(LteRrcSap::RrcConnectionReestablishmentReject msg)
Part of the RRC protocol.
void DoNotifyRandomAccessSuccessful()
Notify random access successful function.
LteUeRrcSapProvider * m_rrcSapProvider
RRC SAP provider.
void VarMeasReportListErase(uint8_t measId, ConcernedCells_t leavingCells, bool reportOnLeave)
Remove some cells from an existing reporting entry in m_varMeasReportList.
void DoRecvRrcConnectionSetup(LteRrcSap::RrcConnectionSetup msg)
Part of the RRC protocol.
void CancelLeavingTrigger(uint8_t measId)
Clear all the waiting triggers in m_leavingTriggerQueue which are associated with the given measureme...
bool m_leaveConnectedMode
true if UE NAS ask UE RRC to leave connected mode, e.g., after RLF, i.e.
void DoRecvRrcConnectionReestablishment(LteRrcSap::RrcConnectionReestablishment msg)
Part of the RRC protocol.
bool m_hasReceivedSib2
True if SIB2 was received for the current cell.
void SynchronizeToStrongestCell()
Go through the list of measurement results, choose the one with the strongest RSRP,...
std::map< uint8_t, uint8_t > m_bid2DrbidMap
bid to DR bid map
void SetLteUeCphySapProvider(LteUeCphySapProvider *s)
set the CPHY SAP this RRC should use to interact with the PHY
std::vector< LteUeCmacSapProvider * > m_cmacSapProvider
UE CMac SAP provider.
uint32_t m_dlEarfcn
Downlink carrier frequency.
LteUeCcmRrcSapProvider * m_ccmRrcSapProvider
Interface to the LteUeComponentCarrierManage instance.
void DoSetCsgWhiteList(uint32_t csgId)
Set CSG white list function.
void ApplyRadioResourceConfigDedicatedSecondaryCarrier(LteRrcSap::NonCriticalExtensionConfiguration nonCec)
Apply radio resource config dedicated secondary carrier.
LteAsSapProvider * GetAsSapProvider()
void DoSetTemporaryCellRnti(uint16_t rnti)
Set temporary cell rnti function.
void SetLteMacSapProvider(LteMacSapProvider *s)
set the MAC SAP provider.
TracedCallback< uint64_t, uint16_t, uint16_t > m_radioLinkFailureTrace
The 'RadioLinkFailure' trace source.
uint32_t m_ulEarfcn
Uplink carrier frequency.
TracedCallback< uint64_t, uint16_t, uint16_t > m_connectionEstablishedTrace
The ConnectionEstablished trace source.
uint8_t GetDlBandwidth() const
TracedCallback< uint64_t, uint16_t, uint16_t, uint16_t > m_sib1ReceivedTrace
The Sib1Received trace source.
TracedCallback< uint64_t, uint16_t, uint16_t > m_randomAccessErrorTrace
The RandomAccessError trace source.
uint32_t GetDlEarfcn() const
std::list< LteRrcSap::SCellToAddMod > m_sCellToAddModList
Secondary carriers.
LtePdcpSapUser * m_drbPdcpSapUser
DRB PDCP SAP user.
TracedCallback< Ptr< LteUeRrc >, std::list< LteRrcSap::SCellToAddMod > > m_sCarrierConfiguredTrace
The SCarrierConfigured trace source.
void DoStartCellSelection(uint32_t dlEarfcn)
Start cell selection function.
friend class MemberLteAsSapProvider< LteUeRrc >
allow MemberLteAsSapProvider<LteUeRrc> class friend access
bool m_useRlcSm
True if RLC SM is to be used, false if RLC UM/AM are to be used.
TracedCallback< uint64_t, uint16_t, uint16_t > m_handoverEndOkTrace
The HandoverEndOk trace source.
TracedCallback< uint64_t, uint16_t, uint16_t, std::string, uint8_t > m_phySyncDetectionTrace
The 'PhySyncDetection' trace source.
std::map< uint8_t, std::list< PendingTrigger_t > > m_leavingTriggerQueue
List of triggers that were raised because leaving condition have been true, but are still delayed fro...
Time m_t310
The 'T310' attribute.
friend class UeMemberLteUeCmacSapUser
allow UeMemberLteUeCmacSapUser class friend access
void RadioLinkFailureDetected()
Radio link failure detected function.
State m_state
The current UE RRC state.
std::vector< LteUeCphySapProvider * > m_cphySapProvider
UE CPhy SAP provider.
LteUeCcmRrcSapUser * m_ccmRrcSapUser
CCM RRC SAP user.
TracedCallback< uint64_t, uint16_t, uint16_t, uint8_t > m_drbCreatedTrace
The DrbCreated trace source.
uint16_t m_numberOfComponentCarriers
The number of component carriers.
std::map< uint8_t, VarMeasReport > m_varMeasReportList
The list of active reporting entries, indexed by the measurement identity which triggered the reporti...
std::vector< LteUeCmacSapUser * > m_cmacSapUser
UE CMac SAP user.
TracedCallback< uint64_t, uint16_t, uint16_t > m_srb1CreatedTrace
The Srb1Created trace source.
TracedCallback< uint64_t, uint16_t > m_initialCellSelectionEndOkTrace
The InitialCellSelectionEndOk trace source.
uint8_t GetUlBandwidth() const
void DoSendData(Ptr< Packet > packet, uint8_t bid)
Send data function.
LteAsSapProvider * m_asSapProvider
AS SAP provider.
uint16_t m_rnti
The C-RNTI attribute.
uint8_t m_noOfSyncIndications
number of in-sync or out-of-sync indications coming from PHY layer
uint16_t GetCellId() const
void DoSetNumberOfComponentCarriers(uint16_t noOfComponentCarriers)
RRC CCM SAP USER Method.
~LteUeRrc() override
Destructor.
void CancelEnteringTrigger(uint8_t measId)
Clear all the waiting triggers in m_enteringTriggerQueue which are associated with the given measurem...
std::map< uint16_t, MeasValues > m_storedMeasValues
Internal storage of the latest measurement results from all detected detected cells,...
void DoReportUeMeasurements(LteUeCphySapUser::UeMeasurementsParameters params)
Report UE measurements function.
LteUeRrcSapUser * m_rrcSapUser
RRC SAP user.
TracedCallback< uint64_t, uint16_t, uint16_t > m_connectionReconfigurationTrace
The ConnectionReconfiguration trace source.
void MeasurementReportTriggering(uint8_t measId)
Evaluate the reporting criteria of a measurement identity and invoke some reporting actions based on ...
void SaveUeMeasurements(uint16_t cellId, double rsrp, double rsrq, bool useLayer3Filtering, uint8_t componentCarrierId)
Keep the given measurement result as the latest measurement figures, to be utilised by UE RRC functio...
void SetLteCcmRrcSapProvider(LteUeCcmRrcSapProvider *s)
set the Component Carrier Management SAP this RRC should interact with
TracedCallback< uint64_t, uint16_t, uint16_t > m_sib2ReceivedTrace
The Sib2Received trace source.
void LeaveConnectedMode()
Leave connected mode method Resets the UE back to an appropriate state depending on the nature of cau...
uint32_t GetUlEarfcn() const
void VarMeasReportListClear(uint8_t measId)
Remove the reporting entry of the given measurement identity from m_varMeasReportList.
LteUeRrcSapProvider * GetLteUeRrcSapProvider()
std::map< uint8_t, Ptr< LteDataRadioBearerInfo > > m_drbMap
The DataRadioBearerMap attribute.
uint16_t m_cellId
The CellId attribute.
uint8_t m_connEstFailCount
the counter to count T300 timer expiration
void DoRecvMasterInformationBlock(uint16_t cellId, LteRrcSap::MasterInformationBlock msg)
Receive master information block function.
void DoReceivePdcpSdu(LtePdcpSapUser::ReceivePdcpSduParameters params)
Receive PDCP SDU function.
TracedCallback< uint64_t, uint16_t, uint16_t, uint8_t > m_connectionTimeoutTrace
The ConnectionTimeout trace source.
std::set< uint16_t > m_acceptableCell
List of cell ID of acceptable cells for cell selection that have been detected.
Time m_t300
The T300 attribute.
EventId m_connectionTimeout
Invokes ConnectionEstablishmentTimeout() if RRC connection establishment procedure for this UE takes ...
void VarMeasReportListAdd(uint8_t measId, ConcernedCells_t enteringCells)
Compose a new reporting entry of the given measurement identity, insert it into m_varMeasReportList,...
std::vector< LteUeCphySapUser * > m_cphySapUser
UE CPhy SAP user.
void ConnectionTimeout()
Invoked after timer T300 expires, notifying upper layers that RRC connection establishment procedure ...
bool m_hasReceivedMib
True if MIB was received for the current cell.
void DoRecvRrcConnectionRelease(LteRrcSap::RrcConnectionRelease msg)
Part of the RRC protocol.
std::list< uint16_t > ConcernedCells_t
List of cell IDs which are responsible for a certain trigger.
void EvaluateCellForSelection()
Performs cell selection evaluation to the current serving cell.
void DoRecvSystemInformationBlockType1(uint16_t cellId, LteRrcSap::SystemInformationBlockType1 msg)
Receive system information block type 1 function.
void StartConnection()
Start connection function.
void DoRecvSystemInformation(LteRrcSap::SystemInformation msg)
Part of the RRC protocol.
void DoNotifyInSync()
Do notify in sync function.
uint16_t m_ulBandwidth
Uplink bandwidth in RBs.
LteUeRrc()
create an RRC instance for use within an ue
uint32_t m_csgWhiteList
List of CSG ID which this UE entity has access to.
uint16_t GetPreviousCellId() const
Get the previous cell id.
void InitializeSap()
Initialize SAP.
void DisposeOldSrb1()
Dispose old SRB1.
void DoInitialize() override
Initialize() implementation.
friend class LtePdcpSpecificLtePdcpSapUser< LteUeRrc >
allow LtePdcpSpecificLtePdcpSapUser<LteUeRrc> class friend access
TracedCallback< uint64_t, uint16_t, uint16_t > m_randomAccessSuccessfulTrace
The RandomAccessSuccessful trace source.
bool IsServingCell(uint16_t cellId) const
LteRrcSap::SystemInformationBlockType1 m_lastSib1
Stored content of the last SIB1 received.
static const std::string ToString(LteUeRrc::State s)
void SetAsSapUser(LteAsSapUser *s)
Set the AS SAP user to interact with the NAS entity.
void SetLteUeRrcSapUser(LteUeRrcSapUser *s)
set the RRC SAP this RRC should interact with
uint16_t m_dlBandwidth
Downlink bandwidth in RBs.
Ptr< LteSignalingRadioBearerInfo > m_srb1
The Srb1 attribute.
LteAsSapUser * m_asSapUser
AS SAP user.
void SetImsi(uint64_t imsi)
void DoForceCampedOnEnb(uint16_t cellId, uint32_t dlEarfcn)
Force camped on ENB function.
void DoDispose() override
Destructor implementation.
void StorePreviousCellId(uint16_t cellId)
Store the previous cell id.
void ResetRlfParams()
Reset radio link failure parameters.
void DoResetSyncIndicationCounter()
Do reset sync indication counter function.
void ApplyRadioResourceConfigDedicated(LteRrcSap::RadioResourceConfigDedicated rrcd)
Apply radio resource config dedicated.
uint8_t Bid2Drbid(uint8_t bid)
Bid 2 DR bid.
TracedCallback< uint64_t, uint16_t, uint16_t, uint16_t > m_handoverStartTrace
The HandoverStart trace source.
Part of the RRC protocol.
Part of the RRC protocol.
Template for the implementation of the LteUeCphySapUser as a member of an owner class of type C to wh...
Ptr< Object > Create() const
Create an Object instance of the configured TypeId.
void SetTypeId(TypeId tid)
Set the TypeId of the Objects to be created by this factory.
friend class ObjectFactory
Friends.
AttributeValue implementation for Pointer.
Smart pointer class similar to boost::intrusive_ptr.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Cancel(const EventId &id)
Set the cancel bit on this event: the event's associated function will not be invoked when it expires...
static EventId ScheduleNow(FUNC f, Ts &&... args)
Schedule an event to expire Now.
static Time GetDelayLeft(const EventId &id)
Get the remaining time until this event will execute.
Simulation virtual time values and global simulation resolution.
AttributeValue implementation for Time.
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
UeMemberLteUeCmacSapUser(LteUeRrc *rrc)
Constructor.
LteUeRrc * m_rrc
the RRC class
void SetTemporaryCellRnti(uint16_t rnti) override
void NotifyRandomAccessSuccessful() override
Notify the RRC that the MAC Random Access procedure completed successfully.
void NotifyRandomAccessFailed() override
Notify the RRC that the MAC Random Access procedure failed.
Hold an unsigned integer type.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
ObjectPtrContainerValue ObjectMapValue
ObjectMapValue is an alias for ObjectPtrContainerValue.
Ptr< const AttributeAccessor > MakeObjectMapAccessor(U T::*memberVariable)
MakeAccessorHelper implementation for ObjectVector.
Ptr< const AttributeChecker > MakeObjectMapChecker()
Ptr< const AttributeAccessor > MakePointerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< AttributeChecker > MakePointerChecker()
Create a PointerChecker for a type.
Ptr< const AttributeAccessor > MakeTimeAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeChecker > MakeTimeChecker()
Helper to make an unbounded Time checker.
Ptr< const AttributeChecker > MakeUintegerChecker()
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
#define NS_LOG_ERROR(msg)
Use NS_LOG to output a message of level LOG_ERROR.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Ptr< T > CreateObject(Args &&... args)
Create an object by type, with varying number of constructor parameters.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Time MicroSeconds(uint64_t value)
Construct a Time in the indicated unit.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit.
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
const Time UE_MEASUREMENT_REPORT_DELAY
Artificial delay of UE measurements procedure.
std::ostream & operator<<(std::ostream &os, const Angles &a)
constexpr uint32_t MIN_NO_CC
Minimum number of carrier components allowed by 3GPP up to R13.
constexpr uint32_t MAX_NO_CC
Maximum number of carrier components allowed by 3GPP up to R13.
Parameters for LtePdcpSapProvider::TransmitPdcpSdu.
Parameters for LtePdcpSapUser::ReceivePdcpSdu.
uint8_t transmissionMode
transmission mode
uint16_t dlBandwidth
DL bandwidth.
uint16_t ulBandwidth
UL bandwidth.
uint32_t dlCarrierFreq
DL carrier frequency.
uint32_t ulCarrierFreq
UL carrier frequency.
uint32_t ulCarrierFreq
UL carrier frequency.
uint16_t ulBandwidth
UL bandwidth.
std::list< uint8_t > measIdToRemoveList
measure ID to remove list
std::list< MeasObjectToAddMod > measObjectToAddModList
measure object to add mod list
std::list< uint8_t > reportConfigToRemoveList
report config to remove list
std::list< uint8_t > measObjectToRemoveList
measure object to remove list
bool haveMeasGapConfig
have measure gap config?
QuantityConfig quantityConfig
quantity config
bool haveSmeasure
have S measure?
bool haveSpeedStatePars
have speed state parameters?
std::list< ReportConfigToAddMod > reportConfigToAddModList
report config to add mod list
std::list< MeasIdToAddMod > measIdToAddModList
measure ID to add mod list
bool haveQuantityConfig
have quantity config?
MeasObjectEutra structure.
int8_t offsetFreq
offset frequency
uint32_t carrierFreq
carrier frequency
MeasResultEutra structure.
uint8_t rsrqResult
RSRQ result.
uint8_t rsrpResult
RSRP result.
bool haveRsrpResult
have RSRP result
bool haveRsrqResult
have RSRQ result?
uint16_t physCellId
Phy cell ID.
bool haveCgiInfo
have CGI info?
uint8_t rsrqResult
the RSRQ result
uint8_t rsrpResult
the RSRP result
uint8_t rsrpResult
the RSRP result
uint8_t rsrqResult
the RSRQ result
MeasResultServFreq structure.
bool haveMeasResultSCell
have measResultSCell?
bool haveMeasResultBestNeighCell
have measResultBestNeighCell?
uint16_t servFreqId
serving cell index
MeasResultSCell measResultSCell
SCell measurement results.
bool haveMeasResultNeighCells
have measure result neighbor cells
std::list< MeasResultEutra > measResultListEutra
measure result list eutra
bool haveMeasResultServFreqList
has measResultServFreqList-r10
std::list< MeasResultServFreq > measResultServFreqList
MeasResultServFreqList-r10.
MeasResultPCell measResultPCell
measurement result primary cell
MeasurementReport structure.
MeasResults measResults
measure results
MobilityControlInfo structure.
RachConfigDedicated rachConfigDedicated
RACH config dedicated.
bool haveRachConfigDedicated
Have RACH config dedicated?
uint16_t newUeIdentity
new UE identity
bool haveCarrierBandwidth
have carrier bandwidth?
bool haveCarrierFreq
have carrier frequency?
CarrierBandwidthEutra carrierBandwidth
carrier bandwidth
CarrierFreqEutra carrierFreq
carrier frequency
uint16_t targetPhysCellId
target Phy cell ID
NonCriticalExtensionConfiguration structure.
std::list< uint8_t > sCellToReleaseList
SCell to release list.
std::list< SCellToAddMod > sCellToAddModList
SCell to add mod list.
int8_t referenceSignalPower
INTEGER (-60..50),.
PdschConfigDedicated structure.
PhysicalConfigDedicated structure.
PdschConfigDedicated pdschConfigDedicated
PDSCH config dedicated.
bool haveAntennaInfoDedicated
have antenna info dedicated?
SoundingRsUlConfigDedicated soundingRsUlConfigDedicated
sounding RS UL config dedicated
bool haveSoundingRsUlConfigDedicated
have sounding RS UL config dedicated?
bool havePdschConfigDedicated
have PDSCH config dedicated?
AntennaInfoDedicated antennaInfo
antenna info
uint8_t numberOfRaPreambles
number of RA preambles
uint8_t filterCoefficientRSRQ
filter coefficient RSRQ
uint8_t filterCoefficientRSRP
filter coefficient RSRP
uint8_t raResponseWindowSize
RA response window size.
uint8_t preambleTransMax
preamble transmit maximum
TxFailParam txFailParam
txFailParams
PreambleInfo preambleInfo
preamble info
RaSupervisionInfo raSupervisionInfo
RA supervision info.
uint8_t raPreambleIndex
RA preamble index.
uint8_t raPrachMaskIndex
RA PRACH mask index.
RachConfigCommon rachConfigCommon
RACH config common.
PdschConfigCommon pdschConfigCommon
PDSCH config common.
RadioResourceConfigDedicated structure.
PhysicalConfigDedicated physicalConfigDedicated
physical config dedicated
std::list< uint8_t > drbToReleaseList
DRB to release list.
std::list< DrbToAddMod > drbToAddModList
DRB to add mod list.
std::list< SrbToAddMod > srbToAddModList
SRB to add mod list.
Specifies criteria for triggering of an E-UTRA measurement reporting event.
bool reportOnLeave
Indicates whether or not the UE shall initiate the measurement reporting procedure when the leaving c...
uint8_t maxReportCells
Maximum number of cells, excluding the serving cell, to be included in the measurement report.
uint8_t hysteresis
Parameter used within the entry and leave condition of an event triggered reporting condition.
enum ns3::LteRrcSap::ReportConfigEutra::@174152020357172127004302246116267001242110156064 eventId
Event enumeration.
enum ns3::LteRrcSap::ReportConfigEutra::@374136270164373156154156077265266160331034212212 triggerQuantity
Trigger type enumeration.
@ EVENT_A2
Event A2: Serving becomes worse than absolute threshold.
@ EVENT_A3
Event A3: Neighbour becomes amount of offset better than PCell.
@ EVENT_A4
Event A4: Neighbour becomes better than absolute threshold.
@ EVENT_A1
Event A1: Serving becomes better than absolute threshold.
@ EVENT_A5
Event A5: PCell becomes worse than absolute threshold1 AND Neighbour becomes better than another abso...
ThresholdEutra threshold2
Threshold for event A5.
enum ns3::LteRrcSap::ReportConfigEutra::@052114161037202132004365346027213360353343030201 reportInterval
Report interval enumeration.
enum ns3::LteRrcSap::ReportConfigEutra::@347136032026324172236035053024104342310355304375 triggerType
Trigger enumeration.
ThresholdEutra threshold1
Threshold for event A1, A2, A4, and A5.
@ RSRP
Reference Signal Received Power.
@ RSRQ
Reference Signal Received Quality.
@ PERIODICAL
periodical report
int8_t a3Offset
Offset value for Event A3.
uint16_t timeToTrigger
Time during which specific criteria for the event needs to be met in order to trigger a measurement r...
RrcConnectionReconfigurationCompleted structure.
uint8_t rrcTransactionIdentifier
RRC transaction identifier.
RrcConnectionReconfiguration structure.
uint8_t rrcTransactionIdentifier
RRC transaction identifier.
bool haveMobilityControlInfo
have mobility control info
NonCriticalExtensionConfiguration nonCriticalExtension
3GPP TS 36.331 v.11.10 R11 Sec.
bool haveRadioResourceConfigDedicated
have radio resource config dedicated
RadioResourceConfigDedicated radioResourceConfigDedicated
radio resource config dedicated
bool haveNonCriticalExtension
have critical extension?
MeasConfig measConfig
measure config
bool haveMeasConfig
have measure config
MobilityControlInfo mobilityControlInfo
mobility control info
RrcConnectionReestablishment structure.
RrcConnectionReestablishmentReject structure.
RrcConnectionReject structure.
RrcConnectionRelease structure.
uint8_t rrcTransactionIdentifier
RRC transaction identifier.
RrcConnectionRequest structure.
uint64_t ueIdentity
UE identity.
RrcConnectionSetupCompleted structure.
uint8_t rrcTransactionIdentifier
RRC transaction identifier.
RrcConnectionSetup structure.
uint8_t rrcTransactionIdentifier
RRC transaction identifier.
RadioResourceConfigDedicated radioResourceConfigDedicated
radio resource config dedicated
uint16_t srsConfigIndex
SRS config index.
uint8_t range
Value range used in RSRP/RSRQ threshold.
enum ns3::LteRrcSap::ThresholdEutra::@200372075340144231162262002242030206054121013015 choice
Threshold enumeration.
@ THRESHOLD_RSRP
RSRP is used for the threshold.
@ THRESHOLD_RSRQ
RSRQ is used for the threshold.
uint8_t connEstFailCount
Number of times that the UE detects T300 expiry on the same cell.
LogicalChannelConfig structure.
uint16_t prioritizedBitRateKbps
prioritize bit rate Kbps
uint16_t bucketSizeDurationMs
bucket size duration ms
uint8_t logicalChannelGroup
logical channel group
UeMeasurementsParameters structure.
Represents a measurement result from a certain cell.
uint32_t carrierFreq
Measurement object frequency.
double rsrp
Measured RSRP in dBm.
double rsrq
Measured RSRQ in dB.
Represents a single triggered event from a measurement identity which reporting criteria have been fu...
ConcernedCells_t concernedCells
The list of cells responsible for this trigger.
EventId timer
The pending reporting event, scheduled at the end of the time-to-trigger.
uint8_t measId
The measurement identity which raised the trigger.
Represents a single measurement reporting entry., which includes information about a measurement for ...
CompleteSetupParameters structure.
SetupParameters structure.
LteRlcSapProvider * srb0SapProvider
SRB0 SAP provider.
LtePdcpSapProvider * srb1SapProvider
SRB1 SAP provider.