satellite-orbiter-user-phy.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013 Magister Solutions Ltd.
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: Sami Rantanen <sami.rantanen@magister.fi>
19  * Bastien Tauran <bastien.tauran@viveris.fr>
20  */
21 
22 #ifndef SATELLITE_ORBITER_USER_PHY_H
23 #define SATELLITE_ORBITER_USER_PHY_H
24 
25 #include "satellite-frame-conf.h"
26 #include "satellite-phy.h"
28 
29 #include <ns3/address.h>
30 #include <ns3/nstime.h>
31 #include <ns3/object.h>
32 #include <ns3/packet.h>
33 #include <ns3/ptr.h>
34 
35 #include <queue>
36 #include <stdint.h>
37 #include <tuple>
38 
39 namespace ns3
40 {
41 
42 class SatPhyRxCarrier;
43 class SatPhyRxCarrierUplink;
44 class SatPhyRxCarrierPerSlot;
45 class SatPhyRxCarrierPerFrame;
46 class SatPhyRxCarrierPerWindow;
47 
54 class SatOrbiterUserPhy : public SatPhy
55 {
56  public:
60  SatOrbiterUserPhy(void);
61 
63  Ptr<SatLinkResults> linkResults,
64  SatPhyRxCarrierConf::RxCarrierCreateParams_s parameters,
65  Ptr<SatSuperframeConf> superFrameConf);
66 
70  virtual ~SatOrbiterUserPhy();
71 
75  static TypeId GetTypeId(void);
76  TypeId GetInstanceTypeId(void) const;
77  virtual void DoInitialize(void);
78 
82  virtual void DoDispose(void);
83 
88  virtual void SendPduWithParams(Ptr<SatSignalParameters> rxParams);
89 
99  virtual void Receive(Ptr<SatSignalParameters> rxParams, bool phyError);
100 
106  virtual double GetAdditionalInterference();
107 
113  typedef void (*QueueSizeCallback)(uint32_t size, const Address& from);
114 
118  typedef Callback<bool, Ptr<SatControlMessage>, const Address&, Ptr<SatSignalParameters>>
120 
125 
130 
131  protected:
136  virtual void RxTraces(SatPhy::PacketContainer_t packets);
137 
143 
149 
153  TracedCallback<uint32_t, const Address&> m_queueSizeBytesTrace;
154 
158  TracedCallback<uint32_t, const Address&> m_queueSizePacketsTrace;
159 
160  private:
164  void SendFromQueue();
165 
169  void EndTx();
170 
177 
182 
187 
192 
197 
202 
207 
212  std::queue<std::tuple<Ptr<SatSignalParameters>, uint32_t, uint32_t>> m_queue;
213 
218 
223 
227  uint32_t m_queueSizeMax;
228 
233 };
234 
235 } // namespace ns3
236 
237 #endif /* SATELLITE_ORBITER_USER_PHY_H */
SatLinkDir_t
Link direction used for packet tracing.
RegenerationMode_t
The regeneration mode used in satellites.
The SatOrbiterUserPhy models the user link physical layer of the satellite node.
TracedCallback< uint32_t, const Address & > m_queueSizePacketsTrace
Traced callback to monitor RTN feeder queue size in packets.
void SetSendControlMsgToFeederCallback(SendControlMsgToFeederCallback cb)
Set SendControlMsgToFeederCallback.
SatOrbiterUserPhy::SendControlMsgToFeederCallback m_txCtrlFeederCallback
Callback to send ctrl packet on orbiter feeder.
double m_otherSysInterferenceCOverI
Other system interference in linear.
uint32_t m_queueSizeBytes
Size of FIFO queue in bytes.
virtual void SendPduWithParams(Ptr< SatSignalParameters > rxParams)
Send Pdu to the PHY tx module (for satellite switch packet forwarding)
virtual void DoInitialize(void)
Initialization of SatPhy.
uint32_t m_queueSizeMax
Maximum size of FIFO m_queue in bytes.
Address GetE2EDestinationAddress(SatPhy::PacketContainer_t packets)
Get destination address of packets.
virtual void DoDispose(void)
Dispose of this class instance.
virtual double GetAdditionalInterference()
Get additional interference, used to compute final SINR at RX.
Callback< bool, Ptr< SatControlMessage >, const Address &, Ptr< SatSignalParameters > > SendControlMsgToFeederCallback
SatOrbiterUserPhy(void)
Default constructor.
SatEnums::RegenerationMode_t m_forwardLinkRegenerationMode
Regeneration mode on forward link.
virtual void RxTraces(SatPhy::PacketContainer_t packets)
Invoke the Rx trace source for each received packet.
bool m_isSending
Indicates if a packet is already being sent.
double m_otherSysInterferenceCOverIDb
Configured other system interference in dB.
double m_aciInterferenceCOverIDb
Configured Adjacent Channel Interference (ACI) in dB.
std::queue< std::tuple< Ptr< SatSignalParameters >, uint32_t, uint32_t > > m_queue
Simple FIFO queue to avoid collisions on TX in case of REGENERATION_PHY.
virtual SatEnums::SatLinkDir_t GetSatLinkRxDir()
Get the link RX direction.
static TypeId GetTypeId(void)
inherited from Object
SatEnums::RegenerationMode_t m_returnLinkRegenerationMode
Regeneration mode on return link.
virtual SatEnums::SatLinkDir_t GetSatLinkTxDir()
Get the link TX direction.
TracedCallback< uint32_t, const Address & > m_queueSizeBytesTrace
Traced callback to monitor RTN feeder queue size in bytes.
void(* QueueSizeCallback)(uint32_t size, const Address &from)
Callback signature for QueueSizeBytes and QueueSizePackets trace source.
void SendFromQueue()
Send a packet from the queue.
virtual ~SatOrbiterUserPhy()
Destructor for SatOrbiterUserPhy.
virtual void Receive(Ptr< SatSignalParameters > rxParams, bool phyError)
Receives packets from lower layer.
void EndTx()
Notify a packet has finished being sent.
uint32_t m_queueSizePackets
Size of FIFO queue in packets.
double m_aciInterferenceCOverI
Adjacent Channel Interference (ACI) in linear.
The SatPhy models the basic physical layer of the satellite system.
Definition: satellite-phy.h:62
SatSignalParameters::PacketsInBurst_t PacketContainer_t
Define PacketContainer in SatPhy.
Definition: satellite-phy.h:79
SatArqSequenceNumber is handling the sequence numbers for the ARQ process.
Creation parameters for base PHY object.