blob: f5f38a06e64548e5d77c2c6c41af33e7a1cbc051 [file] [log] [blame]
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
2/*
Ilya Moiseenko956d0542012-01-02 15:26:40 -08003 * Copyright (c) 2011 University of California, Los Angeles
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -07004 *
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: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
19 *
20 */
21
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070022#include "ndn-net-device-face.h"
23#include "ndn-l3-protocol.h"
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070024
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070025#include "ns3/net-device.h"
26#include "ns3/log.h"
27#include "ns3/packet.h"
28#include "ns3/node.h"
29#include "ns3/pointer.h"
30
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070031// #include "ns3/address.h"
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -070032#include "ns3/point-to-point-net-device.h"
33#include "ns3/channel.h"
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070034#include "ns3/ndn-name-components.h"
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -070035
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070036NS_LOG_COMPONENT_DEFINE ("ndn.NetDeviceFace");
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070037
38namespace ns3 {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070039namespace ndn {
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070040
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080041TypeId
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070042NetDeviceFace::GetTypeId ()
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080043{
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070044 static TypeId tid = TypeId ("ns3::ndn::NetDeviceFace")
45 .SetParent<Face> ()
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070046 .SetGroupName ("Ndn")
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080047 ;
48 return tid;
49}
50
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070051/**
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070052 * By default, Ndn face are created in the "down" state. Before
Alexander Afanasyev0ab833e2011-08-18 15:49:13 -070053 * becoming useable, the user must invoke SetUp on the face
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070054 */
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070055NetDeviceFace::NetDeviceFace (Ptr<Node> node, const Ptr<NetDevice> &netDevice)
56 : Face (node)
Alexander Afanasyev09c7deb2011-11-23 14:50:10 -080057 , m_netDevice (netDevice)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070058{
Alexander Afanasyev09c7deb2011-11-23 14:50:10 -080059 NS_LOG_FUNCTION (this << netDevice);
Alexander Afanasyev0ab833e2011-08-18 15:49:13 -070060
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -070061 SetMetric (1); // default metric
62
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070063 NS_ASSERT_MSG (m_netDevice != 0, "NetDeviceFace needs to be assigned a valid NetDevice");
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070064}
65
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070066NetDeviceFace::~NetDeviceFace ()
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070067{
68 NS_LOG_FUNCTION_NOARGS ();
69}
70
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070071NetDeviceFace& NetDeviceFace::operator= (const NetDeviceFace &)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070072{
73 return *this;
74}
75
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070076Ptr<NetDevice>
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070077NetDeviceFace::GetNetDevice () const
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070078{
79 return m_netDevice;
80}
81
82void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070083NetDeviceFace::RegisterProtocolHandler (ProtocolHandler handler)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070084{
Alexander Afanasyev19426ef2011-11-23 20:55:28 -080085 NS_LOG_FUNCTION (this);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070086
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070087 Face::RegisterProtocolHandler (handler);
Alexander Afanasyev09c7deb2011-11-23 14:50:10 -080088
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070089 m_node->RegisterProtocolHandler (MakeCallback (&NetDeviceFace::ReceiveFromNetDevice, this),
90 L3Protocol::ETHERNET_FRAME_TYPE, m_netDevice, true/*promiscuous mode*/);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070091}
92
Alexander Afanasyev1c0248b2012-07-24 15:59:50 -070093bool
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070094NetDeviceFace::SendImpl (Ptr<Packet> packet)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070095{
Alexander Afanasyev09c7deb2011-11-23 14:50:10 -080096 NS_LOG_FUNCTION (this << packet);
97
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070098 NS_ASSERT_MSG (packet->GetSize () <= m_netDevice->GetMtu (),
99 "Packet size " << packet->GetSize () << " exceeds device MTU "
Alexander Afanasyeva5bbe0e2011-11-22 17:28:39 -0800100 << m_netDevice->GetMtu ()
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700101 << " for Ndn; fragmentation not supported");
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700102
Alexander Afanasyev1c0248b2012-07-24 15:59:50 -0700103 bool ok = m_netDevice->Send (packet, m_netDevice->GetBroadcast (),
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700104 L3Protocol::ETHERNET_FRAME_TYPE);
Alexander Afanasyev1c0248b2012-07-24 15:59:50 -0700105 return ok;
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700106}
107
108// callback
109void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700110NetDeviceFace::ReceiveFromNetDevice (Ptr<NetDevice> device,
111 Ptr<const Packet> p,
112 uint16_t protocol,
113 const Address &from,
114 const Address &to,
115 NetDevice::PacketType packetType)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700116{
Alexander Afanasyev23d2b542011-12-07 18:54:46 -0800117 NS_LOG_FUNCTION (device << p << protocol << from << to << packetType);
Alexander Afanasyev09c7deb2011-11-23 14:50:10 -0800118 Receive (p);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700119}
120
121
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700122std::ostream&
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700123NetDeviceFace::Print (std::ostream& os) const
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700124{
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700125#ifdef NS3_LOG_ENABLE
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -0700126 os << "dev[" << GetNode ()->GetId () << "]=net(" << GetId () << ",";
127 os << DynamicCast<PointToPointNetDevice> (m_netDevice)->GetChannel ()->GetDevice (0)->GetNode ()->GetId ();
128 os << "-";
129 os << DynamicCast<PointToPointNetDevice> (m_netDevice)->GetChannel ()->GetDevice (1)->GetNode ()->GetId ();
130 os << ")";
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700131#else
132 os << "dev=net(" << GetId () << ")";
133#endif
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700134 return os;
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700135}
136
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700137} // namespace ndnsim
138} // namespace ns3
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700139