src/lte/model/lte-rlc-tm.cc
author Peter D. Barnes, Jr. <barnes26@llnl.gov>
Fri, 26 Sep 2014 15:51:00 -0700
changeset 10968 2d29fee2b7b8
parent 10652 dc18deba4502
child 11274 609de51c9b88
permissions -rw-r--r--
[Bug 1551] Redux: NS_LOG_COMPONENT_DEFINE inside or outside of ns3 namespace?
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     2
/*
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
     3
 * Copyright (c) 2011,2012 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     4
 *
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     8
 *
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    12
 * GNU General Public License for more details.
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    13
 *
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    17
 *
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    18
 * Author: Manuel Requena <manuel.requena@cttc.es>
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    19
 *         Nicola Baldo <nbaldo@cttc.es>
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    20
 */
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    21
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    22
#include "ns3/simulator.h"
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    23
#include "ns3/log.h"
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    24
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    25
#include "ns3/lte-rlc-tm.h"
8375
201d78643209 Add support for ReportBufferStatus parameters: txQueueSize and txQueueHolDelay
Manuel Requena <manuel.requena@cttc.es>
parents: 8361
diff changeset
    26
#include "ns3/lte-rlc-tag.h"
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    27
10968
2d29fee2b7b8 [Bug 1551] Redux: NS_LOG_COMPONENT_DEFINE inside or outside of ns3 namespace?
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 10652
diff changeset
    28
namespace ns3 {
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    29
10968
2d29fee2b7b8 [Bug 1551] Redux: NS_LOG_COMPONENT_DEFINE inside or outside of ns3 namespace?
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 10652
diff changeset
    30
NS_LOG_COMPONENT_DEFINE ("LteRlcTm");
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    31
10652
dc18deba4502 [doxygen] Revert r10410, r10411, r10412
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 10410
diff changeset
    32
NS_OBJECT_ENSURE_REGISTERED (LteRlcTm);
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    33
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    34
LteRlcTm::LteRlcTm ()
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    35
  : m_maxTxBufferSize (0),
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    36
    m_txBufferSize (0)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    37
{
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    38
  NS_LOG_FUNCTION (this);
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    39
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    40
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    41
LteRlcTm::~LteRlcTm ()
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    42
{
9597
908d111be3c9 Clean some buffers
Manuel Requena <manuel.requena@cttc.es>
parents: 9470
diff changeset
    43
  NS_LOG_FUNCTION (this);
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    44
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    45
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    46
TypeId
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    47
LteRlcTm::GetTypeId (void)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    48
{
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    49
  static TypeId tid = TypeId ("ns3::LteRlcTm")
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    50
    .SetParent<LteRlc> ()
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    51
    .AddConstructor<LteRlcTm> ()
8745
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    52
    .AddAttribute ("MaxTxBufferSize",
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    53
                   "Maximum Size of the Transmission Buffer (in Bytes)",
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    54
                   UintegerValue (2 * 1024 * 1024),
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    55
                   MakeUintegerAccessor (&LteRlcTm::m_maxTxBufferSize),
8745
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    56
                   MakeUintegerChecker<uint32_t> ())
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    57
    ;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    58
  return tid;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    59
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    60
9451
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    61
void
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    62
LteRlcTm::DoDispose ()
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    63
{
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    64
  NS_LOG_FUNCTION (this);
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    65
  m_rbsTimer.Cancel ();
9597
908d111be3c9 Clean some buffers
Manuel Requena <manuel.requena@cttc.es>
parents: 9470
diff changeset
    66
  m_txBuffer.clear ();
9609
13aed388469a Fix some memory leaks
Manuel Requena <manuel.requena@cttc.es>
parents: 9597
diff changeset
    67
13aed388469a Fix some memory leaks
Manuel Requena <manuel.requena@cttc.es>
parents: 9597
diff changeset
    68
  LteRlc::DoDispose ();
9451
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    69
}
116fd6ad4640 cancel pending events upon RLC disposal
Nicola Baldo <nbaldo@cttc.es>
parents: 9414
diff changeset
    70
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    71
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    72
/**
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    73
 * RLC SAP
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    74
 */
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    75
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    76
void
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
    77
LteRlcTm::DoTransmitPdcpPdu (Ptr<Packet> p)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    78
{
8708
108d9d416b4c Add instance info for RlcUm
Manuel Requena <manuel.requena@cttc.es>
parents: 8666
diff changeset
    79
  NS_LOG_FUNCTION (this << m_rnti << (uint32_t) m_lcid << p->GetSize ());
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
    80
8745
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    81
  if (m_txBufferSize + p->GetSize () <= m_maxTxBufferSize)
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    82
    {
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    83
      /** Store arrival time */
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    84
      RlcTag timeTag (Simulator::Now ());
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    85
      p->AddPacketTag (timeTag);
8375
201d78643209 Add support for ReportBufferStatus parameters: txQueueSize and txQueueHolDelay
Manuel Requena <manuel.requena@cttc.es>
parents: 8361
diff changeset
    86
8745
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    87
      NS_LOG_LOGIC ("Tx Buffer: New packet added");
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    88
      m_txBuffer.push_back (p);
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    89
      m_txBufferSize += p->GetSize ();
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    90
      NS_LOG_LOGIC ("NumOfBuffers = " << m_txBuffer.size() );
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    91
      NS_LOG_LOGIC ("txBufferSize = " << m_txBufferSize);
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    92
    }
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    93
  else
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    94
    {
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    95
      // Discard full RLC SDU
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    96
      NS_LOG_LOGIC ("TxBuffer is full. RLC SDU discarded");
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    97
      NS_LOG_LOGIC ("MaxTxBufferSize = " << m_maxTxBufferSize);
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    98
      NS_LOG_LOGIC ("txBufferSize    = " << m_txBufferSize);
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
    99
      NS_LOG_LOGIC ("packet size     = " << p->GetSize ());
b94de33b24d3 Add maximum size to the RLC Transmission Buffer
Manuel Requena <manuel.requena@cttc.es>
parents: 8726
diff changeset
   100
    }
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   101
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   102
  /** Report Buffer Status */
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   103
  DoReportBufferStatus ();
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   104
  m_rbsTimer.Cancel ();
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   105
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   106
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   107
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   108
/**
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   109
 * MAC SAP
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   110
 */
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   111
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   112
void
9414
7b0db3dbf19b merged lena-dev and lena-epc
Nicola Baldo <nbaldo@cttc.es>
parents: 9351 9406
diff changeset
   113
LteRlcTm::DoNotifyTxOpportunity (uint32_t bytes, uint8_t layer, uint8_t harqId)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   114
{
9414
7b0db3dbf19b merged lena-dev and lena-epc
Nicola Baldo <nbaldo@cttc.es>
parents: 9351 9406
diff changeset
   115
  NS_LOG_FUNCTION (this << m_rnti << (uint32_t) m_lcid << bytes  << (uint32_t) layer << (uint32_t) harqId);
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   116
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   117
  // 5.1.1.1 Transmit operations 
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   118
  // 5.1.1.1.1 General
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   119
  // When submitting a new TMD PDU to lower layer, the transmitting TM RLC entity shall:
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   120
  // - submit a RLC SDU without any modification to lower layer.
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   121
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   122
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   123
  if ( m_txBuffer.size () == 0 )
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   124
    {
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   125
      NS_LOG_LOGIC ("No data pending");
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   126
      return;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   127
    }
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   128
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   129
  Ptr<Packet> packet = (*(m_txBuffer.begin ()))->Copy ();
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   130
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   131
  if (bytes < packet->GetSize ())
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   132
    {
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   133
      NS_LOG_WARN ("TX opportunity too small = " << bytes << " (PDU size: " << packet->GetSize () << ")");
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   134
      return;
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   135
    }
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   136
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   137
  m_txBufferSize -= (*(m_txBuffer.begin()))->GetSize ();
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   138
  m_txBuffer.erase (m_txBuffer.begin ());
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   139
 
8422
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   140
  // Sender timestamp
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   141
  RlcTag rlcTag (Simulator::Now ());
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   142
  packet->AddByteTag (rlcTag);
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   143
  m_txPdu (m_rnti, m_lcid, packet->GetSize ());
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   144
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   145
  // Send RLC PDU to MAC layer
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   146
  LteMacSapProvider::TransmitPduParameters params;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   147
  params.pdu = packet;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   148
  params.rnti = m_rnti;
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   149
  params.lcid = m_lcid;
8714
398bbcbb3f42 Add MIMO model, test and documentation
Marco Miozzo <marco.miozzo@cttc.es>
parents: 8586
diff changeset
   150
  params.layer = layer;
9351
6e074e67a1ad HARQ first draft version: RR works, PF todo, LteMiErrorModel on-going
mmiozzo
parents: 8745
diff changeset
   151
  params.harqProcessId = harqId;
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   152
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   153
  m_macSapProvider->TransmitPdu (params);
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   154
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   155
  if (! m_txBuffer.empty ())
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   156
    {
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   157
      m_rbsTimer.Cancel ();
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   158
      m_rbsTimer = Simulator::Schedule (MilliSeconds (10), &LteRlcTm::ExpireRbsTimer, this);
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   159
    }
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   160
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   161
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   162
void
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   163
LteRlcTm::DoNotifyHarqDeliveryFailure ()
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   164
{
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   165
  NS_LOG_FUNCTION (this);
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   166
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   167
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   168
void
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   169
LteRlcTm::DoReceivePdu (Ptr<Packet> p)
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   170
{
8708
108d9d416b4c Add instance info for RlcUm
Manuel Requena <manuel.requena@cttc.es>
parents: 8666
diff changeset
   171
  NS_LOG_FUNCTION (this << m_rnti << (uint32_t) m_lcid << p->GetSize ());
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   172
8422
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   173
  // Receiver timestamp
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   174
  RlcTag rlcTag;
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   175
  Time delay;
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   176
  if (p->FindFirstMatchingByteTag (rlcTag))
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   177
    {
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   178
      delay = Simulator::Now() - rlcTag.GetSenderTimestamp ();
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   179
    }
8666
cd02fdf79147 Clean traces
Manuel Requena <manuel.requena@cttc.es>
parents: 8638
diff changeset
   180
  m_rxPdu (m_rnti, m_lcid, p->GetSize (), delay.GetNanoSeconds ());
8422
550cd0670022 Add RLC stats
Manuel Requena <manuel.requena@cttc.es>
parents: 8377
diff changeset
   181
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   182
  // 5.1.1.2 Receive operations 
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   183
  // 5.1.1.2.1  General
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   184
  // When receiving a new TMD PDU from lower layer, the receiving TM RLC entity shall:
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   185
  // - deliver the TMD PDU without any modification to upper layer.
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   186
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   187
   m_rlcSapUser->ReceivePdcpPdu (p);
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   188
}
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   189
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   190
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   191
void
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   192
LteRlcTm::DoReportBufferStatus (void)
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   193
{
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   194
  Time holDelay (0);
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   195
  uint32_t queueSize = 0;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   196
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   197
  if (! m_txBuffer.empty ())
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   198
    {
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   199
      RlcTag holTimeTag;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   200
      m_txBuffer.front ()->PeekPacketTag (holTimeTag);
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   201
      holDelay = Simulator::Now () - holTimeTag.GetSenderTimestamp ();
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   202
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   203
      queueSize = m_txBufferSize; // just data in tx queue (no header overhead for RLC TM)
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   204
    }
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   205
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   206
  LteMacSapProvider::ReportBufferStatusParameters r;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   207
  r.rnti = m_rnti;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   208
  r.lcid = m_lcid;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   209
  r.txQueueSize = queueSize;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   210
  r.txQueueHolDelay = holDelay.GetMilliSeconds () ;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   211
  r.retxQueueSize = 0;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   212
  r.retxQueueHolDelay = 0;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   213
  r.statusPduSize = 0;
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   214
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   215
  NS_LOG_LOGIC ("Send ReportBufferStatus = " << r.txQueueSize << ", " << r.txQueueHolDelay );
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   216
  m_macSapProvider->ReportBufferStatus (r);
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   217
}
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   218
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   219
void
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   220
LteRlcTm::ExpireRbsTimer (void)
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   221
{
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   222
  NS_LOG_LOGIC ("RBS Timer expires");
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   223
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   224
  if (! m_txBuffer.empty ())
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   225
    {
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   226
      DoReportBufferStatus ();
9406
7f0f9d8f8e20 new LTE RRC model
Nicola Baldo <nbaldo@cttc.es>
parents: 8745
diff changeset
   227
      m_rbsTimer = Simulator::Schedule (MilliSeconds (10), &LteRlcTm::ExpireRbsTimer, this);
8499
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   228
    }
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   229
}
c2658133775b Add timer to send RBS to MAC
Manuel Requena <manuel.requena@cttc.es>
parents: 8493
diff changeset
   230
8361
d7f82b579891 UM RLC entity
Manuel Requena <manuel.requena@cttc.es>
parents:
diff changeset
   231
} // namespace ns3