diff --git a/make/autoconf/basics.m4 b/make/autoconf/basics.m4 index 3cba8cd3a5a..c8877c92ecb 100644 --- a/make/autoconf/basics.m4 +++ b/make/autoconf/basics.m4 @@ -1127,6 +1127,8 @@ AC_DEFUN_ONCE([BASIC_SETUP_COMPLEX_TOOLS], fi fi BASIC_REQUIRE_PROGS(SETFILE, SetFile) + elif test "x$OPENJDK_TARGET_OS" = "xsolaris"; then + BASIC_REQUIRE_PROGS(ELFEDIT, elfedit) fi ]) diff --git a/make/autoconf/spec.gmk.in b/make/autoconf/spec.gmk.in index 1f2c6acd363..058f76253dd 100644 --- a/make/autoconf/spec.gmk.in +++ b/make/autoconf/spec.gmk.in @@ -710,6 +710,7 @@ CYGPATH:=@CYGPATH@ LDD:=@LDD@ OTOOL:=@OTOOL@ READELF:=@READELF@ +ELFEDIT:=@ELFEDIT@ EXPR:=@EXPR@ FILE:=@FILE@ DOT:=@DOT@ diff --git a/make/hotspot/lib/CompileDtracePostJvm.gmk b/make/hotspot/lib/CompileDtracePostJvm.gmk index 524803df2d0..efe4ffe8021 100644 --- a/make/hotspot/lib/CompileDtracePostJvm.gmk +++ b/make/hotspot/lib/CompileDtracePostJvm.gmk @@ -157,21 +157,19 @@ ifeq ($(call check-jvm-feature, dtrace), true) # Unfortunately dtrace generates incorrect types for some symbols in # dtrace_jhelper.o, resulting in "warning: symbol X has differing types" - # This is tracked in JDK-6890703. - $(DTRACE_JHELPER_OBJ): $(TOPDIR)/src/hotspot/os/solaris/dtrace/jhelper.d \ - $(JVM_OFFSETS_INDEX_H) + # See JDK-6890703 for details. + # We work around this by fixing the types for these symbols using elfedit, + # after dtrace has generated the .o file. + JHELPER_DTRACE_SRC := $(TOPDIR)/src/hotspot/os/solaris/dtrace/jhelper.d + DTRACE_EXTERNAL_SYMBOLS := $(shell $(GREP) ^extern $(JHELPER_DTRACE_SRC) | $(AWK) '{ gsub(";","") ; print $$3 }') + DTRACE_ELFEDIT_COMMANDS := $(foreach symbol, $(DTRACE_EXTERNAL_SYMBOLS), \ + -e 'sym:st_type $(symbol) 1') + + $(DTRACE_JHELPER_OBJ): $(JHELPER_DTRACE_SRC) $(JVM_OFFSETS_INDEX_H) $(call LogInfo, Running dtrace for $( $(DTRACE_SUPPORT_DIR)/$(@F).d) - # $(call ExecuteWithLog, $@, $(DTRACE) $(DTRACE_FLAGS) -o $@ \ - # -s $(DTRACE_SUPPORT_DIR)/$(@F).d) + $(call ExecuteWithLog, $@.elfedit, $(ELFEDIT) $(DTRACE_ELFEDIT_COMMANDS) $@) ############################################################################ # Build the stand-alone dtrace libraries