A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Documentation ▼
Installation
Manual
Models
Contributing
Wiki
Development ▼
API Docs
Issue Tracker
Merge Requests
API
lte-rlc-sap.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3
*
4
* This program is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License version 2 as
6
* published by the Free Software Foundation;
7
*
8
* This program is distributed in the hope that it will be useful,
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU General Public License for more details.
12
*
13
* You should have received a copy of the GNU General Public License
14
* along with this program; if not, write to the Free Software
15
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
*
17
* Author: Manuel Requena <manuel.requena@cttc.es>
18
*/
19
20
#ifndef LTE_RLC_SAP_H
21
#define LTE_RLC_SAP_H
22
23
#include "ns3/packet.h"
24
25
namespace
ns3
26
{
27
35
class
LteRlcSapProvider
36
{
37
public
:
38
virtual
~LteRlcSapProvider
();
39
43
struct
TransmitPdcpPduParameters
44
{
45
Ptr<Packet>
pdcpPdu
;
46
uint16_t
rnti
;
47
uint8_t
lcid
;
48
};
49
56
virtual
void
TransmitPdcpPdu
(
TransmitPdcpPduParameters
params
) = 0;
57
};
58
66
class
LteRlcSapUser
67
{
68
public
:
69
virtual
~LteRlcSapUser
();
70
76
virtual
void
ReceivePdcpPdu
(
Ptr<Packet>
p) = 0;
77
};
78
80
template
<
class
C>
81
class
LteRlcSpecificLteRlcSapProvider
:
public
LteRlcSapProvider
82
{
83
public
:
89
LteRlcSpecificLteRlcSapProvider
(C* rlc);
90
91
// Delete default constructor to avoid misuse
92
LteRlcSpecificLteRlcSapProvider
() =
delete
;
93
98
void
TransmitPdcpPdu
(
TransmitPdcpPduParameters
params
)
override
;
99
100
private
:
101
C*
m_rlc
;
102
};
103
104
template
<
class
C>
105
LteRlcSpecificLteRlcSapProvider<C>::LteRlcSpecificLteRlcSapProvider
(C* rlc)
106
: m_rlc(rlc)
107
{
108
}
109
110
template
<
class
C>
111
void
112
LteRlcSpecificLteRlcSapProvider<C>::TransmitPdcpPdu
(
TransmitPdcpPduParameters
params
)
113
{
114
m_rlc->DoTransmitPdcpPdu(
params
.pdcpPdu);
115
}
116
118
template
<
class
C>
119
class
LteRlcSpecificLteRlcSapUser
:
public
LteRlcSapUser
120
{
121
public
:
127
LteRlcSpecificLteRlcSapUser
(C* pdcp);
128
129
// Delete default constructor to avoid misuse
130
LteRlcSpecificLteRlcSapUser
() =
delete
;
131
132
// Interface implemented from LteRlcSapUser
133
void
ReceivePdcpPdu
(
Ptr<Packet>
p)
override
;
134
135
private
:
136
C*
m_pdcp
;
137
};
138
139
template
<
class
C>
140
LteRlcSpecificLteRlcSapUser<C>::LteRlcSpecificLteRlcSapUser
(C* pdcp)
141
: m_pdcp(pdcp)
142
{
143
}
144
145
template
<
class
C>
146
void
147
LteRlcSpecificLteRlcSapUser<C>::ReceivePdcpPdu
(
Ptr<Packet>
p)
148
{
149
m_pdcp->DoReceivePdcpPdu(p);
150
}
151
152
}
// namespace ns3
153
154
#endif
// LTE_RLC_SAP_H
ns3::LteRlcSapProvider
Service Access Point (SAP) offered by the UM-RLC and AM-RLC entities to the PDCP entity See 3GPP 36....
Definition:
lte-rlc-sap.h:36
ns3::LteRlcSapProvider::~LteRlcSapProvider
virtual ~LteRlcSapProvider()
Definition:
lte-rlc-sap.cc:25
ns3::LteRlcSapProvider::TransmitPdcpPdu
virtual void TransmitPdcpPdu(TransmitPdcpPduParameters params)=0
Send a PDCP PDU to the RLC for transmission This method is to be called when upper PDCP entity has a ...
ns3::LteRlcSapUser
Service Access Point (SAP) offered by the UM-RLC and AM-RLC entities to the PDCP entity See 3GPP 36....
Definition:
lte-rlc-sap.h:67
ns3::LteRlcSapUser::~LteRlcSapUser
virtual ~LteRlcSapUser()
Definition:
lte-rlc-sap.cc:29
ns3::LteRlcSapUser::ReceivePdcpPdu
virtual void ReceivePdcpPdu(Ptr< Packet > p)=0
Called by the RLC entity to notify the PDCP entity of the reception of a new PDCP PDU.
ns3::LteRlcSpecificLteRlcSapProvider
LteRlcSpecificLteRlcSapProvider.
Definition:
lte-rlc-sap.h:82
ns3::LteRlcSpecificLteRlcSapProvider::LteRlcSpecificLteRlcSapProvider
LteRlcSpecificLteRlcSapProvider()=delete
ns3::LteRlcSpecificLteRlcSapProvider::TransmitPdcpPdu
void TransmitPdcpPdu(TransmitPdcpPduParameters params) override
Interface implemented from LteRlcSapProvider.
Definition:
lte-rlc-sap.h:112
ns3::LteRlcSpecificLteRlcSapProvider::m_rlc
C * m_rlc
the RLC
Definition:
lte-rlc-sap.h:101
ns3::LteRlcSpecificLteRlcSapUser
LteRlcSpecificLteRlcSapUser class.
Definition:
lte-rlc-sap.h:120
ns3::LteRlcSpecificLteRlcSapUser::m_pdcp
C * m_pdcp
the PDCP
Definition:
lte-rlc-sap.h:136
ns3::LteRlcSpecificLteRlcSapUser::ReceivePdcpPdu
void ReceivePdcpPdu(Ptr< Packet > p) override
Called by the RLC entity to notify the PDCP entity of the reception of a new PDCP PDU.
Definition:
lte-rlc-sap.h:147
ns3::LteRlcSpecificLteRlcSapUser::LteRlcSpecificLteRlcSapUser
LteRlcSpecificLteRlcSapUser()=delete
ns3::Ptr< Packet >
ns3
Every class exported by the ns3 library is enclosed in the ns3 namespace.
two-ray-to-three-gpp-ch-calibration.params
params
Fit Fluctuating Two Ray model to the 3GPP TR 38.901 using the Anderson-Darling goodness-of-fit ##.
Definition:
two-ray-to-three-gpp-ch-calibration.py:514
ns3::LteRlcSapProvider::TransmitPdcpPduParameters
Parameters for LteRlcSapProvider::TransmitPdcpPdu.
Definition:
lte-rlc-sap.h:44
ns3::LteRlcSapProvider::TransmitPdcpPduParameters::lcid
uint8_t lcid
the logical channel id corresponding to the sending RLC instance
Definition:
lte-rlc-sap.h:47
ns3::LteRlcSapProvider::TransmitPdcpPduParameters::pdcpPdu
Ptr< Packet > pdcpPdu
the PDCP PDU
Definition:
lte-rlc-sap.h:45
ns3::LteRlcSapProvider::TransmitPdcpPduParameters::rnti
uint16_t rnti
the C-RNTI identifying the UE
Definition:
lte-rlc-sap.h:46
src
lte
model
lte-rlc-sap.h
Generated on Sun Mar 3 2024 17:11:02 for ns-3 by
1.9.1