author | Craig Dowell <craigdo@ee.washington.edu> |
Mon, 16 Jun 2008 16:25:52 -0700 | |
changeset 3276 | 8869a79a391f |
parent 3269 | 448134601b03 |
child 3294 | 2ade6552db36 |
permissions | -rw-r--r-- |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
1 |
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
2 |
/* |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
3 |
* This program is free software; you can redistribute it and/or modify |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
4 |
* it under the terms of the GNU General Public License version 2 as |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
5 |
* published by the Free Software Foundation; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
6 |
* |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
7 |
* This program is distributed in the hope that it will be useful, |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
8 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
9 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
10 |
* GNU General Public License for more details. |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
11 |
* |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
12 |
* You should have received a copy of the GNU General Public License |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
13 |
* along with this program; if not, write to the Free Software |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
14 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
15 |
* |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
16 |
*/ |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
17 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
18 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
19 |
// Network topology |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
20 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
21 |
// 10Mb/s, 10ms 10Mb/s, 10ms |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
22 |
// n0-----------------n1-----------------n2 |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
23 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
24 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
25 |
// - Tracing of queues and packet receptions to file |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
26 |
// "tcp-large-transfer.tr" |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
27 |
// - pcap traces also generated in the following files |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
28 |
// "tcp-large-transfer.pcap-$n-$i" where n and i represent node and interface numbers respectively |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
29 |
// Usage (e.g.): ./waf --run tcp-large-transfer |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
30 |
|
3240
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
31 |
//XXX this isn't working as described right now |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
32 |
//it is just blasting away for 10 seconds, with no fixed amount of data |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
33 |
//being sent |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
34 |
|
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
35 |
#include <ctype.h> |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
36 |
#include <iostream> |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
37 |
#include <fstream> |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
38 |
#include <string> |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
39 |
#include <cassert> |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
40 |
|
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
41 |
#include "ns3/core-module.h" |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
42 |
#include "ns3/helper-module.h" |
2753
1f03a5531746
fallout from gustavo's header inclusion policy change.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2749
diff
changeset
|
43 |
#include "ns3/node-module.h" |
1f03a5531746
fallout from gustavo's header inclusion policy change.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2749
diff
changeset
|
44 |
#include "ns3/global-route-manager.h" |
1f03a5531746
fallout from gustavo's header inclusion policy change.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2749
diff
changeset
|
45 |
#include "ns3/simulator-module.h" |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
46 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
47 |
using namespace ns3; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
48 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
49 |
NS_LOG_COMPONENT_DEFINE ("TcpLargeTransfer"); |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
50 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
51 |
void |
2540
4e9ba43f7b9e
use Config-based trace system
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2494
diff
changeset
|
52 |
ApplicationTraceSink (Ptr<const Packet> packet, |
4e9ba43f7b9e
use Config-based trace system
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2494
diff
changeset
|
53 |
const Address &addr) |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
54 |
{ |
2227 | 55 |
// g_log is not declared in optimized builds |
56 |
// should convert this to use of some other flag than the logging system |
|
57 |
#ifdef NS3_LOG_ENABLE |
|
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
58 |
if (!g_log.IsNoneEnabled ()) { |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
59 |
if (InetSocketAddress::IsMatchingType (addr) ) |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
60 |
{ |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
61 |
InetSocketAddress address = InetSocketAddress::ConvertFrom (addr); |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
62 |
std::cout << "PacketSink received size " << |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
63 |
packet->GetSize () << " at time " << |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
64 |
Simulator::Now ().GetSeconds () << " from address: " << |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
65 |
address.GetIpv4 () << std::endl; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
66 |
char buf[2000]; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
67 |
memcpy(buf, packet->PeekData (), packet->GetSize ()); |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
68 |
for (uint32_t i=0; i < packet->GetSize (); i++) |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
69 |
{ |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
70 |
std::cout << buf[i]; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
71 |
if (i && i % 60 == 0) |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
72 |
std::cout << std::endl; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
73 |
} |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
74 |
std::cout << std::endl << std::endl; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
75 |
} |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
76 |
} |
2227 | 77 |
#endif |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
78 |
} |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
79 |
|
3240
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
80 |
void CloseConnection (Ptr<Socket> localSocket); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
81 |
void StartFlow(Ptr<Socket>, uint32_t, Ipv4Address, uint16_t); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
82 |
void WriteUntilBufferFull (Ptr<Socket>, uint32_t); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
83 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
84 |
int main (int argc, char *argv[]) |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
85 |
{ |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
86 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
87 |
// Users may find it convenient to turn on explicit debugging |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
88 |
// for selected modules; the below lines suggest how to do this |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
89 |
// LogComponentEnable("TcpL4Protocol", LOG_LEVEL_ALL); |
3276
8869a79a391f
Changes for bug 205, unlisted FIN bug
Craig Dowell <craigdo@ee.washington.edu>
parents:
3269
diff
changeset
|
90 |
// LogComponentEnable("TcpSocketImpl", LOG_LEVEL_ALL); |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
91 |
// LogComponentEnable("PacketSink", LOG_LEVEL_ALL); |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
92 |
// LogComponentEnable("TcpLargeTransfer", LOG_LEVEL_ALL); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
93 |
|
2865
d40eb18a4da0
Point regression tests to final locations, update release steps, bug 158
Craig Dowell <craigdo@ee.washington.edu>
parents:
2845
diff
changeset
|
94 |
// |
d40eb18a4da0
Point regression tests to final locations, update release steps, bug 158
Craig Dowell <craigdo@ee.washington.edu>
parents:
2845
diff
changeset
|
95 |
// Make the random number generators generate reproducible results. |
d40eb18a4da0
Point regression tests to final locations, update release steps, bug 158
Craig Dowell <craigdo@ee.washington.edu>
parents:
2845
diff
changeset
|
96 |
// |
d40eb18a4da0
Point regression tests to final locations, update release steps, bug 158
Craig Dowell <craigdo@ee.washington.edu>
parents:
2845
diff
changeset
|
97 |
RandomVariable::UseGlobalSeed (1, 1, 2, 3, 5, 8); |
d40eb18a4da0
Point regression tests to final locations, update release steps, bug 158
Craig Dowell <craigdo@ee.washington.edu>
parents:
2845
diff
changeset
|
98 |
|
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
99 |
// Allow the user to override any of the defaults and the above |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
100 |
// Bind()s at run-time, via command-line arguments |
2575
1aae382e65e2
rewrite CommandLine to not handle DefaultValues anymore.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2540
diff
changeset
|
101 |
CommandLine cmd; |
1aae382e65e2
rewrite CommandLine to not handle DefaultValues anymore.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2540
diff
changeset
|
102 |
cmd.Parse (argc, argv); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
103 |
|
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
104 |
// Here, we will explicitly create three nodes. |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
105 |
NodeContainer c0; |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
106 |
c0.Create (2); |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
107 |
|
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
108 |
NodeContainer c1; |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
109 |
c1.Add (c0.Get (1)); |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
110 |
c1.Create (1); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
111 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
112 |
// We create the channels first without any IP addressing information |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
113 |
PointToPointHelper p2p; |
3181
26e7f865c548
point-to-point cleanup
Craig Dowell <craigdo@ee.washington.edu>
parents:
3174
diff
changeset
|
114 |
p2p.SetDeviceParameter ("DataRate", DataRateValue (DataRate(10000000))); |
2965
4b28e9740e3b
get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2890
diff
changeset
|
115 |
p2p.SetChannelParameter ("Delay", TimeValue (MilliSeconds(10))); |
2887
9a637e6daee0
Build -> Install
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2879
diff
changeset
|
116 |
NetDeviceContainer dev0 = p2p.Install (c0); |
9a637e6daee0
Build -> Install
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2879
diff
changeset
|
117 |
NetDeviceContainer dev1 = p2p.Install (c1); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
118 |
|
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
119 |
// add ip/tcp stack to nodes. |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
120 |
NodeContainer c = NodeContainer (c0, c1.Get (1)); |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
121 |
InternetStackHelper internet; |
2887
9a637e6daee0
Build -> Install
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2879
diff
changeset
|
122 |
internet.Install (c); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
123 |
|
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
124 |
// Later, we add IP addresses. |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
125 |
Ipv4AddressHelper ipv4; |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
126 |
ipv4.SetBase ("10.1.3.0", "255.255.255.0"); |
2888
872dc8466352
Ipv4AddressHelper::Allocate -> Ipv4AddressHelper::Assign
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2887
diff
changeset
|
127 |
ipv4.Assign (dev0); |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
128 |
ipv4.SetBase ("10.1.2.0", "255.255.255.0"); |
2888
872dc8466352
Ipv4AddressHelper::Allocate -> Ipv4AddressHelper::Assign
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2887
diff
changeset
|
129 |
Ipv4InterfaceContainer ipInterfs = ipv4.Assign (dev1); |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
130 |
|
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
131 |
// and setup ip routing tables to get total ip-level connectivity. |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
132 |
GlobalRouteManager::PopulateRoutingTables (); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
133 |
|
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
134 |
/////////////////////////////////////////////////////////////////////////// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
135 |
// Simulation 1 |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
136 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
137 |
// Send 2000000 bytes over a connection to server port 50000 at time 0 |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
138 |
// Should observe SYN exchange, a lot of data segments, and FIN exchange |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
139 |
// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
140 |
/////////////////////////////////////////////////////////////////////////// |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
141 |
|
3255
ba3b5024f6a6
Restore tcp example to full size, also a bugfix
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3248
diff
changeset
|
142 |
int nBytes = 2000000; |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
143 |
uint16_t servPort = 50000; |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
144 |
|
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
145 |
// Create a packet sink to receive these packets |
3132
b0b0abb911cd
move Tcp to TcpSocketFactory
Tom Henderson <tomh@tomh.org>
parents:
3116
diff
changeset
|
146 |
PacketSinkHelper sink ("ns3::TcpSocketFactory", |
2965
4b28e9740e3b
get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2890
diff
changeset
|
147 |
InetSocketAddress (Ipv4Address::GetAny (), servPort)); |
2890
172baa5960ff
rework app constructors
Craig Dowell <craigdo@ee.washington.edu>
parents:
2889
diff
changeset
|
148 |
|
2887
9a637e6daee0
Build -> Install
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2879
diff
changeset
|
149 |
ApplicationContainer apps = sink.Install (c1.Get (1)); |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
150 |
apps.Start (Seconds (0.0)); |
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
151 |
|
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
152 |
// and generate traffic to remote sink. |
3132
b0b0abb911cd
move Tcp to TcpSocketFactory
Tom Henderson <tomh@tomh.org>
parents:
3116
diff
changeset
|
153 |
//TypeId tid = TypeId::LookupByName ("ns3::TcpSocketFactory"); |
b0b0abb911cd
move Tcp to TcpSocketFactory
Tom Henderson <tomh@tomh.org>
parents:
3116
diff
changeset
|
154 |
Ptr<Socket> localSocket = Socket::CreateSocket (c0.Get (0), TcpSocketFactory::GetTypeId ()); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
155 |
localSocket->Bind (); |
2746
177a8a3f3c65
convert to helper API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2602
diff
changeset
|
156 |
Simulator::ScheduleNow (&StartFlow, localSocket, nBytes, |
2749
0aa031496023
use Ipv4InterfaceContainer to avoid hardcoding ip addresses.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2746
diff
changeset
|
157 |
ipInterfs.GetAddress (1), servPort); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
158 |
|
2594
a8f89acd17a1
Config::Connect -> Config::ConnectWithoutContext && Config::ConnectWithContext -> Config::Connect
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2592
diff
changeset
|
159 |
Config::ConnectWithoutContext ("/NodeList/*/ApplicationList/*/Rx", |
2540
4e9ba43f7b9e
use Config-based trace system
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2494
diff
changeset
|
160 |
MakeCallback (&ApplicationTraceSink)); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
161 |
|
2789
47e92324cf4b
configure tracing post-topology construction, not before.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2788
diff
changeset
|
162 |
std::ofstream ascii; |
47e92324cf4b
configure tracing post-topology construction, not before.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2788
diff
changeset
|
163 |
ascii.open ("tcp-large-transfer.tr"); |
2996
a83b94e277d4
EnablePcap()->EnablePcapAll(); EnableAscii()->EnableAsciiAll()
Tom Henderson <tomh@tomh.org>
parents:
2890
diff
changeset
|
164 |
PointToPointHelper::EnableAsciiAll (ascii); |
2789
47e92324cf4b
configure tracing post-topology construction, not before.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2788
diff
changeset
|
165 |
|
3012 | 166 |
PointToPointHelper::EnablePcapAll ("tcp-large-transfer"); |
2789
47e92324cf4b
configure tracing post-topology construction, not before.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2788
diff
changeset
|
167 |
|
3174
efeb6e5c276d
Make Application::Start/Stop times relative, Simulator::StopAt(time) renamed to Simulator::Stop(time) and time also made relative, to improve consistency of the API which uses relative times everywhere else. Closes bug #191.
Gustavo J. A. M. Carneiro <gjc@inescporto.pt>
parents:
3132
diff
changeset
|
168 |
Simulator::Stop (Seconds(1000)); |
2224
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
169 |
Simulator::Run (); |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
170 |
Simulator::Destroy (); |
6f97d21a99c2
Added in ns-3-tcp (second try)
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
diff
changeset
|
171 |
} |
3240
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
172 |
|
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
173 |
void CloseConnection (Ptr<Socket> localSocket) |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
174 |
{ |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
175 |
localSocket->Close (); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
176 |
} |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
177 |
|
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
178 |
void StartFlow(Ptr<Socket> localSocket, uint32_t nBytes, |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
179 |
Ipv4Address servAddress, |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
180 |
uint16_t servPort) |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
181 |
{ |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
182 |
// NS_LOG_LOGIC("Starting flow at time " << Simulator::Now ().GetSeconds ()); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
183 |
localSocket->Connect (InetSocketAddress (servAddress, servPort));//connect |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
184 |
localSocket->SetConnectCallback (MakeCallback (&CloseConnection), |
3276
8869a79a391f
Changes for bug 205, unlisted FIN bug
Craig Dowell <craigdo@ee.washington.edu>
parents:
3269
diff
changeset
|
185 |
Callback<void, Ptr<Socket> > ()); |
3240
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
186 |
//we want to close as soon as the connection is established |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
187 |
//the tcp state machine and outgoing buffer will assure that |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
188 |
//all of the data is delivered |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
189 |
localSocket->SetSendCallback (MakeCallback (&WriteUntilBufferFull)); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
190 |
WriteUntilBufferFull (localSocket, nBytes); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
191 |
} |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
192 |
|
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
193 |
void WriteUntilBufferFull (Ptr<Socket> localSocket, uint32_t nBytes) |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
194 |
{ |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
195 |
// Perform series of 1040 byte writes (this is a multiple of 26 since |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
196 |
// we want to detect data splicing in the output stream) |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
197 |
uint32_t writeSize = 1040; |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
198 |
uint8_t data[writeSize]; |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
199 |
while (nBytes > 0) { |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
200 |
uint32_t curSize= nBytes > writeSize ? writeSize : nBytes; |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
201 |
for(uint32_t i = 0; i < curSize; ++i) |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
202 |
{ |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
203 |
char m = toascii (97 + i % 26); |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
204 |
data[i] = m; |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
205 |
} |
3269
448134601b03
RecvFrom() expansion, add flags parameter to some Send calls
Tom Henderson <tomh@tomh.org>
parents:
3255
diff
changeset
|
206 |
uint32_t amountSent = localSocket->Send (data, curSize, 0); |
3241
284705f0775f
Use the correct semantics for sendcallback
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3240
diff
changeset
|
207 |
if(amountSent < curSize) |
284705f0775f
Use the correct semantics for sendcallback
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3240
diff
changeset
|
208 |
{ |
284705f0775f
Use the correct semantics for sendcallback
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3240
diff
changeset
|
209 |
std::cout << "Socket blocking, returning" << std::endl; |
284705f0775f
Use the correct semantics for sendcallback
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3240
diff
changeset
|
210 |
return; |
284705f0775f
Use the correct semantics for sendcallback
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3240
diff
changeset
|
211 |
} |
3240
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
212 |
nBytes -= curSize; |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
213 |
} |
965da7165e78
Tcp large transfer modified to keep sending for 10 seconds
Raj Bhattacharjea <raj.b@gatech.edu>
parents:
3239
diff
changeset
|
214 |
} |