blob: c03e341630c25d951032853d027590d5545c08ab [file] [log] [blame]
Alexander Afanasyev6dbacda2012-10-23 17:20:18 -07001FAQ
2===
3
4Boost libraries
5---------------
6
Alexander Afanasyev26b558b2012-12-13 11:39:46 -08007.. note::
8 **My ubuntu/redhat/freebsd have an old version of boost libraries. How can I get the latest one?**
Alexander Afanasyev6dbacda2012-10-23 17:20:18 -07009
Alexander Afanasyev26b558b2012-12-13 11:39:46 -080010.. _Installing boost libraries:
Alexander Afanasyev6dbacda2012-10-23 17:20:18 -070011
Alexander Afanasyev26b558b2012-12-13 11:39:46 -080012Installing boost libraries to ``/usr/local``
13^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Alexander Afanasyev6dbacda2012-10-23 17:20:18 -070014
Alexander Afanasyev26b558b2012-12-13 11:39:46 -080015.. role:: red
16
17.. note::
18 **The following instructions are for those who want to install latest version of boost libraries** :red:`and has root access`.
19
20The following commands would install the latest version of boost libraries (at the time of writing, version 1.52) ot ``/usr/local``, assuming you have a root access to your machine.
21If you don't have root access, please refer to section :ref:`Installing boost libraries to a non-privileged location`.
22
23.. note::
24 If you are using Ubuntyu, make sure that you have installed ``libbz2-dev``, otherwise not all libraries required by ndnSIM will be installed (see :ref:`Common pitfalls`)
25
26.. code-block:: bash
27 :linenos:
28
29 wget http://downloads.sourceforge.net/project/boost/boost/1.52.0/boost_1_52_0.tar.bz2
30 tar jxf boost_1_52_0.tar.bz2
31 cd boost_1_52_0
32 ./bootstrap.sh
33 sudo ./b2 --prefix=/usr/local install
34
35
36The following commands should allow compilation and run of NS-3 simulations with custom install of boost libraries:
37
38.. code-block:: bash
39 :linenos:
40
41 cd <ns-3>
42 ./waf configure --boost-includes=/usr/local/include --boost-libs=/usr/local/lib --enable-examples
43 ./waf
44 LD_LIBRARY_PATH=/usr/local/lib NS_LOG=ndn.Face:ndn.Consumer ./waf --run=ndn-simple
45
46.. note::
47 `LD_LIBRARY_PATH=/usr/local/lib` is necessary on Linux platform in order for the dynamic linker to find libraries installed in a location different from one of the folders specified in /etc/ld.so.conf.
48
49.. _Installing boost libraries to a non-privileged location:
50
51Installing boost libraries to a non-privileged location
52^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
53
54.. note::
55 **Follow these general instructions if you are trying to installboost libraries to a non-privileged location** :red:`(i.e., you do not have root access),` **but something is going wrong.**
56
57Normally, to compile and install boost libraries in non-privileged mode, you would need to issue following commands (e.g., for boost version 1.52.0):
58
59.. code-block:: bash
60 :linenos:
61
62 export BOOSTDIR=/home/non-privileged-user/boost
63 wget http://downloads.sourceforge.net/project/boost/boost/1.52.0/boost_1_52_0.tar.bz2
64 tar jxf boost_1_52_0.tar.bz2
65 cd boost_1_52_0
66 ./bootstrap.sh
67 ./b2 --prefix=$BOOSTDIR install
68
69However, after the following steps you may still not able to use ndnSIM.
70
71.. _Common pitfalls:
72
73Common pitfalls
74^^^^^^^^^^^^^^^
75
76The common pitfalls is with the **boost iostreams** library, which is required by ndnSIM, but failed to build because of the missing bzip2 library.
77This problem can be easily fixed by downloading and installing bzip2 library, e.g., using the following steps:
78
79.. code-block:: bash
80 :linenos:
81
82 wget http://www.bzip.org/1.0.6/bzip2-1.0.6.tar.gz
83 tar zxf bzip2-1.0.6.tar.gz
84 cd bzip2-1.0.6
85 make PREFIX=$BOOSTDIR CFLAGS="-fPIC -O2 -g" install
86
87Afte bzip2 library is installed, you may recompile and reinstall boost libraries using custom compilation flags::
88
89 ./b2 --prefix=$BOOSTDIR cxxflags=-I$BOOSTDIR/include linkflags=-L$BOOSTDIR/lib install
90
91Alternatively, you can solve this particular problem by installing development package for bzip2 library (:red:`if you have root access`). For example, on Ubuntu 12.04 it would be the following command::
92
93 sudo apt-get install libbz2-dev
94
95And then compiling and installing boost without custom compilation flags::
96
97 ./b2 --prefix=$BOOSTDIR
98
99
100The following commands should allow compilation and run of NS-3 simulations with custom install of boost libraries::
101
102 cd <ns-3>
103 ./waf configure --boost-includes=$BOOSTDIR/include --boost-libs=$BOOSTDIR/lib --enable-examples --enable-ndn-plugins=topology,mobility
104 ./waf
105 LD_LIBRARY_PATH=$BOOSTDIR/lib NS_LOG=ndn.Face:ndn.Consumer ./waf --run=ndn-simple
106
107.. note::
108 `LD_LIBRARY_PATH=$BOOSTDIR/lib` is necessary on Linux platform in order for the dynamic linker to find libraries installed in a location different from one of the folders specified in /etc/ld.so.conf.
109
110
Alexander Afanasyev6dbacda2012-10-23 17:20:18 -0700111
112Visualizer problems
113-------------------
114
115.. topic:: Visualizer module is not working
116
117 Every time I'm trying to run visualizer, I get the following error::
118
119 Waf: Entering directory `/ndnSIM/ns-3/build'
120 Could not find a task generator for the name 'ns3-visualizer'..
121
122Something is wrong with your python bindings and python bindings dependencies.
123Please follow the :ref:`requirements` section that lists what should be installed in order to run visualizer.
124
125Code questions
126--------------
127
128.. topic:: Failing a link between nodes
129
130 How can I fail a link between to NDN nodes?
131
132
133Right now, NS-3 does not provide ability to actually "break" the link between nodes in NS-3.
134However, exactly the same effect can be achieved by making an interface (:ndnsim:`ndn::Face`) up or down (:ndnsim:`ndn::Face::SetUp(true)` or :ndnsim:`ndn::Face::SetUp(false)`).
135
136Here is an example of function to "fail" a point-to-point link between two NDN nodes:
137
138.. code-block:: c++
139
140 // hijacker is more than an application. just disable all faces
141 void
142 FailLinks (Ptr<Node> node1, Ptr<Node> node2)
143 {
144 Ptr<ndn::L3Protocol> ndn1 = node1->GetObject<ndn::L3Protocol> ();
145 Ptr<ndn::L3Protocol> ndn2 = node2->GetObject<ndn::L3Protocol> ();
146
147 // iterate over all faces to find the right one
148 for (uint32_t faceId = 0; faceId < ndn1->GetNFaces (); faceId++)
149 {
150 Ptr<ndn::NetDeviceFace> ndFace = ndn1->GetFace (faceId)->GetObject<ndn::NetDeviceFace> ();
151 if (ndFace == 0) continue;
152
153 Ptr<PointToPointNetDevice> nd1 = ndFace->GetNetDevice ()->GetObject<PointToPointNetDevice> ();
154 if (nd1 == 0) continue;
155
156 Ptr<Channel> channel = nd1->GetChannel ();
157 if (channel == 0) continue;
158
159 Ptr<PointToPointChannel> ppChannel = DynamicCast<PointToPointChannel> (channel);
160
161 Ptr<NetDevice> nd2 = ppChannel->GetDevice (0);
162 if (nd2->GetNode () == node1)
163 nd2 = ppChannel->GetDevice (1);
164
165 if (nd2->GetNode () == node2)
166 {
167 Ptr<ndn::Face> face1 = ndn1->GetFaceByNetDevice (nd1);
168 Ptr<ndn::Face> face2 = ndn2->GetFaceByNetDevice (nd2);
169
170 face1->SetUp (false);
171 face2->SetUp (false);
172 break;
173 }
174 }
175 }
176
177
178General questions
179-----------------
180
181.. topic:: Errors/bugs reporting
182
183 I found an error in the documentation / bug in the code. What should I do?
184
Alexander Afanasyev26b558b2012-12-13 11:39:46 -0800185Please create an issue for the documentation error or code bug on `github <http://github.com/NDN-Routing/ndnSIM>`_, or tell us about the error on `our mailing list <http://www.lists.cs.ucla.edu/mailman/listinfo/ndnsim>`_ .