3 # Copyright(c) 2010-2015 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, bsdapp
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.
66 ## Can be gcc, icc or clang.
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 # Machine forces strict alignment constraints.
79 CONFIG_RTE_ARCH_STRICT_ALIGN=n
82 # Compile to share library
84 CONFIG_RTE_BUILD_SHARED_LIB=n
87 # Combine to one single library
89 CONFIG_RTE_BUILD_COMBINE_LIBS=n
92 # Use newest code breaking previous ABI
97 # Compile Environment Abstraction Layer
99 CONFIG_RTE_LIBRTE_EAL=y
100 CONFIG_RTE_MAX_LCORE=128
101 CONFIG_RTE_MAX_NUMA_NODES=8
102 CONFIG_RTE_MAX_MEMSEG=256
103 CONFIG_RTE_MAX_MEMZONE=2560
104 CONFIG_RTE_MAX_TAILQ=32
105 CONFIG_RTE_LOG_LEVEL=8
106 CONFIG_RTE_LOG_HISTORY=256
107 CONFIG_RTE_LIBEAL_USE_HPET=n
108 CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID=n
109 CONFIG_RTE_EAL_ALWAYS_PANIC_ON_ERROR=n
110 CONFIG_RTE_EAL_IGB_UIO=y
111 CONFIG_RTE_EAL_VFIO=y
112 CONFIG_RTE_MALLOC_DEBUG=n
114 # Default driver path (or "" to disable)
115 CONFIG_RTE_EAL_PMD_PATH=""
118 # Special configurations in PCI Config Space for high performance
120 CONFIG_RTE_PCI_CONFIG=n
121 CONFIG_RTE_PCI_EXTENDED_TAG=""
122 CONFIG_RTE_PCI_MAX_READ_REQUEST_SIZE=0
125 # Compile Environment Abstraction Layer for linux
127 CONFIG_RTE_LIBRTE_EAL_LINUXAPP=y
130 # Compile Environment Abstraction Layer to support Vmware TSC map
132 CONFIG_RTE_LIBRTE_EAL_VMWARE_TSC_MAP_SUPPORT=y
135 # Compile the argument parser library
137 CONFIG_RTE_LIBRTE_KVARGS=y
140 # Compile generic ethernet library
142 CONFIG_RTE_LIBRTE_ETHER=y
143 CONFIG_RTE_LIBRTE_ETHDEV_DEBUG=n
144 CONFIG_RTE_MAX_ETHPORTS=32
145 CONFIG_RTE_MAX_QUEUES_PER_PORT=1024
146 CONFIG_RTE_LIBRTE_IEEE1588=n
147 CONFIG_RTE_ETHDEV_QUEUE_STAT_CNTRS=16
148 CONFIG_RTE_ETHDEV_RXTX_CALLBACKS=y
151 # Support NIC bypass logic
153 CONFIG_RTE_NIC_BYPASS=n
156 # Compile burst-oriented IGB & EM PMD drivers
158 CONFIG_RTE_LIBRTE_EM_PMD=y
159 CONFIG_RTE_LIBRTE_IGB_PMD=y
160 CONFIG_RTE_LIBRTE_E1000_DEBUG_INIT=n
161 CONFIG_RTE_LIBRTE_E1000_DEBUG_RX=n
162 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX=n
163 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX_FREE=n
164 CONFIG_RTE_LIBRTE_E1000_DEBUG_DRIVER=n
165 CONFIG_RTE_LIBRTE_E1000_PF_DISABLE_STRIP_CRC=n
168 # Compile burst-oriented IXGBE PMD driver
170 CONFIG_RTE_LIBRTE_IXGBE_PMD=y
171 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_INIT=n
172 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_RX=n
173 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX=n
174 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX_FREE=n
175 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_DRIVER=n
176 CONFIG_RTE_LIBRTE_IXGBE_PF_DISABLE_STRIP_CRC=n
177 CONFIG_RTE_IXGBE_INC_VECTOR=y
178 CONFIG_RTE_IXGBE_RX_OLFLAGS_ENABLE=y
181 # Compile burst-oriented I40E PMD driver
183 CONFIG_RTE_LIBRTE_I40E_PMD=y
184 CONFIG_RTE_LIBRTE_I40E_DEBUG_INIT=n
185 CONFIG_RTE_LIBRTE_I40E_DEBUG_RX=n
186 CONFIG_RTE_LIBRTE_I40E_DEBUG_TX=n
187 CONFIG_RTE_LIBRTE_I40E_DEBUG_TX_FREE=n
188 CONFIG_RTE_LIBRTE_I40E_DEBUG_DRIVER=n
189 CONFIG_RTE_LIBRTE_I40E_RX_ALLOW_BULK_ALLOC=y
190 CONFIG_RTE_LIBRTE_I40E_INC_VECTOR=n
191 CONFIG_RTE_LIBRTE_I40E_RX_OLFLAGS_ENABLE=y
192 CONFIG_RTE_LIBRTE_I40E_16BYTE_RX_DESC=n
193 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_PF=64
194 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_VF=4
195 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_VM=4
196 # interval up to 8160 us, aligned to 2 (or default value)
197 CONFIG_RTE_LIBRTE_I40E_ITR_INTERVAL=-1
200 # Compile burst-oriented FM10K PMD
202 CONFIG_RTE_LIBRTE_FM10K_PMD=y
203 CONFIG_RTE_LIBRTE_FM10K_DEBUG_INIT=n
204 CONFIG_RTE_LIBRTE_FM10K_DEBUG_RX=n
205 CONFIG_RTE_LIBRTE_FM10K_DEBUG_TX=n
206 CONFIG_RTE_LIBRTE_FM10K_DEBUG_TX_FREE=n
207 CONFIG_RTE_LIBRTE_FM10K_DEBUG_DRIVER=n
208 CONFIG_RTE_LIBRTE_FM10K_RX_OLFLAGS_ENABLE=y
209 CONFIG_RTE_LIBRTE_FM10K_INC_VECTOR=y
212 # Compile burst-oriented Mellanox ConnectX-3 (MLX4) PMD
214 CONFIG_RTE_LIBRTE_MLX4_PMD=n
215 CONFIG_RTE_LIBRTE_MLX4_DEBUG=n
216 CONFIG_RTE_LIBRTE_MLX4_SGE_WR_N=4
217 CONFIG_RTE_LIBRTE_MLX4_MAX_INLINE=0
218 CONFIG_RTE_LIBRTE_MLX4_TX_MP_CACHE=8
219 CONFIG_RTE_LIBRTE_MLX4_SOFT_COUNTERS=1
222 # Compile burst-oriented Mellanox ConnectX-4 (MLX5) PMD
224 CONFIG_RTE_LIBRTE_MLX5_PMD=n
225 CONFIG_RTE_LIBRTE_MLX5_DEBUG=n
226 CONFIG_RTE_LIBRTE_MLX5_SGE_WR_N=4
227 CONFIG_RTE_LIBRTE_MLX5_MAX_INLINE=0
228 CONFIG_RTE_LIBRTE_MLX5_TX_MP_CACHE=8
231 # Compile burst-oriented Broadcom PMD driver
233 CONFIG_RTE_LIBRTE_BNX2X_PMD=n
234 CONFIG_RTE_LIBRTE_BNX2X_DEBUG=n
235 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_INIT=n
236 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_RX=n
237 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_TX=n
238 CONFIG_RTE_LIBRTE_BNX2X_MF_SUPPORT=n
241 # Compile burst-oriented Chelsio Terminator 10GbE/40GbE (CXGBE) PMD
243 CONFIG_RTE_LIBRTE_CXGBE_PMD=y
244 CONFIG_RTE_LIBRTE_CXGBE_DEBUG=n
245 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_REG=n
246 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_MBOX=n
247 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_TX=n
248 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_RX=n
251 # Compile burst-oriented Cisco ENIC PMD driver
253 CONFIG_RTE_LIBRTE_ENIC_PMD=y
254 CONFIG_RTE_LIBRTE_ENIC_DEBUG=n
257 # Compile software PMD backed by SZEDATA2 device
259 CONFIG_RTE_LIBRTE_PMD_SZEDATA2=n
262 # Compile burst-oriented VIRTIO PMD driver
264 CONFIG_RTE_LIBRTE_VIRTIO_PMD=y
265 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_INIT=n
266 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_RX=n
267 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_TX=n
268 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DRIVER=n
269 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DUMP=n
272 # Compile burst-oriented VMXNET3 PMD driver
274 CONFIG_RTE_LIBRTE_VMXNET3_PMD=y
275 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_INIT=n
276 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_RX=n
277 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX=n
278 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX_FREE=n
279 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_DRIVER=n
282 # Compile example software rings based PMD
284 CONFIG_RTE_LIBRTE_PMD_RING=y
285 CONFIG_RTE_PMD_RING_MAX_RX_RINGS=16
286 CONFIG_RTE_PMD_RING_MAX_TX_RINGS=16
289 # Compile software PMD backed by PCAP files
291 CONFIG_RTE_LIBRTE_PMD_PCAP=n
294 # Compile link bonding PMD library
296 CONFIG_RTE_LIBRTE_PMD_BOND=y
297 CONFIG_RTE_LIBRTE_BOND_DEBUG_ALB=n
298 CONFIG_RTE_LIBRTE_BOND_DEBUG_ALB_L1=n
301 # Compile software PMD backed by AF_PACKET sockets (Linux only)
303 CONFIG_RTE_LIBRTE_PMD_AF_PACKET=y
308 CONFIG_RTE_LIBRTE_PMD_XENVIRT=n
313 CONFIG_RTE_LIBRTE_PMD_NULL=y
316 # Do prefetch of packet data within PMD driver receive function
318 CONFIG_RTE_PMD_PACKET_PREFETCH=y
321 # Compile generic crypto device library
323 CONFIG_RTE_LIBRTE_CRYPTODEV=y
324 CONFIG_RTE_LIBRTE_CRYPTODEV_DEBUG=n
325 CONFIG_RTE_CRYPTO_MAX_DEVS=64
326 CONFIG_RTE_CRYPTODEV_NAME_LEN=64
329 # Compile librte_ring
331 CONFIG_RTE_LIBRTE_RING=y
332 CONFIG_RTE_LIBRTE_RING_DEBUG=n
333 CONFIG_RTE_RING_SPLIT_PROD_CONS=n
334 CONFIG_RTE_RING_PAUSE_REP_COUNT=0
337 # Compile librte_mempool
339 CONFIG_RTE_LIBRTE_MEMPOOL=y
340 CONFIG_RTE_MEMPOOL_CACHE_MAX_SIZE=512
341 CONFIG_RTE_LIBRTE_MEMPOOL_DEBUG=n
344 # Compile librte_mbuf
346 CONFIG_RTE_LIBRTE_MBUF=y
347 CONFIG_RTE_LIBRTE_MBUF_DEBUG=n
348 CONFIG_RTE_MBUF_REFCNT_ATOMIC=y
349 CONFIG_RTE_PKTMBUF_HEADROOM=128
352 # Compile librte_mbuf_offload
354 CONFIG_RTE_LIBRTE_MBUF_OFFLOAD=y
355 CONFIG_RTE_LIBRTE_MBUF_OFFLOAD_DEBUG=n
358 # Compile librte_timer
360 CONFIG_RTE_LIBRTE_TIMER=y
361 CONFIG_RTE_LIBRTE_TIMER_DEBUG=n
364 # Compile librte_cfgfile
366 CONFIG_RTE_LIBRTE_CFGFILE=y
369 # Compile librte_cmdline
371 CONFIG_RTE_LIBRTE_CMDLINE=y
372 CONFIG_RTE_LIBRTE_CMDLINE_DEBUG=n
375 # Compile librte_hash
377 CONFIG_RTE_LIBRTE_HASH=y
378 CONFIG_RTE_LIBRTE_HASH_DEBUG=n
381 # Compile librte_jobstats
383 CONFIG_RTE_LIBRTE_JOBSTATS=y
388 CONFIG_RTE_LIBRTE_LPM=y
389 CONFIG_RTE_LIBRTE_LPM_DEBUG=n
394 CONFIG_RTE_LIBRTE_ACL=y
395 CONFIG_RTE_LIBRTE_ACL_DEBUG=n
398 # Compile librte_power
400 CONFIG_RTE_LIBRTE_POWER=y
401 CONFIG_RTE_LIBRTE_POWER_DEBUG=n
402 CONFIG_RTE_MAX_LCORE_FREQS=64
407 CONFIG_RTE_LIBRTE_NET=y
410 # Compile librte_ip_frag
412 CONFIG_RTE_LIBRTE_IP_FRAG=y
413 CONFIG_RTE_LIBRTE_IP_FRAG_DEBUG=n
414 CONFIG_RTE_LIBRTE_IP_FRAG_MAX_FRAG=4
415 CONFIG_RTE_LIBRTE_IP_FRAG_TBL_STAT=n
418 # Compile librte_meter
420 CONFIG_RTE_LIBRTE_METER=y
423 # Compile librte_sched
425 CONFIG_RTE_LIBRTE_SCHED=y
426 CONFIG_RTE_SCHED_DEBUG=n
427 CONFIG_RTE_SCHED_RED=n
428 CONFIG_RTE_SCHED_COLLECT_STATS=n
429 CONFIG_RTE_SCHED_SUBPORT_TC_OV=n
430 CONFIG_RTE_SCHED_PORT_N_GRINDERS=8
431 CONFIG_RTE_SCHED_VECTOR=y
434 # Compile the distributor library
436 CONFIG_RTE_LIBRTE_DISTRIBUTOR=y
439 # Compile the reorder library
441 CONFIG_RTE_LIBRTE_REORDER=y
444 # Compile librte_port
446 CONFIG_RTE_LIBRTE_PORT=y
447 CONFIG_RTE_PORT_STATS_COLLECT=n
450 # Compile librte_table
452 CONFIG_RTE_LIBRTE_TABLE=y
453 CONFIG_RTE_TABLE_STATS_COLLECT=n
456 # Compile librte_pipeline
458 CONFIG_RTE_LIBRTE_PIPELINE=y
459 CONFIG_RTE_PIPELINE_STATS_COLLECT=n
464 CONFIG_RTE_LIBRTE_KNI=y
465 CONFIG_RTE_KNI_KMOD=y
466 CONFIG_RTE_KNI_PREEMPT_DEFAULT=y
467 CONFIG_RTE_KNI_KO_DEBUG=n
468 CONFIG_RTE_KNI_VHOST=n
469 CONFIG_RTE_KNI_VHOST_MAX_CACHE_SIZE=1024
470 CONFIG_RTE_KNI_VHOST_VNET_HDR_EN=n
471 CONFIG_RTE_KNI_VHOST_DEBUG_RX=n
472 CONFIG_RTE_KNI_VHOST_DEBUG_TX=n
475 # Compile vhost library
476 # fuse-devel is needed to run vhost-cuse.
477 # fuse-devel enables user space char driver development
478 # vhost-user is turned on by default.
480 CONFIG_RTE_LIBRTE_VHOST=y
481 CONFIG_RTE_LIBRTE_VHOST_USER=y
482 CONFIG_RTE_LIBRTE_VHOST_NUMA=n
483 CONFIG_RTE_LIBRTE_VHOST_DEBUG=n
486 #Compile Xen domain0 support
488 CONFIG_RTE_LIBRTE_XEN_DOM0=n
491 # Enable warning directives
493 CONFIG_RTE_INSECURE_FUNCTION_WARNING=n
496 # Compile the test application
498 CONFIG_RTE_APP_TEST=y
501 # Compile the PMD test application
503 CONFIG_RTE_TEST_PMD=y
504 CONFIG_RTE_TEST_PMD_RECORD_CORE_CYCLES=n
505 CONFIG_RTE_TEST_PMD_RECORD_BURST_STATS=n