blob: 31d57fc6b457631441d27f4b03b11783aba4d3f0 [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 Afanasyev0c395372014-12-20 15:54:02 -080022#include "ndn-net-device-face.hpp"
23#include "ndn-l3-protocol.hpp"
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 Afanasyev0c395372014-12-20 15:54:02 -080034#include "ns3/ndn-name.hpp"
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -070035
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080036NS_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 Afanasyevbe55cf62014-12-20 17:51:09 -080041NS_OBJECT_ENSURE_REGISTERED(NetDeviceFace);
Alexander Afanasyevea9b3e62012-08-13 19:02:54 -070042
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080043TypeId
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080044NetDeviceFace::GetTypeId()
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080045{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080046 static TypeId tid = TypeId("ns3::ndn::NetDeviceFace").SetParent<Face>().SetGroupName("Ndn");
Alexander Afanasyevcbe92ae2011-12-16 13:06:18 -080047 return tid;
48}
49
Alexander Afanasyev565b50c2013-02-01 13:22:56 -080050/**
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070051 * By default, Ndn face are created in the "down" state. Before
Alexander Afanasyev0ab833e2011-08-18 15:49:13 -070052 * becoming useable, the user must invoke SetUp on the face
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070053 */
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080054NetDeviceFace::NetDeviceFace(Ptr<Node> node, const Ptr<NetDevice>& netDevice)
55 : Face(node)
56 , m_netDevice(netDevice)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070057{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080058 NS_LOG_FUNCTION(this << netDevice);
Alexander Afanasyev0ab833e2011-08-18 15:49:13 -070059
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080060 SetMetric(1); // default metric
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -070061
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080062 NS_ASSERT_MSG(m_netDevice != 0, "NetDeviceFace needs to be assigned a valid NetDevice");
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070063}
64
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080065NetDeviceFace::~NetDeviceFace()
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070066{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080067 NS_LOG_FUNCTION_NOARGS();
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070068}
69
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070070NetDeviceFace& NetDeviceFace::operator= (const NetDeviceFace &)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070071{
72 return *this;
73}
74
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070075Ptr<NetDevice>
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080076NetDeviceFace::GetNetDevice() const
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070077{
78 return m_netDevice;
79}
80
81void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080082NetDeviceFace::RegisterProtocolHandlers(const InterestHandler& interestHandler,
83 const DataHandler& dataHandler)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070084{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080085 NS_LOG_FUNCTION(this);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070086
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080087 Face::RegisterProtocolHandlers(interestHandler, dataHandler);
Alexander Afanasyev565b50c2013-02-01 13:22:56 -080088
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080089 m_node->RegisterProtocolHandler(MakeCallback(&NetDeviceFace::ReceiveFromNetDevice, this),
90 L3Protocol::ETHERNET_FRAME_TYPE, m_netDevice,
91 true /*promiscuous mode*/);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070092}
93
Alexander Afanasyev5bee19e2013-07-10 14:33:57 -070094void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080095NetDeviceFace::UnRegisterProtocolHandlers()
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070096{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080097 m_node->UnregisterProtocolHandler(MakeCallback(&NetDeviceFace::ReceiveFromNetDevice, this));
98 Face::UnRegisterProtocolHandlers();
Alexander Afanasyev5bee19e2013-07-10 14:33:57 -070099}
100
101bool
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800102NetDeviceFace::Send(Ptr<Packet> packet)
Alexander Afanasyev5bee19e2013-07-10 14:33:57 -0700103{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800104 if (!Face::Send(packet)) {
105 return false;
106 }
Alexander Afanasyev565b50c2013-02-01 13:22:56 -0800107
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800108 NS_LOG_FUNCTION(this << packet);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700109
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800110 NS_ASSERT_MSG(packet->GetSize() <= m_netDevice->GetMtu(),
111 "Packet size " << packet->GetSize() << " exceeds device MTU "
112 << m_netDevice->GetMtu() << " for Ndn; fragmentation not supported");
113
114 bool ok = m_netDevice->Send(packet, m_netDevice->GetBroadcast(), L3Protocol::ETHERNET_FRAME_TYPE);
Alexander Afanasyev1c0248b2012-07-24 15:59:50 -0700115 return ok;
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700116}
117
118// callback
119void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800120NetDeviceFace::ReceiveFromNetDevice(Ptr<NetDevice> device, Ptr<const Packet> p, uint16_t protocol,
121 const Address& from, const Address& to,
122 NetDevice::PacketType packetType)
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700123{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800124 NS_LOG_FUNCTION(device << p << protocol << from << to << packetType);
125 Receive(p);
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700126}
127
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700128std::ostream&
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800129NetDeviceFace::Print(std::ostream& os) const
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700130{
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700131#ifdef NS3_LOG_ENABLE
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800132 os << "dev[" << GetNode()->GetId() << "]=net(" << GetId();
Alexander Afanasyev565b50c2013-02-01 13:22:56 -0800133
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800134 if (DynamicCast<PointToPointNetDevice>(m_netDevice)) {
135 // extra debugging information which available ONLY for PointToPointNetDevice's
136 os << ",";
137 os << DynamicCast<PointToPointNetDevice>(m_netDevice)
138 ->GetChannel()
139 ->GetDevice(0)
140 ->GetNode()
141 ->GetId();
142 os << "-";
143 os << DynamicCast<PointToPointNetDevice>(m_netDevice)
144 ->GetChannel()
145 ->GetDevice(1)
146 ->GetNode()
147 ->GetId();
148 }
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -0700149 os << ")";
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700150#else
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800151 os << "dev=net(" << GetId() << ")";
Alexander Afanasyev565b50c2013-02-01 13:22:56 -0800152#endif
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700153 return os;
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700154}
155
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700156} // namespace ndnsim
157} // namespace ns3