2017-12-19 15:49:02 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright(c) 2016-2017 Intel Corporation
|
examples/eventdev_pipeline_sw_pmd: add sample app
This commit adds a sample app for the eventdev library.
The app has been tested with DPDK 17.05-rc2, hence this
release (or later) is recommended.
The sample app showcases a pipeline processing use-case,
with event scheduling and processing defined per stage.
The application receives traffic as normal, with each
packet traversing the pipeline. Once the packet has
been processed by each of the pipeline stages, it is
transmitted again.
The app provides a framework to utilize cores for a single
role or multiple roles. Examples of roles are the RX core,
TX core, Scheduling core (in the case of the event/sw PMD),
and worker cores.
Various flags are available to configure numbers of stages,
cycles of work at each stage, type of scheduling, number of
worker cores, queue depths etc. For a full explaination,
please refer to the documentation.
Signed-off-by: Gage Eads <gage.eads@intel.com>
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
Signed-off-by: Harry van Haaren <harry.van.haaren@intel.com>
Signed-off-by: David Hunt <david.hunt@intel.com>
Acked-by: Jerin Jacob <jerin.jacob@caviumnetworks.com>
2017-07-06 15:35:14 +01:00
|
|
|
|
2017-09-25 17:28:49 +01:00
|
|
|
# binary name
|
|
|
|
APP = eventdev_pipeline
|
|
|
|
|
|
|
|
# all source are stored in SRCS-y
|
|
|
|
SRCS-y := main.c
|
|
|
|
SRCS-y += pipeline_worker_generic.c
|
|
|
|
SRCS-y += pipeline_worker_tx.c
|
|
|
|
|
2017-10-09 14:13:16 +01:00
|
|
|
# Build using pkg-config variables if possible
|
|
|
|
$(shell pkg-config --exists libdpdk)
|
|
|
|
ifeq ($(.SHELLSTATUS),0)
|
|
|
|
|
2017-12-07 15:51:41 +00:00
|
|
|
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)
|
|
|
|
|
2017-10-09 14:13:16 +01:00
|
|
|
PC_FILE := $(shell pkg-config --path libdpdk)
|
2017-12-07 15:51:41 +00:00
|
|
|
CFLAGS += -O3 $(shell pkg-config --cflags libdpdk)
|
|
|
|
LDFLAGS_SHARED = $(shell pkg-config --libs libdpdk)
|
|
|
|
LDFLAGS_STATIC = -Wl,-Bstatic $(shell pkg-config --static --libs libdpdk)
|
2017-10-09 14:13:16 +01:00
|
|
|
|
|
|
|
CFLAGS += -DALLOW_EXPERIMENTAL_API
|
|
|
|
|
2017-12-07 15:51:41 +00:00
|
|
|
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)
|
2017-10-09 14:13:16 +01:00
|
|
|
|
|
|
|
build:
|
|
|
|
@mkdir -p $@
|
|
|
|
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2017-12-07 15:51:41 +00:00
|
|
|
rm -f build/$(APP) build/$(APP)-static build/$(APP)-shared
|
2017-10-09 14:13:16 +01:00
|
|
|
rmdir --ignore-fail-on-non-empty build
|
|
|
|
|
|
|
|
else
|
|
|
|
|
examples/eventdev_pipeline_sw_pmd: add sample app
This commit adds a sample app for the eventdev library.
The app has been tested with DPDK 17.05-rc2, hence this
release (or later) is recommended.
The sample app showcases a pipeline processing use-case,
with event scheduling and processing defined per stage.
The application receives traffic as normal, with each
packet traversing the pipeline. Once the packet has
been processed by each of the pipeline stages, it is
transmitted again.
The app provides a framework to utilize cores for a single
role or multiple roles. Examples of roles are the RX core,
TX core, Scheduling core (in the case of the event/sw PMD),
and worker cores.
Various flags are available to configure numbers of stages,
cycles of work at each stage, type of scheduling, number of
worker cores, queue depths etc. For a full explaination,
please refer to the documentation.
Signed-off-by: Gage Eads <gage.eads@intel.com>
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
Signed-off-by: Harry van Haaren <harry.van.haaren@intel.com>
Signed-off-by: David Hunt <david.hunt@intel.com>
Acked-by: Jerin Jacob <jerin.jacob@caviumnetworks.com>
2017-07-06 15:35:14 +01:00
|
|
|
ifeq ($(RTE_SDK),)
|
|
|
|
$(error "Please define RTE_SDK environment variable")
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Default target, can be overridden by command line or environment
|
|
|
|
RTE_TARGET ?= x86_64-native-linuxapp-gcc
|
|
|
|
|
|
|
|
include $(RTE_SDK)/mk/rte.vars.mk
|
|
|
|
|
2018-01-21 20:48:05 -05:00
|
|
|
CFLAGS += -DALLOW_EXPERIMENTAL_API
|
examples/eventdev_pipeline_sw_pmd: add sample app
This commit adds a sample app for the eventdev library.
The app has been tested with DPDK 17.05-rc2, hence this
release (or later) is recommended.
The sample app showcases a pipeline processing use-case,
with event scheduling and processing defined per stage.
The application receives traffic as normal, with each
packet traversing the pipeline. Once the packet has
been processed by each of the pipeline stages, it is
transmitted again.
The app provides a framework to utilize cores for a single
role or multiple roles. Examples of roles are the RX core,
TX core, Scheduling core (in the case of the event/sw PMD),
and worker cores.
Various flags are available to configure numbers of stages,
cycles of work at each stage, type of scheduling, number of
worker cores, queue depths etc. For a full explaination,
please refer to the documentation.
Signed-off-by: Gage Eads <gage.eads@intel.com>
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
Signed-off-by: Harry van Haaren <harry.van.haaren@intel.com>
Signed-off-by: David Hunt <david.hunt@intel.com>
Acked-by: Jerin Jacob <jerin.jacob@caviumnetworks.com>
2017-07-06 15:35:14 +01:00
|
|
|
CFLAGS += -O3
|
|
|
|
CFLAGS += $(WERROR_FLAGS)
|
|
|
|
|
|
|
|
include $(RTE_SDK)/mk/rte.extapp.mk
|
2017-10-09 14:13:16 +01:00
|
|
|
|
|
|
|
endif
|