net/bnxt: fix FW version query
[dpdk.git] / drivers / net / ixgbe / Makefile
1 # SPDX-License-Identifier: BSD-3-Clause
2 # Copyright(c) 2010-2016 Intel Corporation
3
4 include $(RTE_SDK)/mk/rte.vars.mk
5
6 #
7 # library name
8 #
9 LIB = librte_pmd_ixgbe.a
10
11 CFLAGS += -O3
12 CFLAGS += $(WERROR_FLAGS)
13
14 EXPORT_MAP := rte_pmd_ixgbe_version.map
15
16 ifeq ($(CONFIG_RTE_TOOLCHAIN_ICC),y)
17 #
18 # CFLAGS for icc
19 #
20 CFLAGS_BASE_DRIVER  = -diag-disable 174 -diag-disable 593 -diag-disable 869
21 CFLAGS_BASE_DRIVER += -diag-disable 981 -diag-disable 2259
22
23 CFLAGS_ixgbe_rxtx.o += -diag-disable 3656
24
25 else ifeq ($(CONFIG_RTE_TOOLCHAIN_CLANG),y)
26 #
27 # CFLAGS for clang
28 #
29 CFLAGS_BASE_DRIVER = -Wno-unused-parameter -Wno-unused-value
30 CFLAGS_BASE_DRIVER += -Wno-strict-aliasing -Wno-format-extra-args
31
32 else
33 #
34 # CFLAGS for gcc
35 #
36 ifeq ($(shell test $(GCC_VERSION) -ge 44 && echo 1), 1)
37 CFLAGS     += -Wno-deprecated
38 CFLAGS_ixgbe_common.o += -Wno-unused-but-set-variable
39 CFLAGS_ixgbe_x550.o += -Wno-unused-but-set-variable
40 endif
41 CFLAGS_BASE_DRIVER = -Wno-unused-parameter -Wno-unused-value
42 CFLAGS_BASE_DRIVER += -Wno-strict-aliasing -Wno-format-extra-args
43
44 ifeq ($(shell test $(GCC_VERSION) -ge 46 && echo 1), 1)
45 CFLAGS_ixgbe_x550.o += -Wno-maybe-uninitialized
46 endif
47
48 ifeq ($(shell test $(GCC_VERSION) -ge 50 && echo 1), 1)
49 CFLAGS_ixgbe_common.o += -Wno-logical-not-parentheses
50 ifeq ($(shell test $(GCC_VERSION) -ge 70 && echo 1), 1)
51 CFLAGS_BASE_DRIVER += -Wno-implicit-fallthrough
52 endif
53 endif
54
55 endif
56 LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring
57 LDLIBS += -lrte_ethdev -lrte_net -lrte_kvargs -lrte_hash
58 LDLIBS += -lrte_bus_pci
59 LDLIBS += -lpthread
60
61 #
62 # Add extra flags for base driver files (also known as shared code)
63 # to disable warnings in them
64 #
65 BASE_DRIVER_OBJS=$(sort $(patsubst %.c,%.o,$(notdir $(wildcard $(SRCDIR)/base/*.c))))
66 $(foreach obj, $(BASE_DRIVER_OBJS), $(eval CFLAGS_$(obj)+=$(CFLAGS_BASE_DRIVER)))
67
68 VPATH += $(SRCDIR)/base
69
70 #
71 # all source are stored in SRCS-y
72 #
73 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_common.c
74 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_82598.c
75 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_82599.c
76 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_x540.c
77 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_x550.c
78 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_phy.c
79 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_api.c
80 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_vf.c
81 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_hv_vf.c
82 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_dcb.c
83 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_dcb_82599.c
84 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_dcb_82598.c
85 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_mbx.c
86 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_rxtx.c
87 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_ethdev.c
88 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_fdir.c
89 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_pf.c
90 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_flow.c
91 ifeq ($(CONFIG_RTE_ARCH_ARM64),y)
92 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_rxtx_vec_neon.c
93 else ifeq ($(CONFIG_RTE_ARCH_X86),y)
94 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_rxtx_vec_sse.c
95 endif
96 ifeq ($(CONFIG_RTE_LIBRTE_IXGBE_BYPASS),y)
97 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_bypass.c
98 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_82599_bypass.c
99 endif
100 ifeq ($(CONFIG_RTE_LIBRTE_SECURITY),y)
101 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_ipsec.c
102 endif
103 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += rte_pmd_ixgbe.c
104 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_tm.c
105 SRCS-$(CONFIG_RTE_LIBRTE_IXGBE_PMD) += ixgbe_vf_representor.c
106
107 # install this header file
108 SYMLINK-$(CONFIG_RTE_LIBRTE_IXGBE_PMD)-include := rte_pmd_ixgbe.h
109
110 include $(RTE_SDK)/mk/rte.lib.mk