net/sfc: support equal stride super-buffer Rx mode
[dpdk.git] / drivers / net / sfc / Makefile
1 # SPDX-License-Identifier: BSD-3-Clause
2 #
3 # Copyright (c) 2016-2018 Solarflare Communications Inc.
4 # All rights reserved.
5 #
6 # This software was jointly developed between OKTET Labs (under contract
7 # for Solarflare) and Solarflare Communications, Inc.
8
9 include $(RTE_SDK)/mk/rte.vars.mk
10
11 #
12 # library name
13 #
14 LIB = librte_pmd_sfc_efx.a
15
16 CFLAGS += -DALLOW_EXPERIMENTAL_API
17 CFLAGS += -I$(SRCDIR)/base/
18 CFLAGS += -I$(SRCDIR)
19 CFLAGS += -O3
20 CFLAGS += $(WERROR_FLAGS)
21 # Strict-aliasing rules are violated by rte_eth_link to uint64_t casts
22 CFLAGS += -Wno-strict-aliasing
23
24 # Enable extra warnings
25 CFLAGS += -Wextra
26
27 # More warnings not enabled by above aggregators
28 CFLAGS += -Wdisabled-optimization
29
30 # Extra CFLAGS for base driver files
31 CFLAGS_BASE_DRIVER += -Wno-sign-compare
32 CFLAGS_BASE_DRIVER += -Wno-unused-parameter
33 CFLAGS_BASE_DRIVER += -Wno-unused-variable
34
35 # Compiler and version dependent flags
36 ifeq ($(CONFIG_RTE_TOOLCHAIN_GCC),y)
37 CFLAGS += -Waggregate-return
38 CFLAGS += -Wnested-externs
39 CFLAGS_BASE_DRIVER += -Wno-empty-body
40 CFLAGS_BASE_DRIVER += -Wno-unused-but-set-variable
41 else ifeq ($(CONFIG_RTE_TOOLCHAIN_CLANG),y)
42 CFLAGS += -Waggregate-return
43 CFLAGS += -Wbad-function-cast
44 CFLAGS_BASE_DRIVER += -Wno-empty-body
45 else ifeq ($(CONFIG_RTE_TOOLCHAIN_ICC),y)
46 CFLAGS_BASE_DRIVER += -Wno-unused-but-set-variable
47 # Suppress ICC false positive warning on 'bulk' may be used before its
48 # value is set
49 CFLAGS_sfc_ef10_tx.o += -diag-disable 3656
50 endif
51 LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring
52 LDLIBS += -lrte_ethdev -lrte_net -lrte_kvargs
53 LDLIBS += -lrte_bus_pci -lrte_pci
54
55 #
56 # List of base driver object files for which
57 # special CFLAGS above should be applied
58 #
59 BASE_DRIVER_OBJS=$(sort $(patsubst %.c,%.o,$(notdir $(wildcard $(SRCDIR)/base/*.c))))
60 $(foreach obj, $(BASE_DRIVER_OBJS), \
61   $(eval CFLAGS_$(obj)+=$(CFLAGS_BASE_DRIVER)))
62
63 EXPORT_MAP := rte_pmd_sfc_version.map
64
65 LIBABIVER := 1
66
67 #
68 # all source are stored in SRCS-y
69 #
70 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_ethdev.c
71 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_kvargs.c
72 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc.c
73 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_mcdi.c
74 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_intr.c
75 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_ev.c
76 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_port.c
77 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_rx.c
78 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_tx.c
79 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_tso.c
80 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_filter.c
81 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_flow.c
82 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_dp.c
83 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_ef10_rx.c
84 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_ef10_essb_rx.c
85 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += sfc_ef10_tx.c
86
87 VPATH += $(SRCDIR)/base
88
89 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_bootcfg.c
90 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_crc32.c
91 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_ev.c
92 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_filter.c
93 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_hash.c
94 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_intr.c
95 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_lic.c
96 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_mac.c
97 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_mcdi.c
98 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_mon.c
99 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_nic.c
100 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_nvram.c
101 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_phy.c
102 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_port.c
103 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_rx.c
104 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_sram.c
105 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_tunnel.c
106 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_tx.c
107 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += efx_vpd.c
108 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += mcdi_mon.c
109 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_mac.c
110 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_mcdi.c
111 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_nic.c
112 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_nvram.c
113 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_phy.c
114 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_sram.c
115 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += siena_vpd.c
116 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += ef10_ev.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_rx.c
126 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += ef10_tx.c
127 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += ef10_vpd.c
128 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += hunt_nic.c
129 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += medford_nic.c
130 SRCS-$(CONFIG_RTE_LIBRTE_SFC_EFX_PMD) += medford2_nic.c
131
132 include $(RTE_SDK)/mk/rte.lib.mk