summaryrefslogtreecommitdiff
path: root/third-party/README.rst
blob: 9d536c3060baa3d5784f538125fedff3759e3e67 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
..
      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.

      Convention for heading levels in Open vSwitch documentation:

      =======  Heading 0 (reserved for the title in a document)
      -------  Heading 1
      ~~~~~~~  Heading 2
      +++++++  Heading 3
      '''''''  Heading 4

      Avoid deeper levels because they do not render well.

================================
Third-party software integration
================================

This directory contains third-party software that may be useful for debugging.

tcpdump
-------

The ``ofp-tcpdump.patch`` patch adds the ability to parse OpenFlow messages to
tcpdump.  These instructions assume that tcpdump 4.3.0 is going to be used, but
it should work with other versions that are not substantially different.  To
begin, download tcpdump and apply the patch:

::

    $ wget http://www.tcpdump.org/release/tcpdump-4.3.0.tar.gz
    $ tar xzf tcpdump-4.3.0.tar.gz
    $ ln -s tcpdump-4.3.0 tcpdump
    $ patch -p0 < ofp-tcpdump.patch

Then build the new version of tcpdump:

::

    $ cd tcpdump
    $ ./configure
    $ make

Clearly, tcpdump can only parse unencrypted packets, so you will need to
connect the controller and datapath using plain TCP.  To look at the traffic,
tcpdump will be started in a manner similar to the following:

::

    $ sudo ./tcpdump -s0 -i eth0 port 6653

The ``-s0`` flag indicates that tcpdump should capture the entire packet.  If
the OpenFlow message is not received in its entirety, ``[|openflow]`` will be
printed instead of the OpenFlow message contents.

The verbosity of the output may be increased by adding additional ``-v`` flags.
If ``-vvv`` is used, the raw OpenFlow data is also printed in hex and ASCII.