3 # Copyright(c) 2010-2016 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
35 # RTE_EXEC_ENV values are the directories in mk/exec-env/
40 # define the architecture we compile for.
41 # RTE_ARCH values are the directories in mk/arch/
46 # machine can define specific variables or action for a specific board
47 # RTE_MACHINE values are the directories in mk/machine/
52 # The compiler we use.
53 # RTE_TOOLCHAIN values are the directories in mk/toolchain/
58 # Use intrinsics or assembly code for key routines
60 CONFIG_RTE_FORCE_INTRINSICS=n
63 # Machine forces strict alignment constraints.
65 CONFIG_RTE_ARCH_STRICT_ALIGN=n
68 # Compile to share library
70 CONFIG_RTE_BUILD_SHARED_LIB=n
73 # Use newest code breaking previous ABI
78 # Machine's cache line size
80 CONFIG_RTE_CACHE_LINE_SIZE=64
83 # Compile Environment Abstraction Layer
85 CONFIG_RTE_LIBRTE_EAL=y
86 CONFIG_RTE_MAX_LCORE=128
87 CONFIG_RTE_MAX_NUMA_NODES=8
88 CONFIG_RTE_MAX_MEMSEG=256
89 CONFIG_RTE_MAX_MEMZONE=2560
90 CONFIG_RTE_MAX_TAILQ=32
91 CONFIG_RTE_LOG_LEVEL=RTE_LOG_INFO
92 CONFIG_RTE_LOG_DP_LEVEL=RTE_LOG_INFO
93 CONFIG_RTE_LOG_HISTORY=256
94 CONFIG_RTE_LIBEAL_USE_HPET=n
95 CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID=n
96 CONFIG_RTE_EAL_ALWAYS_PANIC_ON_ERROR=n
97 CONFIG_RTE_EAL_IGB_UIO=n
99 CONFIG_RTE_MALLOC_DEBUG=n
101 # Default driver path (or "" to disable)
102 CONFIG_RTE_EAL_PMD_PATH=""
105 # Compile Environment Abstraction Layer to support Vmware TSC map
107 CONFIG_RTE_LIBRTE_EAL_VMWARE_TSC_MAP_SUPPORT=y
110 # Compile the argument parser library
112 CONFIG_RTE_LIBRTE_KVARGS=y
115 # Compile generic ethernet library
117 CONFIG_RTE_LIBRTE_ETHER=y
118 CONFIG_RTE_LIBRTE_ETHDEV_DEBUG=n
119 CONFIG_RTE_MAX_ETHPORTS=32
120 CONFIG_RTE_MAX_QUEUES_PER_PORT=1024
121 CONFIG_RTE_LIBRTE_IEEE1588=n
122 CONFIG_RTE_ETHDEV_QUEUE_STAT_CNTRS=16
123 CONFIG_RTE_ETHDEV_RXTX_CALLBACKS=y
126 # Turn off Tx preparation stage
128 # Warning: rte_ethdev_tx_prepare() can be safely disabled only if using a
129 # driver which do not implement any Tx preparation.
131 CONFIG_RTE_ETHDEV_TX_PREPARE_NOOP=n
134 # Support NIC bypass logic
136 CONFIG_RTE_NIC_BYPASS=n
139 # Compile burst-oriented Amazon ENA PMD driver
141 CONFIG_RTE_LIBRTE_ENA_PMD=y
142 CONFIG_RTE_LIBRTE_ENA_DEBUG_RX=n
143 CONFIG_RTE_LIBRTE_ENA_DEBUG_TX=n
144 CONFIG_RTE_LIBRTE_ENA_DEBUG_TX_FREE=n
145 CONFIG_RTE_LIBRTE_ENA_DEBUG_DRIVER=n
146 CONFIG_RTE_LIBRTE_ENA_COM_DEBUG=n
149 # Compile burst-oriented IGB & EM PMD drivers
151 CONFIG_RTE_LIBRTE_EM_PMD=y
152 CONFIG_RTE_LIBRTE_IGB_PMD=y
153 CONFIG_RTE_LIBRTE_E1000_DEBUG_INIT=n
154 CONFIG_RTE_LIBRTE_E1000_DEBUG_RX=n
155 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX=n
156 CONFIG_RTE_LIBRTE_E1000_DEBUG_TX_FREE=n
157 CONFIG_RTE_LIBRTE_E1000_DEBUG_DRIVER=n
158 CONFIG_RTE_LIBRTE_E1000_PF_DISABLE_STRIP_CRC=n
161 # Compile burst-oriented IXGBE PMD driver
163 CONFIG_RTE_LIBRTE_IXGBE_PMD=y
164 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_INIT=n
165 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_RX=n
166 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX=n
167 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_TX_FREE=n
168 CONFIG_RTE_LIBRTE_IXGBE_DEBUG_DRIVER=n
169 CONFIG_RTE_LIBRTE_IXGBE_PF_DISABLE_STRIP_CRC=n
170 CONFIG_RTE_IXGBE_INC_VECTOR=y
171 CONFIG_RTE_IXGBE_RX_OLFLAGS_ENABLE=y
174 # Compile burst-oriented I40E PMD driver
176 CONFIG_RTE_LIBRTE_I40E_PMD=y
177 CONFIG_RTE_LIBRTE_I40E_DEBUG_INIT=n
178 CONFIG_RTE_LIBRTE_I40E_DEBUG_RX=n
179 CONFIG_RTE_LIBRTE_I40E_DEBUG_TX=n
180 CONFIG_RTE_LIBRTE_I40E_DEBUG_TX_FREE=n
181 CONFIG_RTE_LIBRTE_I40E_DEBUG_DRIVER=n
182 CONFIG_RTE_LIBRTE_I40E_RX_ALLOW_BULK_ALLOC=y
183 CONFIG_RTE_LIBRTE_I40E_INC_VECTOR=y
184 CONFIG_RTE_LIBRTE_I40E_RX_OLFLAGS_ENABLE=y
185 CONFIG_RTE_LIBRTE_I40E_16BYTE_RX_DESC=n
186 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_PF=64
187 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_VF=4
188 CONFIG_RTE_LIBRTE_I40E_QUEUE_NUM_PER_VM=4
189 # interval up to 8160 us, aligned to 2 (or default value)
190 CONFIG_RTE_LIBRTE_I40E_ITR_INTERVAL=-1
193 # Compile burst-oriented FM10K PMD
195 CONFIG_RTE_LIBRTE_FM10K_PMD=y
196 CONFIG_RTE_LIBRTE_FM10K_DEBUG_INIT=n
197 CONFIG_RTE_LIBRTE_FM10K_DEBUG_RX=n
198 CONFIG_RTE_LIBRTE_FM10K_DEBUG_TX=n
199 CONFIG_RTE_LIBRTE_FM10K_DEBUG_TX_FREE=n
200 CONFIG_RTE_LIBRTE_FM10K_DEBUG_DRIVER=n
201 CONFIG_RTE_LIBRTE_FM10K_RX_OLFLAGS_ENABLE=y
202 CONFIG_RTE_LIBRTE_FM10K_INC_VECTOR=y
205 # Compile burst-oriented Mellanox ConnectX-3 (MLX4) PMD
207 CONFIG_RTE_LIBRTE_MLX4_PMD=n
208 CONFIG_RTE_LIBRTE_MLX4_DEBUG=n
209 CONFIG_RTE_LIBRTE_MLX4_SGE_WR_N=4
210 CONFIG_RTE_LIBRTE_MLX4_MAX_INLINE=0
211 CONFIG_RTE_LIBRTE_MLX4_TX_MP_CACHE=8
212 CONFIG_RTE_LIBRTE_MLX4_SOFT_COUNTERS=1
215 # Compile burst-oriented Mellanox ConnectX-4 (MLX5) PMD
217 CONFIG_RTE_LIBRTE_MLX5_PMD=n
218 CONFIG_RTE_LIBRTE_MLX5_DEBUG=n
219 CONFIG_RTE_LIBRTE_MLX5_TX_MP_CACHE=8
222 # Compile burst-oriented Broadcom PMD driver
224 CONFIG_RTE_LIBRTE_BNX2X_PMD=n
225 CONFIG_RTE_LIBRTE_BNX2X_DEBUG=n
226 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_INIT=n
227 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_RX=n
228 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_TX=n
229 CONFIG_RTE_LIBRTE_BNX2X_MF_SUPPORT=n
230 CONFIG_RTE_LIBRTE_BNX2X_DEBUG_PERIODIC=n
233 # Compile burst-oriented Chelsio Terminator 10GbE/40GbE (CXGBE) PMD
235 CONFIG_RTE_LIBRTE_CXGBE_PMD=y
236 CONFIG_RTE_LIBRTE_CXGBE_DEBUG=n
237 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_REG=n
238 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_MBOX=n
239 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_TX=n
240 CONFIG_RTE_LIBRTE_CXGBE_DEBUG_RX=n
243 # Compile burst-oriented Cisco ENIC PMD driver
245 CONFIG_RTE_LIBRTE_ENIC_PMD=y
246 CONFIG_RTE_LIBRTE_ENIC_DEBUG=n
249 # Compile burst-oriented Netronome NFP PMD driver
251 CONFIG_RTE_LIBRTE_NFP_PMD=n
252 CONFIG_RTE_LIBRTE_NFP_DEBUG=n
255 # Compile burst-oriented Broadcom BNXT PMD driver
257 CONFIG_RTE_LIBRTE_BNXT_PMD=y
260 # Compile burst-oriented Solarflare libefx-based PMD
262 CONFIG_RTE_LIBRTE_SFC_EFX_PMD=y
263 CONFIG_RTE_LIBRTE_SFC_EFX_DEBUG=n
266 # Compile software PMD backed by SZEDATA2 device
268 CONFIG_RTE_LIBRTE_PMD_SZEDATA2=n
270 # Defines firmware type address space.
271 # RTE_LIBRTE_PMD_SZEDATA2_AS can be:
276 # Other values raise compile time error
277 CONFIG_RTE_LIBRTE_PMD_SZEDATA2_AS=0
280 # Compile burst-oriented Cavium Thunderx NICVF PMD driver
282 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_PMD=n
283 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_DEBUG_INIT=n
284 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_DEBUG_RX=n
285 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_DEBUG_TX=n
286 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_DEBUG_DRIVER=n
287 CONFIG_RTE_LIBRTE_THUNDERX_NICVF_DEBUG_MBOX=n
290 # Compile burst-oriented VIRTIO PMD driver
292 CONFIG_RTE_LIBRTE_VIRTIO_PMD=y
293 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_INIT=n
294 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_RX=n
295 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_TX=n
296 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DRIVER=n
297 CONFIG_RTE_LIBRTE_VIRTIO_DEBUG_DUMP=n
300 # Compile virtio device emulation inside virtio PMD driver
302 CONFIG_RTE_VIRTIO_USER=n
305 # Compile burst-oriented VMXNET3 PMD driver
307 CONFIG_RTE_LIBRTE_VMXNET3_PMD=y
308 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_INIT=n
309 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_RX=n
310 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX=n
311 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_TX_FREE=n
312 CONFIG_RTE_LIBRTE_VMXNET3_DEBUG_DRIVER=n
315 # Compile example software rings based PMD
317 CONFIG_RTE_LIBRTE_PMD_RING=y
318 CONFIG_RTE_PMD_RING_MAX_RX_RINGS=16
319 CONFIG_RTE_PMD_RING_MAX_TX_RINGS=16
322 # Compile software PMD backed by PCAP files
324 CONFIG_RTE_LIBRTE_PMD_PCAP=n
327 # Compile link bonding PMD library
329 CONFIG_RTE_LIBRTE_PMD_BOND=y
330 CONFIG_RTE_LIBRTE_BOND_DEBUG_ALB=n
331 CONFIG_RTE_LIBRTE_BOND_DEBUG_ALB_L1=n
333 # QLogic 10G/25G/40G/100G PMD
335 CONFIG_RTE_LIBRTE_QEDE_PMD=y
336 CONFIG_RTE_LIBRTE_QEDE_DEBUG_INIT=n
337 CONFIG_RTE_LIBRTE_QEDE_DEBUG_INFO=n
338 CONFIG_RTE_LIBRTE_QEDE_DEBUG_DRIVER=n
339 CONFIG_RTE_LIBRTE_QEDE_DEBUG_TX=n
340 CONFIG_RTE_LIBRTE_QEDE_DEBUG_RX=n
341 #Provides abs path/name of the firmware file.
342 #Empty string denotes driver will use default firmware
343 CONFIG_RTE_LIBRTE_QEDE_FW=""
346 # Compile software PMD backed by AF_PACKET sockets (Linux only)
348 CONFIG_RTE_LIBRTE_PMD_AF_PACKET=n
351 # Compile the TAP PMD
352 # It is enabled by default for Linux only.
354 CONFIG_RTE_LIBRTE_PMD_TAP=n
359 CONFIG_RTE_LIBRTE_PMD_XENVIRT=n
364 CONFIG_RTE_LIBRTE_PMD_NULL=y
367 # Do prefetch of packet data within PMD driver receive function
369 CONFIG_RTE_PMD_PACKET_PREFETCH=y
372 # Compile generic crypto device library
374 CONFIG_RTE_LIBRTE_CRYPTODEV=y
375 CONFIG_RTE_LIBRTE_CRYPTODEV_DEBUG=n
376 CONFIG_RTE_CRYPTO_MAX_DEVS=64
377 CONFIG_RTE_CRYPTODEV_NAME_LEN=64
380 # Compile PMD for QuickAssist based devices
382 CONFIG_RTE_LIBRTE_PMD_QAT=n
383 CONFIG_RTE_LIBRTE_PMD_QAT_DEBUG_INIT=n
384 CONFIG_RTE_LIBRTE_PMD_QAT_DEBUG_TX=n
385 CONFIG_RTE_LIBRTE_PMD_QAT_DEBUG_RX=n
386 CONFIG_RTE_LIBRTE_PMD_QAT_DEBUG_DRIVER=n
388 # Number of sessions to create in the session memory pool
389 # on a single QuickAssist device.
391 CONFIG_RTE_QAT_PMD_MAX_NB_SESSIONS=2048
394 # Compile PMD for AESNI backed device
396 CONFIG_RTE_LIBRTE_PMD_AESNI_MB=n
397 CONFIG_RTE_LIBRTE_PMD_AESNI_MB_DEBUG=n
400 # Compile PMD for Software backed device
402 CONFIG_RTE_LIBRTE_PMD_OPENSSL=n
403 CONFIG_RTE_LIBRTE_PMD_OPENSSL_DEBUG=n
406 # Compile PMD for AESNI GCM device
408 CONFIG_RTE_LIBRTE_PMD_AESNI_GCM=n
409 CONFIG_RTE_LIBRTE_PMD_AESNI_GCM_DEBUG=n
412 # Compile PMD for SNOW 3G device
414 CONFIG_RTE_LIBRTE_PMD_SNOW3G=n
415 CONFIG_RTE_LIBRTE_PMD_SNOW3G_DEBUG=n
418 # Compile PMD for KASUMI device
420 CONFIG_RTE_LIBRTE_PMD_KASUMI=n
421 CONFIG_RTE_LIBRTE_PMD_KASUMI_DEBUG=n
424 # Compile PMD for ZUC device
426 CONFIG_RTE_LIBRTE_PMD_ZUC=n
427 CONFIG_RTE_LIBRTE_PMD_ZUC_DEBUG=n
430 # Compile PMD for NULL Crypto device
432 CONFIG_RTE_LIBRTE_PMD_NULL_CRYPTO=y
435 # Compile librte_ring
437 CONFIG_RTE_LIBRTE_RING=y
438 CONFIG_RTE_LIBRTE_RING_DEBUG=n
439 CONFIG_RTE_RING_SPLIT_PROD_CONS=n
440 CONFIG_RTE_RING_PAUSE_REP_COUNT=0
443 # Compile librte_mempool
445 CONFIG_RTE_LIBRTE_MEMPOOL=y
446 CONFIG_RTE_MEMPOOL_CACHE_MAX_SIZE=512
447 CONFIG_RTE_LIBRTE_MEMPOOL_DEBUG=n
450 # Compile librte_mbuf
452 CONFIG_RTE_LIBRTE_MBUF=y
453 CONFIG_RTE_LIBRTE_MBUF_DEBUG=n
454 CONFIG_RTE_MBUF_DEFAULT_MEMPOOL_OPS="ring_mp_mc"
455 CONFIG_RTE_MBUF_REFCNT_ATOMIC=y
456 CONFIG_RTE_PKTMBUF_HEADROOM=128
459 # Compile librte_timer
461 CONFIG_RTE_LIBRTE_TIMER=y
462 CONFIG_RTE_LIBRTE_TIMER_DEBUG=n
465 # Compile librte_cfgfile
467 CONFIG_RTE_LIBRTE_CFGFILE=y
470 # Compile librte_cmdline
472 CONFIG_RTE_LIBRTE_CMDLINE=y
473 CONFIG_RTE_LIBRTE_CMDLINE_DEBUG=n
476 # Compile librte_hash
478 CONFIG_RTE_LIBRTE_HASH=y
479 CONFIG_RTE_LIBRTE_HASH_DEBUG=n
482 # Compile librte_jobstats
484 CONFIG_RTE_LIBRTE_JOBSTATS=y
489 CONFIG_RTE_LIBRTE_LPM=y
490 CONFIG_RTE_LIBRTE_LPM_DEBUG=n
495 CONFIG_RTE_LIBRTE_ACL=y
496 CONFIG_RTE_LIBRTE_ACL_DEBUG=n
499 # Compile librte_power
501 CONFIG_RTE_LIBRTE_POWER=n
502 CONFIG_RTE_LIBRTE_POWER_DEBUG=n
503 CONFIG_RTE_MAX_LCORE_FREQS=64
508 CONFIG_RTE_LIBRTE_NET=y
511 # Compile librte_ip_frag
513 CONFIG_RTE_LIBRTE_IP_FRAG=y
514 CONFIG_RTE_LIBRTE_IP_FRAG_DEBUG=n
515 CONFIG_RTE_LIBRTE_IP_FRAG_MAX_FRAG=4
516 CONFIG_RTE_LIBRTE_IP_FRAG_TBL_STAT=n
519 # Compile librte_meter
521 CONFIG_RTE_LIBRTE_METER=y
524 # Compile librte_sched
526 CONFIG_RTE_LIBRTE_SCHED=y
527 CONFIG_RTE_SCHED_DEBUG=n
528 CONFIG_RTE_SCHED_RED=n
529 CONFIG_RTE_SCHED_COLLECT_STATS=n
530 CONFIG_RTE_SCHED_SUBPORT_TC_OV=n
531 CONFIG_RTE_SCHED_PORT_N_GRINDERS=8
532 CONFIG_RTE_SCHED_VECTOR=n
535 # Compile the distributor library
537 CONFIG_RTE_LIBRTE_DISTRIBUTOR=y
540 # Compile the reorder library
542 CONFIG_RTE_LIBRTE_REORDER=y
545 # Compile librte_port
547 CONFIG_RTE_LIBRTE_PORT=y
548 CONFIG_RTE_PORT_STATS_COLLECT=n
549 CONFIG_RTE_PORT_PCAP=n
552 # Compile librte_table
554 CONFIG_RTE_LIBRTE_TABLE=y
555 CONFIG_RTE_TABLE_STATS_COLLECT=n
558 # Compile librte_pipeline
560 CONFIG_RTE_LIBRTE_PIPELINE=y
561 CONFIG_RTE_PIPELINE_STATS_COLLECT=n
566 CONFIG_RTE_LIBRTE_KNI=n
567 CONFIG_RTE_KNI_KMOD=n
568 CONFIG_RTE_KNI_PREEMPT_DEFAULT=y
569 CONFIG_RTE_KNI_VHOST=n
570 CONFIG_RTE_KNI_VHOST_MAX_CACHE_SIZE=1024
571 CONFIG_RTE_KNI_VHOST_VNET_HDR_EN=n
574 # Compile the pdump library
576 CONFIG_RTE_LIBRTE_PDUMP=y
579 # Compile vhost user library
581 CONFIG_RTE_LIBRTE_VHOST=n
582 CONFIG_RTE_LIBRTE_VHOST_NUMA=n
583 CONFIG_RTE_LIBRTE_VHOST_DEBUG=n
587 # To compile, CONFIG_RTE_LIBRTE_VHOST should be enabled.
589 CONFIG_RTE_LIBRTE_PMD_VHOST=n
592 #Compile Xen domain0 support
594 CONFIG_RTE_LIBRTE_XEN_DOM0=n
597 # Compile the test application
599 CONFIG_RTE_APP_TEST=y
600 CONFIG_RTE_APP_TEST_RESOURCE_TAR=n
603 # Compile the PMD test application
605 CONFIG_RTE_TEST_PMD=y
606 CONFIG_RTE_TEST_PMD_RECORD_CORE_CYCLES=n
607 CONFIG_RTE_TEST_PMD_RECORD_BURST_STATS=n