From: Mohsin Kazmi Date: Thu, 13 Sep 2018 07:59:50 +0000 (+0200) Subject: japi: Move Java API binding to cmake X-Git-Tag: v19.04-rc0~408 X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=commitdiff_plain;h=24195081f1355c91cd716f09f88db0721671cbd0 japi: Move Java API binding to cmake Change-Id: I264d547a06e3636d021a74cd26efb8137f629cbc Signed-off-by: Mohsin Kazmi Signed-off-by: Michal Cmarada --- diff --git a/build-data/packages/japi.mk b/build-data/packages/japi.mk index d6435930f4a..a9df1fcb336 100644 --- a/build-data/packages/japi.mk +++ b/build-data/packages/japi.mk @@ -1,6 +1,44 @@ +# Copyright (c) 2017-2018 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + japi_configure_depend = vpp-install japi_source = extras japi_configure_subdir = japi -japi_CPPFLAGS = $(call installed_includes_fn, vpp) $(call installed_includes_fn, vpp)/vpp_plugins -japi_LDFLAGS = $(call installed_libs_fn, vpp) +ifneq ($(shell which cmake3),) +CMAKE?=cmake3 +else +CMAKE?=cmake +endif + +japi_cmake_args ?= +japi_cmake_args += -DCMAKE_INSTALL_PREFIX:PATH=$(PACKAGE_INSTALL_DIR) +japi_cmake_args += -DCMAKE_C_FLAGS="$($(TAG)_TAG_CFLAGS)" +japi_cmake_args += -DCMAKE_SHARED_LINKER_FLAGS="$($(TAG)_TAG_LDFLAGS)" +japi_cmake_args += -DCMAKE_PREFIX_PATH:PATH="$(PACKAGE_INSTALL_DIR)/../vpp" +ifeq ("$(V)","1") +japi_cmake_args += -DCMAKE_VERBOSE_MAKEFILE:BOOL=ON +endif + +#Use devtoolset on centos 7 +ifneq ($(wildcard /opt/rh/devtoolset-7/enable),) +japi_cmake_args += -DCMAKE_PROGRAM_PATH:PATH="/opt/rh/devtoolset-7/root/bin" +endif + +japi_configure = \ + cd $(PACKAGE_BUILD_DIR) && \ + $(CMAKE) -G Ninja $(japi_cmake_args) $(call find_source_fn,$(PACKAGE_SOURCE))$(PACKAGE_SUBDIR) + +japi_build = $(CMAKE) --build $(PACKAGE_BUILD_DIR) -- $(MAKE_PARALLEL_FLAGS) + +japi_install = $(CMAKE) --build $(PACKAGE_BUILD_DIR) -- install diff --git a/extras/japi/CMakeLists.txt b/extras/japi/CMakeLists.txt new file mode 100644 index 00000000000..274dd0798da --- /dev/null +++ b/extras/japi/CMakeLists.txt @@ -0,0 +1,77 @@ +# Copyright (c) 2018 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +cmake_minimum_required(VERSION 3.5 FATAL_ERROR) + +project(japi) + +include(CheckCCompilerFlag) + +if(CMAKE_SYSTEM_PROCESSOR MATCHES "amd64.*|x86_64.*|AMD64.*") + set(CMAKE_C_FLAGS "-march=corei7 -mtune=corei7-avx ${CMAKE_C_FLAGS}") +elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^(aarch64.*|AARCH64.*)") + set(CMAKE_C_FLAGS "-march=armv8-a+crc ${CMAKE_C_FLAGS}") +endif() + +check_c_compiler_flag("-Wno-address-of-packed-member" compiler_flag_no_address_of_packed_member) +if (compiler_flag_no_address_of_packed_member) + add_definitions(-Wno-address-of-packed-member) +endif() + +execute_process( + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/../../src + COMMAND scripts/version + OUTPUT_VARIABLE JAPI_VERSION + OUTPUT_STRIP_TRAILING_WHITESPACE +) +string(REPLACE "-" ";" JAPI_LIB_VERSION ${JAPI_VERSION}) +list(GET JAPI_LIB_VERSION 0 JAPI_LIB_VERSION) + +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) +set(CMAKE_INSTALL_RPATH ${CMAKE_INSTALL_PREFIX}/lib) +set(CMAKE_INSTALL_MESSAGE NEVER) + +find_package(Threads REQUIRED) + +unset(dirlist) + +macro(subdirlist dirlist dirpath) + file(GLOB dirs RELATIVE ${dirpath} ${dirpath}/*) + foreach(dir ${dirs}) + if(IS_DIRECTORY ${dirpath}/${dir}) + list(APPEND dirlist ${dirpath}/${dir}) + endif() + endforeach() +endmacro() + +list(APPEND dirlist $ENV{JAVA_HOME}) +subdirlist(dirlist /usr/lib/jvm) +subdirlist(dirlist /usr/lib64/jvm) + +unset(JAVA_HOME_SET) +find_path(JAVA_HOME_SET NAMES include/jni.h PATHS ${dirlist}) +if (NOT JAVA_HOME_SET) + message("JAVA_HOME is not found") +else() + set(ENV{JAVA_HOME} "${JAVA_HOME_SET}") +endif() + +message("JAVA_HOME: $ENV{JAVA_HOME}") + +find_package(Java 1.8 REQUIRED COMPONENTS Development) +get_filename_component(jvm_path ${Java_JAVAC_EXECUTABLE} DIRECTORY) +set (Java_INCLUDE_DIRS ${jvm_path}/../include ${jvm_path}/../include/linux) + +message("Found java headers ${Java_INCLUDE_DIRS}") +message("Found javac at: " ${Java_JAVAC_EXECUTABLE}) +add_subdirectory(java) diff --git a/extras/japi/Makefile.am b/extras/japi/Makefile.am deleted file mode 100644 index 81ff5bb049e..00000000000 --- a/extras/japi/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ - - -AUTOMAKE_OPTIONS = foreign subdir-objects - -SUBDIRS = java diff --git a/extras/japi/configure.ac b/extras/japi/configure.ac deleted file mode 100644 index f6e7b53ac7f..00000000000 --- a/extras/japi/configure.ac +++ /dev/null @@ -1,57 +0,0 @@ -AC_INIT(japi, 18.10) -LT_INIT -AM_INIT_AUTOMAKE -AM_SILENT_RULES([yes]) -AC_PREFIX_DEFAULT([/usr]) - -PKG_CHECK_MODULES([CHECK], [check], [HAVE_CHECK=1], [HAVE_CHECK=0]) -AM_CONDITIONAL([USE_CHECK],[test "$HAVE_CHECK" -eq 1]) - -AC_PROG_CC -AC_PROG_CXX - -# Check if compiler supports specific flag -AC_DEFUN([CC_CHECK_FLAG], -[ - AC_MSG_CHECKING([if $CC supports $1]) - AC_LANG_PUSH([C]) - ac_saved_cflags="$CFLAGS" - CFLAGS="-Werror $1" - AC_COMPILE_IFELSE([AC_LANG_PROGRAM([])], - [cc_flag_check=yes], - [cc_flag_check=no] -) - AC_MSG_RESULT([$cc_flag_check]) - CFLAGS="$ac_saved_cflags" - AC_LANG_POP([C]) -]) - -CC_CHECK_FLAG("-Wno-address-of-packed-member") -AS_IF([test "$cc_flag_check" = yes], - [CFLAGS="${CFLAGS} -Wno-address-of-packed-member"], []) - -AM_CONDITIONAL(ENABLE_ACL_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_NAT_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_L2E_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_GBP_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_PPPOE_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_GTPU_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_IOAM_PLUGIN, test "yes" = "yes") -AM_CONDITIONAL(ENABLE_NSH_PLUGIN, test "yes" = "yes") - -AX_VPP_FIND_JDK8 -AC_SUBST(JAVA_HOME) -AC_SUBST(JAVAC) -AC_SUBST(JAVAH) -AC_SUBST(JAR) - -AS_CASE([$host_cpu], - [x86_64], [CPU_FLAGS="-march=corei7 -mtune=corei7-avx"], - [aarch64], [CPU_FLAGS="-march=armv8-a+crc"], - [CPU_FLAGS=""], -) -AC_SUBST([CPU_FLAGS]) - -AC_OUTPUT([Makefile java/Makefile]) - -AC_CONFIG_MACRO_DIR([m4]) diff --git a/extras/japi/java/CMakeLists.txt b/extras/japi/java/CMakeLists.txt new file mode 100644 index 00000000000..0cbdd514711 --- /dev/null +++ b/extras/japi/java/CMakeLists.txt @@ -0,0 +1,191 @@ +# Copyright (c) 2018 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +find_path(VNET_INCLUDE_DIR NAMES vnet/api_errno.h) +find_library(VPPINFRA_DIR NAMES vppinfra REQUIRED) +find_library(VLIBMEMORYCLIENT_DIR NAMES vlibmemoryclient REQUIRED) +find_library(SVM_DIR NAMES svm REQUIRED) + +include_directories(${VNET_INCLUDE_DIR} + ${VNET_INCLUDE_DIR}/vpp_plugins + ${Java_INCLUDE_DIRS} + ${CMAKE_CURRENT_SOURCE_DIR} + ${CMAKE_BINARY_DIR/../vpp/plugins}) +add_compile_options(-Wall) +############# Common package ################## +add_library(jvpp_common SHARED jvpp-common/jvpp_common.c) +set_target_properties(jvpp_common PROPERTIES SOVERSION ${JAPI_LIB_VERSION}) +target_link_libraries(jvpp_common ${VPPINFRA_DIR}) +install(TARGETS jvpp_common DESTINATION lib COMPONENT libjvpp_common) +install(FILES jvpp-common/jvpp_common.h DESTINATION include/japi/) + +set(JVPP_LIBS jvpp_common ${VPPINFRA_DIR} ${VLIBMEMORYCLIENT_DIR} ${SVM_DIR} + Threads::Threads m rt) + +############# Registry package ################## +set(PACKAGE_DIR_JVPP_REGISTRY io/fd/vpp/jvpp) +unset(files) +FILE(GLOB files RELATIVE + ${CMAKE_CURRENT_SOURCE_DIR} + ${CMAKE_CURRENT_SOURCE_DIR}/jvpp-registry/${PACKAGE_DIR_JVPP_REGISTRY}/*.java + ${CMAKE_CURRENT_SOURCE_DIR}/jvpp-registry/${PACKAGE_DIR_JVPP_REGISTRY}/*/*.java +) + +add_custom_target (jvpp-registry-classes) +add_custom_command (TARGET jvpp-registry-classes + PRE_BUILD + COMMAND mkdir -p jvpp-registry/target + COMMAND mkdir -p ${CMAKE_CURRENT_BINARY_DIR}/jvpp-registry + COMMAND ${Java_JAVAC_EXECUTABLE} + ARGS -d ${CMAKE_CURRENT_SOURCE_DIR}/jvpp-registry/target -h jvpp-registry ${files} + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} +) + +add_library(jvpp_registry SHARED jvpp-registry/jvpp_registry.c) +target_link_libraries(jvpp_registry ${JVPP_LIBS}) +include_directories(jvpp-registry) +add_dependencies(jvpp_registry jvpp_common jvpp-registry-classes) + +add_custom_target (jvpp-registry) +add_dependencies(jvpp-registry jvpp_registry) +add_custom_command(TARGET jvpp-registry + PRE_BUILD + COMMAND cp ${CMAKE_BINARY_DIR}/lib/libjvpp_registry.so jvpp-registry/target + COMMAND ${Java_JAR_EXECUTABLE} ARGS cf + ${CMAKE_CURRENT_BINARY_DIR}/jvpp-registry-${JAPI_LIB_VERSION}.jar + -C jvpp-registry/target . + COMMAND rm ARGS -rf jvpp-registry/target + jvpp-registry/io_fd_vpp_jvpp_*.h + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + COMMENT "JAR_GEN registry" +) +install( + FILES ${CMAKE_CURRENT_BINARY_DIR}/jvpp-registry-${JAPI_LIB_VERSION}.jar + DESTINATION share/java +) + +############## Functions ######################### +function(japigen name) + if(NOT VPP_JAVA_APIGEN) + set(VPP_JAVA_APIGEN ${CMAKE_CURRENT_SOURCE_DIR}/jvpp/gen/jvpp_gen.py) + endif() + add_custom_target(japigen-${name} DEPENDS jvpp-registry) + add_custom_command(TARGET japigen-${name} + POST_BUILD + COMMAND mkdir -p jvpp-${name}/target + COMMAND mkdir -p ${CMAKE_CURRENT_BINARY_DIR}/jvpp-${name} + COMMAND ${VPP_JAVA_APIGEN} + ARGS --plugin_name ${name} --root_dir jvpp-${name} -i ${ARGN} + COMMAND find jvpp-${name} -name \*.java > jvpp-${name}/jvpp-${name}.files + COMMAND ${Java_JAVAC_EXECUTABLE} + ARGS -cp ${CMAKE_CURRENT_BINARY_DIR}/jvpp-registry-${JAPI_LIB_VERSION}.jar -d + ${CMAKE_CURRENT_SOURCE_DIR}/jvpp-${name}/target -h jvpp-${name} + @jvpp-${name}/jvpp-${name}.files + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + COMMENT "JAVA_API_GEN ${name}" + ) +endfunction() + +function(jargen name) + add_custom_command(TARGET jvpp_${name} + POST_BUILD + COMMAND cp ${CMAKE_BINARY_DIR}/lib/libjvpp_${name}.so jvpp-${name}/target + COMMAND ${Java_JAR_EXECUTABLE} ARGS cf + ${CMAKE_CURRENT_BINARY_DIR}/jvpp-${name}-${JAPI_LIB_VERSION}.jar + -C jvpp-${name}/target . + COMMAND rm ARGS -rf jvpp-${name}/target jvpp-${name}/jvpp-${name}.files + jvpp-${name}/jvpp_${name}_gen.h jvpp-${name}/io_fd_vpp_jvpp_*.h + jvpp-registry/io_fd_vpp_jvpp_*.h + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} + COMMENT "JAR_GEN ${name}" + ) + install( + FILES ${CMAKE_CURRENT_BINARY_DIR}/jvpp-${name}-${JAPI_LIB_VERSION}.jar + DESTINATION share/java + ) +endfunction() + +function(java_api_binding name src_file) + japigen (${name} ${ARGN}) + add_library(jvpp_${name} SHARED jvpp-${name}/jvpp_${src_file}.c) + target_link_libraries(jvpp_${name} ${JVPP_LIBS}) + include_directories(jvpp-${name}) + add_dependencies(jvpp_${name} jvpp_common jvpp_registry japigen-${name}) + jargen (${name}) +endfunction() + +############ Core Package ####################### +unset (files) +unset (JSON_API_PATH) +set (JSON_API_PATH ${CMAKE_BINARY_DIR}/../vpp) + +FILE(GLOB_RECURSE files RELATIVE + ${CMAKE_CURRENT_SOURCE_DIR} + ${JSON_API_PATH}/vnet/*.api.json + ${JSON_API_PATH}/vpp/*.api.json +) + +java_api_binding (core core ${files}) + +############ Plugin Packages ####################### +unset (ACL_JSON_FILE) +unset (NAT_JSON_FILE) +unset (NSH_JSON_FILE) +unset (GTPU_JSON_FILE) +unset (PPPOE_JSON_FILE) +unset (IOAM_TRACE_JSON_FILE) +unset (IOAM_POT_JSON_FILE) +unset (IOAM_EXPORT_JSON_FILE) + +set (plugin_path ${CMAKE_BINARY_DIR}/../vpp/plugins) + +find_file(ACL_JSON_FILE NAMES acl.api.json HINTS ${plugin_path} PATH_SUFFIXES acl) +find_file(NAT_JSON_FILE NAMES nat.api.json HINTS ${plugin_path} PATH_SUFFIXES nat) +find_file(NSH_JSON_FILE NAMES nsh.api.json HINTS ${plugin_path} PATH_SUFFIXES nsh) +find_file(GTPU_JSON_FILE NAMES gtpu.api.json HINTS ${plugin_path} PATH_SUFFIXES gtpu) +find_file(PPPOE_JSON_FILE NAMES pppoe.api.json HINTS ${plugin_path} PATH_SUFFIXES pppoe) +find_file(IOAM_TRACE_JSON_FILE NAMES trace.api.json HINTS ${plugin_path} PATH_SUFFIXES ioam/lib-trace) +find_file(IOAM_POT_JSON_FILE NAMES pot.api.json HINTS ${plugin_path} PATH_SUFFIXES ioam/lib-pot) +find_file(IOAM_EXPORT_JSON_FILE NAMES ioam_export.api.json HINTS ${plugin_path} PATH_SUFFIXES ioam/export) + +if(ACL_JSON_FILE) + java_api_binding (acl acl ${ACL_JSON_FILE}) +endif() + +if(NAT_JSON_FILE) + java_api_binding (nat nat ${NAT_JSON_FILE}) +endif() + +if(NSH_JSON_FILE) + java_api_binding (nsh nsh ${NSH_JSON_FILE}) +endif() + +if(GTPU_JSON_FILE) + java_api_binding (gtpu gtpu ${GTPU_JSON_FILE}) +endif() + +if(PPPOE_JSON_FILE) + java_api_binding (pppoe pppoe ${PPPOE_JSON_FILE}) +endif() + +if(IOAM_TRACE_JSON_FILE) + java_api_binding (ioamtrace ioam_trace ${IOAM_TRACE_JSON_FILE}) +endif() + +if(IOAM_POT_JSON_FILE) + java_api_binding (ioampot ioam_pot ${IOAM_POT_JSON_FILE}) +endif() + +if(IOAM_EXPORT_JSON_FILE) + java_api_binding (ioamexport ioam_export ${IOAM_EXPORT_JSON_FILE}) +endif() diff --git a/extras/japi/java/Makefile.am b/extras/japi/java/Makefile.am deleted file mode 100644 index d33ae82ff0d..00000000000 --- a/extras/japi/java/Makefile.am +++ /dev/null @@ -1,279 +0,0 @@ -# Copyright (c) 2016 Cisco and/or its affiliates. -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at: -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -AUTOMAKE_OPTIONS = foreign subdir-objects -ACLOCAL_AMFLAGS = -I m4 -AM_LIBTOOLFLAGS = --quiet - -AM_CFLAGS = @CPU_FLAGS@ -Wall -I${top_srcdir} -I${top_builddir} \ - -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/linux \ - -I@top_srcdir@/plugins -I@top_builddir@/plugins - -AM_LDFLAGS = -shared -avoid-version -rpath /none -no-undefined - -BUILT_SOURCES = -bin_PROGRAMS = -noinst_LTLIBRARIES = -JAR_FILES = -CLEANDIRS = - -# -# jvpp-common -# - -nobase_include_HEADERS = \ - jvpp-common/jvpp_common.h - -lib_LTLIBRARIES = libjvpp_common.la -libjvpp_common_la_SOURCES = jvpp-common/jvpp_common.c -libjvpp_common_la_LDFLAGS = shared -rpath /none -no-undefined -lvppinfra - -JVPP_LIBS = \ - libjvpp_common.la \ - -lvppinfra -lvlibmemoryclient -lsvm -lpthread -lm -lrt - -# -# jvpp-registry (connection management + plugin registry) -# - -noinst_LTLIBRARIES += libjvpp_registry.la - -libjvpp_registry_la_SOURCES = jvpp-registry/jvpp_registry.c -libjvpp_registry_la_CPPFLAGS = -Ijvpp-registry -libjvpp_registry_la_LIBADD = $(JVPP_LIBS) -libjvpp_registry_la_DEPENDENCIES = libjvpp_common.la - -packagedir_jvpp_registry = io/fd/vpp/jvpp -jvpp_registry_src_files := \ - $(wildcard @srcdir@/jvpp-registry/$(packagedir_jvpp_registry)/*.java) \ - $(wildcard @srcdir@/jvpp-registry/$(packagedir_jvpp_registry)/**/*.java) - -BUILT_SOURCES += jvpp-registry/io_fd_vpp_jvpp_VppJNIConnection.h -CLEANDIRS += jvpp-registry/target -JAR_FILES += jvpp-registry-$(PACKAGE_VERSION).jar - -jvpp_registry_ok = jvpp-registry/io_fd_vpp_jvpp_VppJNIConnection.h - -jvpp-registry/io_fd_vpp_jvpp_VppJNIConnection.h: $(jvpp_registry_src_files) - @echo " JVPP GEN $@" - @rm -rf jvpp-registry/target - @mkdir -p jvpp-registry/target - @$(JAVAC) -source 8 -target 8 -d jvpp-registry/target -h jvpp-registry $^ - @touch jvpp-registry.ok - -define japigen - @echo " JVPP GEN $@" - @rm -rf jvpp-$(1)/target - @ @srcdir@/jvpp/gen/jvpp_gen.py --plugin_name $(1) --root_dir jvpp-$(1) \ - -i $(jvpp_$(1)_json_files) - @find jvpp-$(1)/target -name \*.java > jvpp-$(1).generated.files - @find @srcdir@/jvpp-$(1) -name \*.java > jvpp-$(1).static.files - @$(JAVAC) -source 8 -target 8 -classpath jvpp-registry/target \ - -d jvpp-$(1)/target -h jvpp-$(1) @jvpp-$(1).generated.files @jvpp-$(1).static.files -endef - -# -# jvpp-core (Java wrapper for vpe.api) -# -noinst_LTLIBRARIES += libjvpp_core.la -libjvpp_core_la_SOURCES = jvpp-core/jvpp_core.c jvpp-core/jvpp_core_gen.h -libjvpp_core_la_CPPFLAGS = -Ijvpp-registry -Ijvpp-core -libjvpp_core_la_LIBADD = $(JVPP_LIBS) -libjvpp_core_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-core/io_fd_vpp_jvpp_core_JVppCoreImpl.h -JAR_FILES += jvpp-core-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-core/target - -# Include all VPP API files -jvpp_core_json_files = $(shell find @top_builddir@/../vpp/vnet -type f -name '*.api.json') -jvpp_core_json_files += $(shell find @top_builddir@/../vpp/vpp -type f -name '*.api.json') -# except for plugins and unsupported ones: -# jvpp_core_json_files += @top_builddir@/vlibmemory/memclnt.api.json - -jvpp-core/io_fd_vpp_jvpp_core_JVppCoreImpl.h: $(jvpp_registry_ok) $(jvpp_core_json_files) - $(call japigen,core,JVppCoreImpl) - -# -# ACL Plugin -# -if ENABLE_ACL_PLUGIN -noinst_LTLIBRARIES += libjvpp_acl.la -libjvpp_acl_la_SOURCES = jvpp-acl/jvpp_acl.c -libjvpp_acl_la_CPPFLAGS = -Ijvpp-acl -libjvpp_acl_la_LIBADD = $(JVPP_LIBS) -libjvpp_acl_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-acl/io_fd_vpp_jvpp_acl_JVppAclImpl.h -JAR_FILES += jvpp-acl-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-acl/target - -jvpp_acl_json_files = @top_builddir@/../vpp/plugins/acl/acl.api.json - -jvpp-acl/io_fd_vpp_jvpp_acl_JVppAclImpl.h: $(jvpp_registry_ok) $(jvpp_acl_json_files) - $(call japigen,acl,JVppAclImpl) -endif - -# -# GTPU Plugin -# -if ENABLE_GTPU_PLUGIN -noinst_LTLIBRARIES += libjvpp_gtpu.la -libjvpp_gtpu_la_SOURCES = jvpp-gtpu/jvpp_gtpu.c -libjvpp_gtpu_la_CPPFLAGS = -Ijvpp-gtpu -libjvpp_gtpu_la_LIBADD = $(JVPP_LIBS) -libjvpp_gtpu_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-gtpu/io_fd_vpp_jvpp_gtpu_JVppGtpuImpl.h -JAR_FILES += jvpp-gtpu-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-gtpu/target - -jvpp_gtpu_json_files = @top_builddir@/../vpp/plugins/gtpu/gtpu.api.json - -jvpp-gtpu/io_fd_vpp_jvpp_gtpu_JVppGtpuImpl.h: $(jvpp_registry_ok) $(jvpp_gtpu_json_files) - $(call japigen,gtpu,JVppGtpuImpl) -endif - -# -# PPPOE Plugin -# -if ENABLE_PPPOE_PLUGIN -noinst_LTLIBRARIES += libjvpp_pppoe.la -libjvpp_pppoe_la_SOURCES = jvpp-pppoe/jvpp_pppoe.c -libjvpp_pppoe_la_CPPFLAGS = -Ijvpp-pppoe -libjvpp_pppoe_la_LIBADD = $(JVPP_LIBS) -libjvpp_pppoe_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-pppoe/io_fd_vpp_jvpp_pppoe_JVppPppoeImpl.h -JAR_FILES += jvpp-pppoe-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-pppoe/target - -jvpp_pppoe_json_files = @top_builddir@/../vpp/plugins/pppoe/pppoe.api.json - -jvpp-pppoe/io_fd_vpp_jvpp_pppoe_JVppPppoeImpl.h: $(jvpp_registry_ok) $(jvpp_pppoe_json_files) - $(call japigen,pppoe,JVppPppoeImpl) -endif - -# -# NAT Plugin -# -if ENABLE_NAT_PLUGIN -noinst_LTLIBRARIES += libjvpp_nat.la -libjvpp_nat_la_SOURCES = jvpp-nat/jvpp_nat.c -libjvpp_nat_la_CPPFLAGS = -Ijvpp-nat -libjvpp_nat_la_LIBADD = $(JVPP_LIBS) -libjvpp_nat_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-nat/io_fd_vpp_jvpp_nat_JVppNatImpl.h -JAR_FILES += jvpp-nat-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-nat/target - -jvpp_nat_json_files = @top_builddir@/../vpp/plugins/nat/nat.api.json - -jvpp-nat/io_fd_vpp_jvpp_nat_JVppNatImpl.h: $(jvpp_registry_ok) $(jvpp_nat_json_files) - $(call japigen,nat,JVppNatImpl) -endif - -# -# NSH Plugin -# -if ENABLE_NSH_PLUGIN -noinst_LTLIBRARIES += libjvpp_nsh.la -libjvpp_nsh_la_SOURCES = jvpp-nsh/jvpp_nsh.c -libjvpp_nsh_la_CPPFLAGS = -Ijvpp-nsh -libjvpp_nsh_la_LIBADD = $(JVPP_LIBS) -libjvpp_nsh_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-nsh/io_fd_vpp_jvpp_nsh_JVppNshImpl.h -JAR_FILES += jvpp-nsh-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-nsh/target - -jvpp_nsh_json_files = @top_builddir@/../vpp/plugins/nsh/nsh.api.json - -jvpp-nsh/io_fd_vpp_jvpp_nsh_JVppNshImpl.h: $(jvpp_registry_ok) $(jvpp_nsh_json_files) - $(call japigen,nsh,JVppNshImpl) -endif - -# -# iOAM Trace Plugin -# -if ENABLE_IOAM_PLUGIN -noinst_LTLIBRARIES += libjvpp_ioamtrace.la -libjvpp_ioamtrace_la_SOURCES = jvpp-ioamtrace/jvpp_ioam_trace.c -libjvpp_ioamtrace_la_LIBADD = $(JVPP_LIBS) -libjvpp_ioamtrace_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-ioamtrace/io_fd_vpp_jvpp_ioamtrace_JVppIoamtraceImpl.h -JAR_FILES += jvpp-ioamtrace-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-ioamtrace/target - -jvpp_ioamtrace_json_files = @top_builddir@/../vpp/plugins/ioam/lib-trace/trace.api.json - -jvpp-ioamtrace/io_fd_vpp_jvpp_ioamtrace_JVppIoamtraceImpl.h: $(jvpp_registry_ok) $(jvpp_ioamtrace_json_files) - $(call japigen,ioamtrace,JVppIoamtraceImpl) - -# -# iOAM POT Plugin -# -noinst_LTLIBRARIES += libjvpp_ioampot.la -libjvpp_ioampot_la_SOURCES = jvpp-ioampot/jvpp_ioam_pot.c -libjvpp_ioampot_la_LIBADD = $(JVPP_LIBS) -libjvpp_ioampot_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-ioampot/io_fd_vpp_jvpp_ioampot_JVppIoampotImpl.h -JAR_FILES += jvpp-ioampot-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-ioampot/target - -jvpp_ioampot_json_files = @top_builddir@/../vpp/plugins/ioam/lib-pot/pot.api.json - -jvpp-ioampot/io_fd_vpp_jvpp_ioampot_JVppIoampotImpl.h: $(jvpp_registry_ok) $(jvpp_ioampot_json_files) - $(call japigen,ioampot,JVppIoampotImpl) - -# -# iOAM Export Plugin -# -noinst_LTLIBRARIES += libjvpp_ioamexport.la -libjvpp_ioamexport_la_SOURCES = jvpp-ioamexport/jvpp_ioam_export.c -libjvpp_ioamexport_la_LIBADD = $(JVPP_LIBS) -libjvpp_ioamexport_la_DEPENDENCIES = libjvpp_common.la - -BUILT_SOURCES += jvpp-ioamexport/io_fd_vpp_jvpp_ioamexport_JVppIoamexportImpl.h -JAR_FILES += jvpp-ioamexport-$(PACKAGE_VERSION).jar -CLEANDIRS += jvpp-ioamexport/target - -jvpp_ioamexport_json_files = @top_builddir@/../vpp/plugins/ioam/export/ioam_export.api.json - -jvpp-ioamexport/io_fd_vpp_jvpp_ioamexport_JVppIoamexportImpl.h: $(jvpp_registry_ok) $(jvpp_ioamexport_json_files) - $(call japigen,ioamexport,JVppIoamexportImpl) -endif - -# -# JAR creation -# -jvpp-%-$(PACKAGE_VERSION).jar: libjvpp_%.la - @echo " JAR $@" - @cp .libs/libjvpp_$*.so jvpp-$*/target - @$(JAR) cf $(JARFLAGS) $@ -C jvpp-$*/target . - -jardir = $(prefix)/share/java -jar_DATA = $(JAR_FILES) - -all-local: $(JAR_FILES) - -# -# Cleanup -# -CLEANFILES = jvpp-registry.ok $(JAR_FILES) $(BUILT_SOURCES) *.files */*.h - -clean-local: - rm -rf $(CLEANDIRS) diff --git a/extras/japi/m4/ax_vpp_find_jdk8.m4 b/extras/japi/m4/ax_vpp_find_jdk8.m4 deleted file mode 100644 index 94b785038f7..00000000000 --- a/extras/japi/m4/ax_vpp_find_jdk8.m4 +++ /dev/null @@ -1,43 +0,0 @@ - - -AC_DEFUN([AX_VPP_FIND_JDK8], -[ -while true -do - if test "${JAVA_HOME+set}" = set ; then - AC_MSG_CHECKING([${JAVA_HOME} for Java 8 compiler]) - JAVAC=${JAVA_HOME}/bin/javac - JAVAH=${JAVA_HOME}/bin/javah - JAR=${JAVA_HOME}/bin/jar - JAVA_VERSION=$(${JAVA_HOME}/bin/javac -source 8 -version 2>&1) - if test 0 -eq "$?"; then - JAVA_VERSION=$(echo "${JAVA_VERSION}" | cut -d\ -f2) - AC_MSG_RESULT([ok]) - else - AC_MSG_RESULT([no]) - AC_MSG_ERROR([Java in ${JAVA_HOME} (path specified in JAVA_HOME) cannot compile Java 8 code]) - fi - break - fi - - for dir in $(find /usr/lib*/jvm/* -maxdepth 0 -type d); do - AC_MSG_CHECKING([${dir} for Java 8 compiler]) - JAVA_VERSION=$(${dir}/bin/javac -source 8 -version 2>&1) - if test 0 -eq "$?"; then - JAVA_VERSION=$(echo "${JAVA_VERSION}" | cut -d\ -f2) - JAVA_HOME=${dir} - JAVAC=${dir}/bin/javac - JAVAH=${dir}/bin/javah - JAR=${dir}/bin/jar - AC_MSG_RESULT([found version $JAVA_VERSION]) - break - else - JAVA_VERSION="" - AC_MSG_RESULT([no]) - fi - done - - test "${JAVA_HOME}set" = set && AC_MSG_ERROR([Could not find Java 8 compiler]) - break -done -])