A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
seq-ts-header.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2009 INRIA
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: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
18 */
19
20#ifndef SEQ_TS_HEADER_H
21#define SEQ_TS_HEADER_H
22
23#include "ns3/header.h"
24#include "ns3/nstime.h"
25
26namespace ns3
27{
28/**
29 * \ingroup applications
30 *
31 * \brief Packet header to carry sequence number and timestamp
32 *
33 * The header is used as a payload in applications (typically UDP) to convey
34 * a 32 bit sequence number followed by a 64 bit timestamp (12 bytes total).
35 *
36 * The timestamp is not set explicitly but automatically set to the
37 * simulation time upon creation.
38 *
39 * If you need space for an application data unit size field (e.g. for
40 * stream-based protocols like TCP), use ns3::SeqTsSizeHeader.
41 *
42 * \sa ns3::SeqTsSizeHeader
43 */
44class SeqTsHeader : public Header
45{
46 public:
48
49 /**
50 * \param seq the sequence number
51 */
52 void SetSeq(uint32_t seq);
53 /**
54 * \return the sequence number
55 */
56 uint32_t GetSeq() const;
57 /**
58 * \return the time stamp
59 */
60 Time GetTs() const;
61
62 /**
63 * \brief Get the type ID.
64 * \return the object TypeId
65 */
66 static TypeId GetTypeId();
67
68 TypeId GetInstanceTypeId() const override;
69 void Print(std::ostream& os) const override;
70 uint32_t GetSerializedSize() const override;
71 void Serialize(Buffer::Iterator start) const override;
73
74 private:
75 uint32_t m_seq; //!< Sequence number
76 uint64_t m_ts; //!< Timestamp
77};
78
79} // namespace ns3
80
81#endif /* SEQ_TS_HEADER_H */
iterator in a Buffer instance
Definition: buffer.h:100
Protocol header serialization and deserialization.
Definition: header.h:44
Packet header to carry sequence number and timestamp.
Definition: seq-ts-header.h:45
static TypeId GetTypeId()
Get the type ID.
uint64_t m_ts
Timestamp.
Definition: seq-ts-header.h:76
void Serialize(Buffer::Iterator start) const override
uint32_t m_seq
Sequence number.
Definition: seq-ts-header.h:75
void Print(std::ostream &os) const override
void SetSeq(uint32_t seq)
TypeId GetInstanceTypeId() const override
Get the most derived TypeId for this Object.
uint32_t GetSerializedSize() const override
uint32_t Deserialize(Buffer::Iterator start) override
Time GetTs() const
uint32_t GetSeq() const
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.