diff options
Diffstat (limited to 'src/spdk/dpdk/drivers/common/mvep')
-rw-r--r-- | src/spdk/dpdk/drivers/common/mvep/Makefile | 35 | ||||
-rw-r--r-- | src/spdk/dpdk/drivers/common/mvep/meson.build | 20 | ||||
-rw-r--r-- | src/spdk/dpdk/drivers/common/mvep/mvep_common.c | 45 | ||||
-rw-r--r-- | src/spdk/dpdk/drivers/common/mvep/rte_common_mvep_version.map | 8 | ||||
-rw-r--r-- | src/spdk/dpdk/drivers/common/mvep/rte_mvep_common.h | 21 |
5 files changed, 129 insertions, 0 deletions
diff --git a/src/spdk/dpdk/drivers/common/mvep/Makefile b/src/spdk/dpdk/drivers/common/mvep/Makefile new file mode 100644 index 000000000..f91d295e5 --- /dev/null +++ b/src/spdk/dpdk/drivers/common/mvep/Makefile @@ -0,0 +1,35 @@ +# SPDX-License-Identifier: BSD-3-Clause +# Copyright(c) 2018 Marvell International Ltd. +# + +include $(RTE_SDK)/mk/rte.vars.mk + +ifneq ($(MAKECMDGOALS),clean) +ifneq ($(MAKECMDGOALS),config) +ifeq ($(LIBMUSDK_PATH),) +$(error "Please define LIBMUSDK_PATH environment variable") +endif +endif +endif + +# library name +LIB = librte_common_mvep.a + +# versioning export map +EXPORT_MAP := rte_common_mvep_version.map + +# external library dependencies +CFLAGS += -I$($RTE_SDK)/drivers/common/mvep +CFLAGS += -I$(LIBMUSDK_PATH)/include +CFLAGS += -DMVCONF_TYPES_PUBLIC +CFLAGS += -DMVCONF_DMA_PHYS_ADDR_T_PUBLIC +CFLAGS += $(WERROR_FLAGS) +CFLAGS += -O3 +LDLIBS += -L$(LIBMUSDK_PATH)/lib +LDLIBS += -lmusdk +LDLIBS += -lrte_eal -lrte_kvargs + +# library source files +SRCS-y += mvep_common.c + +include $(RTE_SDK)/mk/rte.lib.mk diff --git a/src/spdk/dpdk/drivers/common/mvep/meson.build b/src/spdk/dpdk/drivers/common/mvep/meson.build new file mode 100644 index 000000000..8df4bc6e0 --- /dev/null +++ b/src/spdk/dpdk/drivers/common/mvep/meson.build @@ -0,0 +1,20 @@ +# SPDX-License-Identifier: BSD-3-Clause +# Copyright(c) 2018 Marvell International Ltd. +# Copyright(c) 2018 Semihalf. +# All rights reserved. +# +path = get_option('lib_musdk_dir') +lib_dir = path + '/lib' +inc_dir = path + '/include' + +lib = cc.find_library('libmusdk', dirs: [lib_dir], required: false) +if not lib.found() + build = false + reason = 'missing dependency, "libmusdk"' +else + ext_deps += lib + includes += include_directories(inc_dir) + cflags += ['-DMVCONF_TYPES_PUBLIC', '-DMVCONF_DMA_PHYS_ADDR_T_PUBLIC'] +endif + +sources = files('mvep_common.c') diff --git a/src/spdk/dpdk/drivers/common/mvep/mvep_common.c b/src/spdk/dpdk/drivers/common/mvep/mvep_common.c new file mode 100644 index 000000000..67fa65b57 --- /dev/null +++ b/src/spdk/dpdk/drivers/common/mvep/mvep_common.c @@ -0,0 +1,45 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2018 Marvell International Ltd. + */ + +#include <rte_common.h> + +#include <env/mv_autogen_comp_flags.h> +#include <env/mv_sys_dma.h> + +#include "rte_mvep_common.h" + +/* Memory size (in bytes) for MUSDK dma buffers */ +#define MRVL_MUSDK_DMA_MEMSIZE (40 * 1024 * 1024) + +struct mvep { + uint32_t ref_count; +}; + +static struct mvep mvep; + +int rte_mvep_init(enum mvep_module_type module __rte_unused, + struct rte_kvargs *kvlist __rte_unused) +{ + int ret; + + if (!mvep.ref_count) { + ret = mv_sys_dma_mem_init(MRVL_MUSDK_DMA_MEMSIZE); + if (ret) + return ret; + } + + mvep.ref_count++; + + return 0; +} + +int rte_mvep_deinit(enum mvep_module_type module __rte_unused) +{ + mvep.ref_count--; + + if (!mvep.ref_count) + mv_sys_dma_mem_destroy(); + + return 0; +} diff --git a/src/spdk/dpdk/drivers/common/mvep/rte_common_mvep_version.map b/src/spdk/dpdk/drivers/common/mvep/rte_common_mvep_version.map new file mode 100644 index 000000000..030928439 --- /dev/null +++ b/src/spdk/dpdk/drivers/common/mvep/rte_common_mvep_version.map @@ -0,0 +1,8 @@ +DPDK_20.0 { + global: + + rte_mvep_deinit; + rte_mvep_init; + + local: *; +}; diff --git a/src/spdk/dpdk/drivers/common/mvep/rte_mvep_common.h b/src/spdk/dpdk/drivers/common/mvep/rte_mvep_common.h new file mode 100644 index 000000000..0593cefcd --- /dev/null +++ b/src/spdk/dpdk/drivers/common/mvep/rte_mvep_common.h @@ -0,0 +1,21 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2018 Marvell International Ltd. + */ + +#ifndef __RTE_MVEP_COMMON_H__ +#define __RTE_MVEP_COMMON_H__ + +#include <rte_kvargs.h> + +enum mvep_module_type { + MVEP_MOD_T_NONE = 0, + MVEP_MOD_T_PP2, + MVEP_MOD_T_SAM, + MVEP_MOD_T_NETA, + MVEP_MOD_T_LAST +}; + +int rte_mvep_init(enum mvep_module_type module, struct rte_kvargs *kvlist); +int rte_mvep_deinit(enum mvep_module_type module); + +#endif /* __RTE_MVEP_COMMON_H__ */ |