A Discrete-Event Network Simulator
API
lte-enb-mac.h
Go to the documentation of this file.
1 /* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Marco Miozzo <marco.miozzo@cttc.es>
19  * Nicola Baldo <nbaldo@cttc.es>
20  * Modified by:
21  * Danilo Abrignani <danilo.abrignani@unibo.it> (Carrier Aggregation - GSoC 2015)
22  * Biljana Bojovic <biljana.bojovic@cttc.es> (Carrier Aggregation)
23  */
24 
25 #ifndef LTE_ENB_MAC_H
26 #define LTE_ENB_MAC_H
27 
28 
29 #include <map>
30 #include <vector>
31 #include <ns3/lte-common.h>
32 #include <ns3/lte-mac-sap.h>
33 #include <ns3/lte-enb-cmac-sap.h>
34 #include <ns3/ff-mac-csched-sap.h>
35 #include <ns3/ff-mac-sched-sap.h>
36 #include <ns3/lte-enb-phy-sap.h>
37 #include "ns3/traced-value.h"
38 #include "ns3/trace-source-accessor.h"
39 #include <ns3/packet.h>
40 #include <ns3/packet-burst.h>
41 #include <ns3/lte-ccm-mac-sap.h>
42 
43 namespace ns3 {
44 
45 class DlCqiLteControlMessage;
46 class UlCqiLteControlMessage;
47 class PdcchMapLteControlMessage;
48 
50 typedef std::vector <std::vector < Ptr<PacketBurst> > > DlHarqProcessesBuffer_t;
51 
55 class LteEnbMac : public Object
56 {
69 
70 public:
75  static TypeId GetTypeId (void);
76 
77  LteEnbMac (void);
78  virtual ~LteEnbMac (void);
79  virtual void DoDispose (void);
80 
85  void SetComponentCarrierId (uint8_t index);
106 
107 
108 
129 
130 
136 
142 
148 
154 
155 
168  typedef void (* DlSchedulingTracedCallback)
169  (const uint32_t frame, const uint32_t subframe, const uint16_t rnti,
170  const uint8_t mcs0, const uint16_t tbs0Size,
171  const uint8_t mcs1, const uint16_t tbs1Size, const uint8_t ccId);
172 
182  typedef void (* UlSchedulingTracedCallback)
183  (const uint32_t frame, const uint32_t subframe, const uint16_t rnti,
184  const uint8_t mcs, const uint16_t tbsSize);
185 
186 private:
187 
193 
199 
205 
211 
212 
213 
214  // forwarded from LteEnbCmacSapProvider
220  void DoConfigureMac (uint8_t ulBandwidth, uint8_t dlBandwidth);
225  void DoAddUe (uint16_t rnti);
230  void DoRemoveUe (uint16_t rnti);
247  void DoReleaseLc (uint16_t rnti, uint8_t lcid);
264 
265  // forwarded from LteMacSapProvider
276 
277 
278  // forwarded from FfMacCchedSapUser
314 
315  // forwarded from FfMacSchedSapUser
326 
327  // forwarded from LteEnbPhySapUser
333  void DoSubframeIndication (uint32_t frameNo, uint32_t subframeNo);
338  void DoReceiveRachPreamble (uint8_t prachId);
339 
340  // forwarded by LteCcmMacSapProvider
346 
347 public:
352  void DoReceivePhyPdu (Ptr<Packet> p);
353 
354 private:
365 
367  std::map <uint16_t, std::map<uint8_t, LteMacSapUser*> > m_rlcAttached;
368 
369  std::vector <CqiListElement_s> m_dlCqiReceived;
370  std::vector <FfMacSchedSapProvider::SchedUlCqiInfoReqParameters> m_ulCqiReceived;
371  std::vector <MacCeListElement_s> m_ulCeReceived;
372 
373  std::vector <DlInfoListElement_s> m_dlInfoListReceived;
374 
375  std::vector <UlInfoListElement_s> m_ulInfoListReceived;
376 
377 
378  /*
379  * Map of UE's info element (see 4.3.12 of FF MAC Scheduler API)
380  */
381  //std::map <uint16_t,UlInfoListElement_s> m_ulInfoListElements;
382 
383 
384 
389 
390 
395 
396  // PHY-SAP
399 
400  // Sap For ComponentCarrierManager 'Uplink case'
403 
406  uint32_t m_frameNo;
410  uint32_t m_subframeNo;
417 
422  TracedCallback<uint32_t, uint32_t, uint16_t,
423  uint8_t, uint16_t, uint8_t> m_ulScheduling;
424 
425  uint8_t m_macChTtiDelay;
426 
427 
428  std::map <uint16_t, DlHarqProcessesBuffer_t> m_miDlHarqProcessesPackets;
429 
433 
439  {
440  uint16_t rnti;
442  };
443 
449  std::map<uint8_t, NcRaPreambleInfo> m_allocatedNcRaPreambleMap;
450 
451  std::map<uint8_t, uint32_t> m_receivedRachPreambleCount;
452 
453  std::map<uint8_t, uint32_t> m_rapIdRntiMap;
454 
457 
458 };
459 
460 } // end namespace ns3
461 
462 #endif /* LTE_ENB_MAC_ENTITY_H */
Service Access Point (SAP) offered by the component carrier manager (CCM) by MAC to CCM...
void DoConfigureMac(uint8_t ulBandwidth, uint8_t dlBandwidth)
Configure MAC function.
Definition: lte-enb-mac.cc:782
void DoReconfigureLc(LteEnbCmacSapProvider::LcInfo lcinfo)
Reconfigure LC function.
Definition: lte-enb-mac.cc:891
FfMacSchedSapUser * m_schedSapUser
the Sched SAP user
Definition: lte-enb-mac.h:393
Parameters of the CSCHED_LC_CONFIG_CNF primitive.
AllocateNcRaPreambleReturnValue structure.
void(* UlSchedulingTracedCallback)(const uint32_t frame, const uint32_t subframe, const uint16_t rnti, const uint8_t mcs, const uint16_t tbsSize)
TracedCallback signature for UL scheduling events.
Definition: lte-enb-mac.h:183
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
void DoDlInfoListElementHarqFeeback(DlInfoListElement_s params)
DL Info List ELements HARQ Feedback function.
EnbMacMemberLteMacSapProvider class.
Definition: lte-mac-sap.h:134
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:73
std::vector< FfMacSchedSapProvider::SchedUlCqiInfoReqParameters > m_ulCqiReceived
UL-CQI received.
Definition: lte-enb-mac.h:370
Parameters of the CSCHED_UE_CONFIG_CNF primitive.
void DoReceivePhyPdu(Ptr< Packet > p)
legacy public for use the Phy callback
Definition: lte-enb-mac.cc:722
Parameters of the CSCHED_CELL_CONFIG_UPDATE_IND primitive.
void DoUlInfoListElementHarqFeeback(UlInfoListElement_s params)
UL Info List ELements HARQ Feedback function.
TracedCallback< uint32_t, uint32_t, uint16_t, uint8_t, uint16_t, uint8_t > m_ulScheduling
Trace information regarding UL scheduling Frame number, Subframe number, RNTI, MCS of TB...
Definition: lte-enb-mac.h:423
LteEnbCmacSapProvider * m_cmacSapProvider
the CMAC SAP provider
Definition: lte-enb-mac.h:386
std::map< uint16_t, std::map< uint8_t, LteMacSapUser * > > m_rlcAttached
rnti, lcid, SAP of the RLC instance
Definition: lte-enb-mac.h:367
void DoAddLc(LteEnbCmacSapProvider::LcInfo lcinfo, LteMacSapUser *msu)
Add LC function.
Definition: lte-enb-mac.cc:844
LteEnbCmacSapProvider::RachConfig DoGetRachConfig()
Get RACH configuration function.
Definition: lte-enb-mac.cc:925
void DoCschedCellConfigUpdateInd(FfMacCschedSapUser::CschedCellConfigUpdateIndParameters params)
CSched Cell Config Update Indication function.
void DoReleaseLc(uint16_t rnti, uint8_t lcid)
Release LC function.
Definition: lte-enb-mac.cc:897
void SetLteEnbCmacSapUser(LteEnbCmacSapUser *s)
Set the control MAC SAP user.
Definition: lte-enb-mac.cc:458
Forward calls to a chain of Callback.
void SetComponentCarrierId(uint8_t index)
Set the component carrier ID.
Definition: lte-enb-mac.cc:414
void DoSchedUlConfigInd(FfMacSchedSapUser::SchedUlConfigIndParameters params)
Sched UL Config Indication function.
void DoReportMacCeToScheduler(MacCeListElement_s bsr)
Report MAC CE to scheduler.
Definition: lte-enb-mac.cc:711
uint8_t m_preambleTransMax
preamble transmit maximum
Definition: lte-enb-mac.h:431
Provides the CSCHED SAP.
void DoTransmitPdu(LteMacSapProvider::TransmitPduParameters params)
Transmit PDU function.
Definition: lte-enb-mac.cc:980
LteCcmMacSapProvider * GetLteCcmMacSapProvider()
Get the eNB-ComponentCarrierManager SAP User.
Definition: lte-enb-mac.cc:490
Parameters of the CSCHED_UE_CONFIG_UPDATE_IND primitive.
void(* DlSchedulingTracedCallback)(const uint32_t frame, const uint32_t subframe, const uint16_t rnti, const uint8_t mcs0, const uint16_t tbs0Size, const uint8_t mcs1, const uint16_t tbs1Size, const uint8_t ccId)
TracedCallback signature for DL scheduling events.
Definition: lte-enb-mac.h:169
Service Access Point (SAP) offered by the eNB-PHY to the eNB-MAC.
See section 4.3.12 ulInfoListElement.
void DoAddUe(uint16_t rnti)
Add UE function.
Definition: lte-enb-mac.cc:796
uint8_t m_componentCarrierId
component carrier Id used to address sap
Definition: lte-enb-mac.h:456
void SetLteCcmMacSapUser(LteCcmMacSapUser *s)
Set the ComponentCarrierManager SAP user.
Definition: lte-enb-mac.cc:483
Service Access Point (SAP) offered by the eNB-PHY to the eNB-MAC.
FfMacCschedSapUser * GetFfMacCschedSapUser(void)
Get the control scheduler SAP user.
Definition: lte-enb-mac.cc:438
LteMacSapProvider * GetLteMacSapProvider(void)
Get the MAC SAP provider.
Definition: lte-enb-mac.cc:452
Parameters for LteMacSapProvider::ReportBufferStatus.
Definition: lte-mac-sap.h:67
std::map< uint8_t, uint32_t > m_receivedRachPreambleCount
received RACH preamble count
Definition: lte-enb-mac.h:451
FfMacCschedSapUser * m_cschedSapUser
the CSched SAP user
Definition: lte-enb-mac.h:394
Service Access Point (SAP) offered by the MAC to the RRC See Femto Forum MAC Scheduler Interface Spec...
void SetFfMacCschedSapProvider(FfMacCschedSapProvider *s)
Set the control scheduler SAP provider.
Definition: lte-enb-mac.cc:432
Parameters of the CSCHED_LC_RELEASE_CNF primitive.
LteEnbPhySapProvider * m_enbPhySapProvider
the ENB Phy SAP provider
Definition: lte-enb-mac.h:397
LteEnbPhySapUser * m_enbPhySapUser
the ENB Phy SAP user
Definition: lte-enb-mac.h:398
FfMacSchedSapUser * GetFfMacSchedSapUser(void)
Get the scheduler SAP user.
Definition: lte-enb-mac.cc:426
void DoCschedUeConfigCnf(FfMacCschedSapUser::CschedUeConfigCnfParameters params)
CSched UE Config configure function.
EnbMacMemberFfMacSchedSapUser class.
Definition: lte-enb-mac.cc:147
void DoUeUpdateConfigurationReq(LteEnbCmacSapProvider::UeConfig params)
UE Update configuration request function.
Definition: lte-enb-mac.cc:912
Logical Channel information to be passed to CmacSapProvider::ConfigureLc.
std::map< uint8_t, uint32_t > m_rapIdRntiMap
RAPID RNTI map.
Definition: lte-enb-mac.h:453
EnbMacMemberFfMacCschedSapUser class.
Definition: lte-enb-mac.cc:187
uint16_t rnti
rnti previously allocated for this non-contention based RA procedure
Definition: lte-enb-mac.h:440
uint8_t m_macChTtiDelay
delay of MAC, PHY and channel in terms of TTIs
Definition: lte-enb-mac.h:425
void DoCschedLcReleaseCnf(FfMacCschedSapUser::CschedLcReleaseCnfParameters params)
CSched LC Release configure function.
static TypeId GetTypeId(void)
Get the type ID.
Definition: lte-enb-mac.cc:337
void DoUlCqiReport(FfMacSchedSapProvider::SchedUlCqiInfoReqParameters ulcqi)
UL CQI report.
Definition: lte-enb-mac.cc:676
Provides the SCHED SAP.
virtual void DoDispose(void)
Destructor implementation.
Definition: lte-enb-mac.cc:396
void ReceiveBsrMessage(MacCeListElement_s bsr)
Receive a CE element containing the buffer status report.
Definition: lte-enb-mac.cc:704
MemberLteCcmMacSapProvider class.
uint8_t m_raResponseWindowSize
RA response window size.
Definition: lte-enb-mac.h:432
See section 4.3.23 dlInfoListElement.
void DoReceiveRachPreamble(uint8_t prachId)
Receive RACH Preamble function.
Definition: lte-enb-mac.cc:668
void DoRemoveUe(uint16_t rnti)
Remove UE function.
Definition: lte-enb-mac.cc:833
See section 4.3.14 macCEListElement.
Parameters for [re]configuring the UE.
uint32_t m_subframeNo
subframe number of current subframe indication
Definition: lte-enb-mac.h:410
LteEnbCmacSapProvider::AllocateNcRaPreambleReturnValue DoAllocateNcRaPreamble(uint16_t rnti)
Allocate NC RA preamble function.
Definition: lte-enb-mac.cc:935
uint8_t m_numberOfRaPreambles
number of RA preambles
Definition: lte-enb-mac.h:430
Every class exported by the ns3 library is enclosed in the ns3 namespace.
LteEnbCmacSapProvider * GetLteEnbCmacSapProvider(void)
Get the control MAC SAP provider.
Definition: lte-enb-mac.cc:464
Service Access Point (SAP) offered by MAC to the component carrier manager (CCM). ...
std::vector< UlInfoListElement_s > m_ulInfoListReceived
UL HARQ feedback received.
Definition: lte-enb-mac.h:375
LteMacSapProvider * m_macSapProvider
the MAC SAP provider
Definition: lte-enb-mac.h:385
std::vector< CqiListElement_s > m_dlCqiReceived
DL-CQI received.
Definition: lte-enb-mac.h:369
FfMacCschedSapUser class.
LteCcmMacSapUser * m_ccmMacSapUser
CCM MAC SAP user.
Definition: lte-enb-mac.h:402
std::vector< MacCeListElement_s > m_ulCeReceived
CE received (BSR up to now)
Definition: lte-enb-mac.h:371
std::vector< std::vector< Ptr< PacketBurst > > > DlHarqProcessesBuffer_t
DlHarqProcessesBuffer_t typedef.
Definition: lte-enb-mac.h:47
void DoCschedUeReleaseCnf(FfMacCschedSapUser::CschedUeReleaseCnfParameters params)
CSched UE Release configure function.
EnbMacMemberLteEnbCmacSapProvider class.
Definition: lte-enb-mac.cc:59
std::vector< DlInfoListElement_s > m_dlInfoListReceived
DL HARQ feedback received.
Definition: lte-enb-mac.h:373
void SetLteEnbPhySapProvider(LteEnbPhySapProvider *s)
Set the PHY SAP Provider.
Definition: lte-enb-mac.cc:470
LteEnbCmacSapUser * m_cmacSapUser
the CMAC SAP user
Definition: lte-enb-mac.h:388
Parameters of the SCHED_UL_CQI_INFO_REQ primitive.
LteEnbPhySapUser * GetLteEnbPhySapUser()
Get the eNB-PHY SAP User.
Definition: lte-enb-mac.cc:477
Service Access Point (SAP) offered by the MAC to the RLC See Femto Forum MAC Scheduler Interface Spec...
Definition: lte-mac-sap.h:95
struct defining the RACH configuration of the MAC
FfMacSchedSapProvider * m_schedSapProvider
the Sched SAP provider
Definition: lte-enb-mac.h:391
void DoReportBufferStatus(LteMacSapProvider::ReportBufferStatusParameters params)
Report Buffer Status function.
Definition: lte-enb-mac.cc:997
LteCcmMacSapProvider * m_ccmMacSapProvider
CCM MAC SAP provider.
Definition: lte-enb-mac.h:401
void DoCschedUeConfigUpdateInd(FfMacCschedSapUser::CschedUeConfigUpdateIndParameters params)
CSched UE Config Update Indication function.
LteMacSapUser * m_macSapUser
the MAC SAP user
Definition: lte-enb-mac.h:387
void DoSchedDlConfigInd(FfMacSchedSapUser::SchedDlConfigIndParameters ind)
Sched DL Config Indication function.
Service Access Point (SAP) offered by the MAC to the RLC See Femto Forum MAC Scheduler Interface Spec...
Definition: lte-mac-sap.h:36
TracedCallback< DlSchedulingCallbackInfo > m_dlScheduling
Trace information regarding DL scheduling Frame number, Subframe number, RNTI, MCS of TB1...
Definition: lte-enb-mac.h:416
void SetLteMacSapUser(LteMacSapUser *s)
Set the MAC SAP user.
Definition: lte-enb-mac.cc:446
uint32_t m_frameNo
frame number of current subframe indication
Definition: lte-enb-mac.h:406
void DoCschedLcConfigCnf(FfMacCschedSapUser::CschedLcConfigCnfParameters params)
CSched LC Config configure function.
Parameters of the SCHED_UL_CONFIG_IND primitive.
void DoReceiveLteControlMessage(Ptr< LteControlMessage > msg)
Receive a DL CQI ideal control message.
Definition: lte-enb-mac.cc:643
A base class which provides memory management and object aggregation.
Definition: object.h:87
std::map< uint8_t, NcRaPreambleInfo > m_allocatedNcRaPreambleMap
map storing as key the random access preamble IDs allocated for non-contention based access...
Definition: lte-enb-mac.h:449
Service Access Point (SAP) offered by the eNB MAC to the eNB RRC See Femto Forum MAC Scheduler Interf...
virtual ~LteEnbMac(void)
Definition: lte-enb-mac.cc:390
std::map< uint16_t, DlHarqProcessesBuffer_t > m_miDlHarqProcessesPackets
Packet under transmission of the DL HARQ process.
Definition: lte-enb-mac.h:428
info associated with a preamble allocated for non-contention based RA
Definition: lte-enb-mac.h:438
a unique identifier for an interface.
Definition: type-id.h:58
void DoSubframeIndication(uint32_t frameNo, uint32_t subframeNo)
Subrame Indication function.
Definition: lte-enb-mac.cc:496
This class implements the MAC layer of the eNodeB device.
Definition: lte-enb-mac.h:55
FfMacSchedSapUser class.
Parameters of the CSCHED_UE_RELEASE_CNF primitive.
void SetFfMacSchedSapProvider(FfMacSchedSapProvider *s)
Set the scheduler SAP provider.
Definition: lte-enb-mac.cc:420
FfMacCschedSapProvider * m_cschedSapProvider
the Csched SAP provider
Definition: lte-enb-mac.h:392
Time expiryTime
value the expiration time of this allocation (so that stale preambles can be reused) ...
Definition: lte-enb-mac.h:441
void ReceiveDlCqiLteControlMessage(Ptr< DlCqiLteControlMessage > msg)
Receive a DL CQI ideal control message.
Definition: lte-enb-mac.cc:691
void DoCschedCellConfigCnf(FfMacCschedSapUser::CschedCellConfigCnfParameters params)
CSched Cell Config configure function.
Parameters for LteMacSapProvider::TransmitPdu.
Definition: lte-mac-sap.h:45