1 # SPDX-License-Identifier: BSD-3-Clause
3 # Copyright(c) 2019-2020 Xilinx, Inc.
4 # Copyright(c) 2016-2019 Solarflare Communications Inc.
6 # This software was jointly developed between OKTET Labs (under contract
7 # for Solarflare) and Solarflare Communications, Inc.
9 include $(RTE_SDK
)/mk
/rte.vars.mk
14 LIB
= librte_pmd_sfc_efx.a
16 CFLAGS
+= -I
$(SRCDIR
)/base
/
19 CFLAGS
+= $(WERROR_FLAGS
)
20 # Strict-aliasing rules are violated by rte_eth_link to uint64_t casts
21 CFLAGS
+= -Wno-strict-aliasing
23 # Enable extra warnings
26 # More warnings not enabled by above aggregators
27 CFLAGS
+= -Wdisabled-optimization
29 # Extra CFLAGS for base driver files
30 CFLAGS_BASE_DRIVER
+= -Wno-sign-compare
31 CFLAGS_BASE_DRIVER
+= -Wno-unused-parameter
32 CFLAGS_BASE_DRIVER
+= -Wno-unused-variable
34 # Compiler and version dependent flags
35 ifeq ($(CONFIG_RTE_TOOLCHAIN_GCC
),y
)
36 CFLAGS
+= -Waggregate-return
37 CFLAGS
+= -Wnested-externs
38 CFLAGS_BASE_DRIVER
+= -Wno-empty-body
39 CFLAGS_BASE_DRIVER
+= -Wno-unused-but-set-variable
40 else ifeq ($(CONFIG_RTE_TOOLCHAIN_CLANG
),y
)
41 CFLAGS
+= -Waggregate-return
42 CFLAGS
+= -Wbad-function-cast
43 CFLAGS_BASE_DRIVER
+= -Wno-empty-body
44 else ifeq ($(CONFIG_RTE_TOOLCHAIN_ICC
),y
)
45 CFLAGS_BASE_DRIVER
+= -Wno-unused-but-set-variable
46 # Suppress ICC false positive warning on 'bulk' may be used before its
48 CFLAGS_sfc_ef10_tx.o
+= -diag-disable
3656
50 LDLIBS
+= -lrte_eal
-lrte_mbuf
-lrte_mempool
-lrte_ring
51 LDLIBS
+= -lrte_ethdev
-lrte_net
-lrte_kvargs
52 LDLIBS
+= -lrte_bus_pci
-lrte_pci
55 # List of base driver object files for which
56 # special CFLAGS above should be applied
58 BASE_DRIVER_OBJS
=$(sort $(patsubst %.c
,%.o
,$(notdir $(wildcard $(SRCDIR
)/base
/*.c
))))
59 $(foreach obj
, $(BASE_DRIVER_OBJS
), \
60 $(eval CFLAGS_
$(obj
)+=$(CFLAGS_BASE_DRIVER
)))
62 EXPORT_MAP
:= rte_pmd_sfc_version.map
65 # all source are stored in SRCS-y
67 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_ethdev.c
68 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_kvargs.c
69 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc.c
70 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_mcdi.c
71 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_intr.c
72 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_ev.c
73 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_port.c
74 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_rx.c
75 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_tx.c
76 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_tso.c
77 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_filter.c
78 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_flow.c
79 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_dp.c
80 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_ef10_rx.c
81 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_ef10_essb_rx.c
82 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += sfc_ef10_tx.c
84 VPATH
+= $(SRCDIR
)/base
86 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_bootcfg.c
87 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_crc32.c
88 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_ev.c
89 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_evb.c
90 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_filter.c
91 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_hash.c
92 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_intr.c
93 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_lic.c
94 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_mac.c
95 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_mcdi.c
96 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_mon.c
97 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_nic.c
98 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_nvram.c
99 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_phy.c
100 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_port.c
101 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_proxy.c
102 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_rx.c
103 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_sram.c
104 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_tunnel.c
105 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_tx.c
106 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += efx_vpd.c
107 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += mcdi_mon.c
108 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_mac.c
109 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_mcdi.c
110 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_nic.c
111 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_nvram.c
112 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_phy.c
113 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_sram.c
114 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += siena_vpd.c
115 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_ev.c
116 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_evb.c
117 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_filter.c
118 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_intr.c
119 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_image.c
120 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_mac.c
121 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_mcdi.c
122 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_nic.c
123 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_nvram.c
124 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_phy.c
125 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_proxy.c
126 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_rx.c
127 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_tx.c
128 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += ef10_vpd.c
129 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += hunt_nic.c
130 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += medford_nic.c
131 SRCS-
$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD
) += medford2_nic.c
133 include $(RTE_SDK
)/mk
/rte.lib.mk