3 # Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions
10 # * Redistributions of source code must retain the above copyright
11 # notice, this list of conditions and the following disclaimer.
12 # * Redistributions in binary form must reproduce the above copyright
13 # notice, this list of conditions and the following disclaimer in
14 # the documentation and/or other materials provided with the
16 # * Neither the name of Intel Corporation nor the names of its
17 # contributors may be used to endorse or promote products derived
18 # from this software without specific prior written permission.
20 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 # define executive environment
36 # CONFIG_RTE_EXEC_ENV can be linuxapp, baremetal
38 CONFIG_RTE_EXEC_ENV="linuxapp"
39 CONFIG_RTE_EXEC_ENV_LINUXAPP=y
42 ## machine can define specific variables or action for a specific board
43 ## RTE_MACHINE can be:
44 ## default nothing specific
45 ## native current machine
46 ## atm Intel® Atom™ microarchitecture
47 ## nhm Intel® microarchitecture code name Nehalem
48 ## wsm Intel® microarchitecture code name Westmere
49 ## snb Intel® microarchitecture code name Sandy Bridge
50 ## ivb Intel® microarchitecture code name Ivy Bridge
52 ## Note: if your compiler does not support the relevant -march options,
53 ## it will be compiled with whatever latest processor the compiler supports!
55 #CONFIG_RTE_MACHINE="native"
58 ## define the architecture we compile for.
59 ## CONFIG_RTE_ARCH can be i686, x86_64, x86_64_32
61 #CONFIG_RTE_ARCH="x86_64"
62 #CONFIG_RTE_ARCH_X86_64=y
65 ## The compiler we use.
68 #CONFIG_RTE_TOOLCHAIN="gcc"
69 #CONFIG_RTE_TOOLCHAIN_GCC=y
72 # Use intrinsics or assembly code for key routines
74 CONFIG_RTE_FORCE_INTRINSICS=n
77 # Compile to share library
79 CONFIG_RTE_BUILD_SHARED_LIB=n
82 # Combine to one single library
84 CONFIG_RTE_BUILD_COMBINE_LIBS=n
85 CONFIG_RTE_LIBNAME="intel_dpdk"
88 # Compile libc directory
93 # Compile newlib as libc from source
95 CONFIG_RTE_LIBC_NEWLIB_SRC=n
100 CONFIG_RTE_LIBC_NEWLIB_BIN=n
105 CONFIG_RTE_LIBC_NETINCS=n
108 # Compile libgloss (newlib-stubs)
110 CONFIG_RTE_LIBGLOSS=n
113 # Compile Environment Abstraction Layer
115 CONFIG_RTE_LIBRTE_EAL=y
116 CONFIG_RTE_MAX_LCORE=64
117 CONFIG_RTE_MAX_NUMA_NODES=8
118 CONFIG_RTE_MAX_MEMSEG=256
119 CONFIG_RTE_MAX_MEMZONE=2560
120 CONFIG_RTE_MAX_TAILQ=32
121 CONFIG_RTE_LOG_LEVEL=8
122 CONFIG_RTE_LOG_HISTORY=256
123 CONFIG_RTE_LIBEAL_USE_HPET=n
124 CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID=n
125 CONFIG_RTE_EAL_ALWAYS_PANIC_ON_ERROR=n
126 CONFIG_RTE_EAL_IGB_UIO=y
127 CONFIG_RTE_EAL_VFIO=y
130 # Compile Environment Abstraction Layer for linux
132 CONFIG_RTE_LIBRTE_EAL_LINUXAPP=y
135 # Compile Environment Abstraction Layer for Bare metal
137 CONFIG_RTE_LIBRTE_EAL_BAREMETAL=n
140 # Compile Environment Abstraction Layer to support Vmware TSC map
142 CONFIG_RTE_LIBRTE_EAL_VMWARE_TSC_MAP_SUPPORT=y
145 # Compile the argument parser library
147 CONFIG_RTE_LIBRTE_KVARGS=y
150 # Compile generic ethernet library
152 CONFIG_RTE_LIBRTE_ETHER=y
153 CONFIG_RTE_LIBRTE_ETHDEV_DEBUG=n
154 CONFIG_RTE_MAX_ETHPORTS=32
155 CONFIG_RTE_LIBRTE_IEEE1588=n
156 CONFIG_RTE_ETHDEV_QUEUE_STAT_CNTRS=16
159 # Support NIC bypass logic
161 CONFIG_RTE_NIC_BYPASS=n
164 # Compile burst-oriented IGB & EM PMD drivers
166 CONFIG_RTE_LIBRTE_EM_PMD=y
167 CONFIG_RTE_LIBRTE_IGB_PMD=y
168 CONFIG_RTE_LIBRTE_E1000_DEBUG_INIT=n
169 CONFIG_RTE_LIBRTE_E1000_DEBUG_RX=n
170 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX=n
171 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX_FREE=n
172 CONFIG_RTE_LIBRTE_E1000_DEBUG_DRIVER=n
173 CONFIG_RTE_LIBRTE_E1000_PF_DISABLE_STRIP_CRC=n
176 # Compile burst-oriented IXGBE PMD driver
178 CONFIG_RTE_LIBRTE_IXGBE_PMD=y
179 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_INIT=n
180 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_RX=n
181 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX=n
182 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX_FREE=n
183 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_DRIVER=n
184 CONFIG_RTE_LIBRTE_IXGBE_PF_DISABLE_STRIP_CRC=n
185 CONFIG_RTE_LIBRTE_IXGBE_RX_ALLOW_BULK_ALLOC=y
186 CONFIG_RTE_LIBRTE_IXGBE_ALLOW_UNSUPPORTED_SFP=n
187 CONFIG_RTE_IXGBE_INC_VECTOR=y
188 CONFIG_RTE_IXGBE_RX_OLFLAGS_DISABLE=n
191 # Compile burst-oriented VIRTIO PMD driver
193 CONFIG_RTE_LIBRTE_VIRTIO_PMD=y
194 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_INIT=n
195 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_RX=n
196 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_TX=n
197 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DRIVER=n
198 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DUMP=n
201 # Compile burst-oriented VMXNET3 PMD driver
203 CONFIG_RTE_LIBRTE_VMXNET3_PMD=y
204 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_INIT=n
205 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_RX=n
206 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX=n
207 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX_FREE=n
208 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_DRIVER=n
211 # Compile example software rings based PMD
213 CONFIG_RTE_LIBRTE_PMD_RING=y
214 CONFIG_RTE_PMD_RING_MAX_RX_RINGS=16
215 CONFIG_RTE_PMD_RING_MAX_TX_RINGS=16
218 # Compile software PMD backed by PCAP files
220 CONFIG_RTE_LIBRTE_PMD_PCAP=n
225 CONFIG_RTE_LIBRTE_PMD_XENVIRT=n
228 # Do prefetch of packet data within PMD driver receive function
230 CONFIG_RTE_PMD_PACKET_PREFETCH=y
233 # Compile librte_ring
235 CONFIG_RTE_LIBRTE_RING=y
236 CONFIG_RTE_LIBRTE_RING_DEBUG=n
237 CONFIG_RTE_RING_SPLIT_PROD_CONS=n
240 # Compile librte_mempool
242 CONFIG_RTE_LIBRTE_MEMPOOL=y
243 CONFIG_RTE_MEMPOOL_CACHE_MAX_SIZE=512
244 CONFIG_RTE_LIBRTE_MEMPOOL_DEBUG=n
247 # Compile librte_mbuf
249 CONFIG_RTE_LIBRTE_MBUF=y
250 CONFIG_RTE_LIBRTE_MBUF_DEBUG=n
251 CONFIG_RTE_MBUF_SCATTER_GATHER=y
252 CONFIG_RTE_MBUF_REFCNT_ATOMIC=y
253 CONFIG_RTE_PKTMBUF_HEADROOM=128
256 # Compile librte_timer
258 CONFIG_RTE_LIBRTE_TIMER=y
259 CONFIG_RTE_LIBRTE_TIMER_DEBUG=n
262 # Compile librte_malloc
264 CONFIG_RTE_LIBRTE_MALLOC=y
265 CONFIG_RTE_LIBRTE_MALLOC_DEBUG=n
266 CONFIG_RTE_MALLOC_MEMZONE_SIZE=11M
269 # Compile librte_cmdline
271 CONFIG_RTE_LIBRTE_CMDLINE=y
272 CONFIG_RTE_LIBRTE_CMDLINE_DEBUG=n
275 # Compile librte_hash
277 CONFIG_RTE_LIBRTE_HASH=y
278 CONFIG_RTE_LIBRTE_HASH_DEBUG=n
283 CONFIG_RTE_LIBRTE_LPM=y
284 CONFIG_RTE_LIBRTE_LPM_DEBUG=n
289 CONFIG_RTE_LIBRTE_ACL=y
290 CONFIG_RTE_LIBRTE_ACL_DEBUG=n
291 CONFIG_RTE_LIBRTE_ACL_STANDALONE=n
294 # Compile librte_power
296 CONFIG_RTE_LIBRTE_POWER=y
297 CONFIG_RTE_LIBRTE_POWER_DEBUG=n
298 CONFIG_RTE_MAX_LCORE_FREQS=64
303 CONFIG_RTE_LIBRTE_NET=y
306 # Compile librte_meter
308 CONFIG_RTE_LIBRTE_METER=y
311 # Compile librte_sched
313 CONFIG_RTE_LIBRTE_SCHED=y
314 CONFIG_RTE_SCHED_RED=n
315 CONFIG_RTE_SCHED_COLLECT_STATS=n
316 CONFIG_RTE_SCHED_SUBPORT_TC_OV=n
317 CONFIG_RTE_SCHED_PORT_N_GRINDERS=8
320 # Compile the distributor library
322 CONFIG_RTE_LIBRTE_DISTRIBUTOR=y
327 CONFIG_RTE_LIBRTE_KNI=y
328 CONFIG_RTE_KNI_KO_DEBUG=n
329 CONFIG_RTE_KNI_VHOST=n
330 CONFIG_RTE_KNI_VHOST_MAX_CACHE_SIZE=1024
331 CONFIG_RTE_KNI_VHOST_VNET_HDR_EN=n
332 CONFIG_RTE_KNI_VHOST_DEBUG_RX=n
333 CONFIG_RTE_KNI_VHOST_DEBUG_TX=n
336 #Compile Xen domain0 support
338 CONFIG_RTE_LIBRTE_XEN_DOM0=n
341 # Enable warning directives
343 CONFIG_RTE_INSECURE_FUNCTION_WARNING=n
346 # Compile the test application
348 CONFIG_RTE_APP_TEST=y
351 # Compile the PMD test application
353 CONFIG_RTE_TEST_PMD=y
354 CONFIG_RTE_TEST_PMD_RECORD_CORE_CYCLES=n
355 CONFIG_RTE_TEST_PMD_RECORD_BURST_STATS=n