perf jvmti: Separate jvmti cmlr check
The Compiled Method Load Record (cmlr) is JDK specific interface to access JVM stack info. This makes the jvmti agent code not compile under another jdk, which does not support that. Separating jvmti cmlr check into special feature check, and adding HAVE_JVMTI_CMLR macro to indicate that. Mark cmlr code in jvmti/libjvmti.c with HAVE_JVMTI_CMLR, so we can compile it on system without cmlr support. This change makes the jvmti compile with java-1.8.0-ibm package. It's without the line numbers support, but the rest works. Adding NO_JVMTI_CMLR compile variable for testing. Signed-off-by: Jiri Olsa <jolsa@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Ben Gainey <ben.gainey@arm.com> Cc: Gustavo Luiz Duarte <gduarte@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/r/20181121154341.21521-1-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
ecd94f1be3
commit
dd1d0044dd
@ -55,6 +55,7 @@ FILES= \
|
|||||||
test-sdt.bin \
|
test-sdt.bin \
|
||||||
test-cxx.bin \
|
test-cxx.bin \
|
||||||
test-jvmti.bin \
|
test-jvmti.bin \
|
||||||
|
test-jvmti-cmlr.bin \
|
||||||
test-sched_getcpu.bin \
|
test-sched_getcpu.bin \
|
||||||
test-setns.bin \
|
test-setns.bin \
|
||||||
test-libopencsd.bin \
|
test-libopencsd.bin \
|
||||||
@ -267,6 +268,9 @@ $(OUTPUT)test-cxx.bin:
|
|||||||
$(OUTPUT)test-jvmti.bin:
|
$(OUTPUT)test-jvmti.bin:
|
||||||
$(BUILD)
|
$(BUILD)
|
||||||
|
|
||||||
|
$(OUTPUT)test-jvmti-cmlr.bin:
|
||||||
|
$(BUILD)
|
||||||
|
|
||||||
$(OUTPUT)test-llvm.bin:
|
$(OUTPUT)test-llvm.bin:
|
||||||
$(BUILDXX) -std=gnu++11 \
|
$(BUILDXX) -std=gnu++11 \
|
||||||
-I$(shell $(LLVM_CONFIG) --includedir) \
|
-I$(shell $(LLVM_CONFIG) --includedir) \
|
||||||
|
11
tools/build/feature/test-jvmti-cmlr.c
Normal file
11
tools/build/feature/test-jvmti-cmlr.c
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
|
#include <jvmti.h>
|
||||||
|
#include <jvmticmlr.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
jvmtiCompiledMethodLoadInlineRecord rec __attribute__((unused));
|
||||||
|
jvmtiCompiledMethodLoadRecordHeader hdr __attribute__((unused));
|
||||||
|
PCStackInfo p __attribute__((unused));
|
||||||
|
return 0;
|
||||||
|
}
|
@ -1,6 +1,5 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
#include <jvmti.h>
|
#include <jvmti.h>
|
||||||
#include <jvmticmlr.h>
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
@ -855,6 +855,13 @@ ifndef NO_JVMTI
|
|||||||
$(call feature_check,jvmti)
|
$(call feature_check,jvmti)
|
||||||
ifeq ($(feature-jvmti), 1)
|
ifeq ($(feature-jvmti), 1)
|
||||||
$(call detected_var,JDIR)
|
$(call detected_var,JDIR)
|
||||||
|
ifndef NO_JVMTI_CMLR
|
||||||
|
FEATURE_CHECK_CFLAGS-jvmti-cmlr := $(FEATURE_CHECK_CFLAGS-jvmti)
|
||||||
|
$(call feature_check,jvmti-cmlr)
|
||||||
|
ifeq ($(feature-jvmti-cmlr), 1)
|
||||||
|
CFLAGS += -DHAVE_JVMTI_CMLR
|
||||||
|
endif
|
||||||
|
endif # NO_JVMTI_CMLR
|
||||||
else
|
else
|
||||||
$(warning No openjdk development package found, please install JDK package, e.g. openjdk-8-jdk, java-1.8.0-openjdk-devel)
|
$(warning No openjdk development package found, please install JDK package, e.g. openjdk-8-jdk, java-1.8.0-openjdk-devel)
|
||||||
NO_JVMTI := 1
|
NO_JVMTI := 1
|
||||||
|
@ -95,6 +95,9 @@ include ../scripts/utilities.mak
|
|||||||
#
|
#
|
||||||
# Define NO_JVMTI if you do not want jvmti agent built
|
# Define NO_JVMTI if you do not want jvmti agent built
|
||||||
#
|
#
|
||||||
|
# Define NO_JVMTI_CMLR (debug only) if you do not want to process CMLR
|
||||||
|
# data for java source lines.
|
||||||
|
#
|
||||||
# Define LIBCLANGLLVM if you DO want builtin clang and llvm support.
|
# Define LIBCLANGLLVM if you DO want builtin clang and llvm support.
|
||||||
# When selected, pass LLVM_CONFIG=/path/to/llvm-config to `make' if
|
# When selected, pass LLVM_CONFIG=/path/to/llvm-config to `make' if
|
||||||
# llvm-config is not in $PATH.
|
# llvm-config is not in $PATH.
|
||||||
|
@ -6,7 +6,9 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
#include <jvmti.h>
|
#include <jvmti.h>
|
||||||
|
#ifdef HAVE_JVMTI_CMLR
|
||||||
#include <jvmticmlr.h>
|
#include <jvmticmlr.h>
|
||||||
|
#endif
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
#include "jvmti_agent.h"
|
#include "jvmti_agent.h"
|
||||||
@ -27,6 +29,7 @@ static void print_error(jvmtiEnv *jvmti, const char *msg, jvmtiError ret)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_JVMTI_CMLR
|
||||||
static jvmtiError
|
static jvmtiError
|
||||||
do_get_line_numbers(jvmtiEnv *jvmti, void *pc, jmethodID m, jint bci,
|
do_get_line_numbers(jvmtiEnv *jvmti, void *pc, jmethodID m, jint bci,
|
||||||
jvmti_line_info_t *tab, jint *nr)
|
jvmti_line_info_t *tab, jint *nr)
|
||||||
@ -125,6 +128,15 @@ get_line_numbers(jvmtiEnv *jvmti, const void *compile_info, jvmti_line_info_t **
|
|||||||
*nr_lines = lines_total;
|
*nr_lines = lines_total;
|
||||||
return JVMTI_ERROR_NONE;
|
return JVMTI_ERROR_NONE;
|
||||||
}
|
}
|
||||||
|
#else /* HAVE_JVMTI_CMLR */
|
||||||
|
|
||||||
|
static jvmtiError
|
||||||
|
get_line_numbers(jvmtiEnv *jvmti __maybe_unused, const void *compile_info __maybe_unused,
|
||||||
|
jvmti_line_info_t **tab __maybe_unused, int *nr_lines __maybe_unused)
|
||||||
|
{
|
||||||
|
return JVMTI_ERROR_NONE;
|
||||||
|
}
|
||||||
|
#endif /* HAVE_JVMTI_CMLR */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
copy_class_filename(const char * class_sign, const char * file_name, char * result, size_t max_length)
|
copy_class_filename(const char * class_sign, const char * file_name, char * result, size_t max_length)
|
||||||
|
Loading…
Reference in New Issue
Block a user