aaa95effdc0369738c4769e26ebe09fbd8d38e44
[dpdk.git] / doc / guides / sample_app_ug / index.rst
1 ..  BSD LICENSE
2     Copyright(c) 2010-2015 Intel Corporation. All rights reserved.
3     All rights reserved.
4
5     Redistribution and use in source and binary forms, with or without
6     modification, are permitted provided that the following conditions
7     are met:
8
9     * Redistributions of source code must retain the above copyright
10     notice, this list of conditions and the following disclaimer.
11     * Redistributions in binary form must reproduce the above copyright
12     notice, this list of conditions and the following disclaimer in
13     the documentation and/or other materials provided with the
14     distribution.
15     * Neither the name of Intel Corporation nor the names of its
16     contributors may be used to endorse or promote products derived
17     from this software without specific prior written permission.
18
19     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20     "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21     LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22     A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23     OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24     SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25     LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26     DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27     THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28     (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29     OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31 Sample Applications User Guide
32 ==============================
33
34 |today|
35
36 **Contents**
37
38 .. toctree::
39     :maxdepth: 2
40     :numbered:
41
42     intro
43     cmd_line
44     exception_path
45     hello_world
46     skeleton
47     rxtx_callbacks
48     ip_frag
49     ipv4_multicast
50     ip_reassembly
51     kernel_nic_interface
52     l2_forward_job_stats
53     l2_forward_real_virtual
54     l3_forward
55     l3_forward_power_man
56     l3_forward_access_ctrl
57     l3_forward_virtual
58     link_status_intr
59     load_balancer
60     multi_process
61     qos_metering
62     qos_scheduler
63     intel_quickassist
64     quota_watermark
65     timer
66     packet_ordering
67     vmdq_dcb_forwarding
68     vhost
69     netmap_compatibility
70     internet_proto_ip_pipeline
71     test_pipeline
72     dist_app
73     vm_power_management
74
75 **Figures**
76
77 :ref:`Figure 1.Packet Flow <figure_1>`
78
79 :ref:`Figure 2.Kernel NIC Application Packet Flow <figure_2>`
80
81 :ref:`Figure 3.Performance Benchmark Setup (Basic Environment) <figure_3>`
82
83 :ref:`Figure 4.Performance Benchmark Setup (Virtualized Environment) <figure_4>`
84
85 :ref:`Figure 5.Load Balancer Application Architecture <figure_5>`
86
87 :ref:`Figure 5.Example Rules File <figure_5_1>`
88
89 :ref:`Figure 6.Example Data Flow in a Symmetric Multi-process Application <figure_6>`
90
91 :ref:`Figure 7.Example Data Flow in a Client-Server Symmetric Multi-process Application <figure_7>`
92
93 :ref:`Figure 8.Master-slave Process Workflow <figure_8>`
94
95 :ref:`Figure 9.Slave Process Recovery Process Flow <figure_9>`
96
97 :ref:`Figure 10.QoS Scheduler Application Architecture <figure_10>`
98
99 :ref:`Figure 11.Intel®QuickAssist Technology Application Block Diagram <figure_11>`
100
101 :ref:`Figure 12.Pipeline Overview <figure_12>`
102
103 :ref:`Figure 13.Ring-based Processing Pipeline Performance Setup <figure_13>`
104
105 :ref:`Figure 14.Threads and Pipelines <figure_14>`
106
107 :ref:`Figure 15.Packet Flow Through the VMDQ and DCB Sample Application <figure_15>`
108
109 :ref:`Figure 16.QEMU Virtio-net (prior to vhost-net) <figure_16>`
110
111 :ref:`Figure 17.Virtio with Linux* Kernel Vhost <figure_17>`
112
113 :ref:`Figure 18.Vhost-net Architectural Overview <figure_18>`
114
115 :ref:`Figure 19.Packet Flow Through the vhost-net Sample Application <figure_19>`
116
117 :ref:`Figure 20.Packet Flow on TX in DPDK-testpmd <figure_20>`
118
119 :ref:`Figure 21.Test Pipeline Application <figure_21>`
120
121 :ref:`Figure 22.Performance Benchmarking Setup (Basic Environment) <figure_22>`
122
123 :ref:`Figure 23.Distributor Sample Application Layout <figure_23>`
124
125 :ref:`Figure 24.High level Solution <figure_24>`
126
127 :ref:`Figure 25.VM request to scale frequency <figure_25>`
128
129 **Tables**
130
131 :ref:`Table 1.Output Traffic Marking <table_1>`
132
133 :ref:`Table 2.Entity Types <table_2>`
134
135 :ref:`Table 3.Table Types <table_3>`