8549295db0
Rather than setting -Bstatic in the linker flags when doing a static link, and then having to explicitly set -Bdynamic again afterwards, we can update the pkg-config file to use -l:libfoo.a syntax to explicitly refer to the static library in question. Since this syntax is not supported by meson's pkg-config module directly, we can post-process the .pc files instead to adjust them. Once done, we can simplify the examples' makefiles and the docs by removing the explicit static flag. Signed-off-by: Bruce Richardson <bruce.richardson@intel.com> Acked-by: Luca Boccassi <bluca@debian.org> Acked-by: Sunil Pai G <sunil.pai.g@intel.com> Signed-off-by: Thomas Monjalon <thomas@monjalon.net>
74 lines
1.9 KiB
Makefile
74 lines
1.9 KiB
Makefile
# SPDX-License-Identifier: BSD-3-Clause
|
|
# Copyright(c) 2010-2018 Intel Corporation
|
|
|
|
# binary name
|
|
APP = l3fwd-power
|
|
|
|
# all source are stored in SRCS-y
|
|
SRCS-y := main.c perf_core.c
|
|
|
|
# Build using pkg-config variables if possible
|
|
ifeq ($(shell pkg-config --exists libdpdk && echo 0),0)
|
|
|
|
all: shared
|
|
.PHONY: shared static
|
|
shared: build/$(APP)-shared
|
|
ln -sf $(APP)-shared build/$(APP)
|
|
static: build/$(APP)-static
|
|
ln -sf $(APP)-static build/$(APP)
|
|
|
|
PKGCONF ?= pkg-config
|
|
|
|
PC_FILE := $(shell $(PKGCONF) --path libdpdk 2>/dev/null)
|
|
CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
|
|
LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
|
|
LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
|
|
|
|
CFLAGS += -DALLOW_EXPERIMENTAL_API
|
|
|
|
build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
|
|
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
|
|
|
|
build/$(APP)-static: $(SRCS-y) Makefile $(PC_FILE) | build
|
|
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_STATIC)
|
|
|
|
build:
|
|
@mkdir -p $@
|
|
|
|
.PHONY: clean
|
|
clean:
|
|
rm -f build/$(APP) build/$(APP)-static build/$(APP)-shared
|
|
test -d build && rmdir -p build || true
|
|
|
|
else # Build using legacy build system
|
|
|
|
ifeq ($(RTE_SDK),)
|
|
$(error "Please define RTE_SDK environment variable")
|
|
endif
|
|
|
|
# Default target, detect a build directory, by looking for a path with a .config
|
|
RTE_TARGET ?= $(notdir $(abspath $(dir $(firstword $(wildcard $(RTE_SDK)/*/.config)))))
|
|
|
|
include $(RTE_SDK)/mk/rte.vars.mk
|
|
|
|
ifneq ($(CONFIG_RTE_EXEC_ENV_LINUX),y)
|
|
$(info This application can only operate in a linux environment, \
|
|
please change the definition of the RTE_TARGET environment variable)
|
|
all:
|
|
else
|
|
|
|
CFLAGS += -DALLOW_EXPERIMENTAL_API
|
|
CFLAGS += -O3
|
|
CFLAGS += $(WERROR_FLAGS)
|
|
LDLIBS += -lm -lrte_telemetry
|
|
|
|
# workaround for a gcc bug with noreturn attribute
|
|
# http://gcc.gnu.org/bugzilla/show_bug.cgi?id=12603
|
|
ifeq ($(CONFIG_RTE_TOOLCHAIN_GCC),y)
|
|
CFLAGS_main.o += -Wno-return-type
|
|
endif
|
|
|
|
include $(RTE_SDK)/mk/rte.extapp.mk
|
|
endif
|
|
endif
|