author | erikj |
Fri, 28 Aug 2015 10:13:30 +0200 | |
changeset 32408 | 97230ec16697 |
parent 31069 | 14be2fa211f6 |
child 33406 | 4680f7495292 |
permissions | -rw-r--r-- |
25859 | 1 |
# |
30351 | 2 |
# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. |
25859 | 3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
# |
|
5 |
# This code is free software; you can redistribute it and/or modify it |
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
|
7 |
# published by the Free Software Foundation. Oracle designates this |
|
8 |
# particular file as subject to the "Classpath" exception as provided |
|
9 |
# by Oracle in the LICENSE file that accompanied this code. |
|
10 |
# |
|
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
# accompanied this code). |
|
16 |
# |
|
17 |
# You should have received a copy of the GNU General Public License version |
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
# |
|
21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
|
22 |
# or visit www.oracle.com if you need additional information or have any |
|
23 |
# questions. |
|
24 |
# |
|
25 |
||
26 |
include LibCommon.gmk |
|
27 |
||
30351 | 28 |
# Hook to include the corresponding custom file, if present. |
29 |
$(eval $(call IncludeCustomExtension, jdk, lib/Lib-java.instrument.gmk)) |
|
30 |
||
25859 | 31 |
################################################################################ |
32 |
||
33 |
LIBINSTRUMENT_SRC := $(JDK_TOPDIR)/src/java.instrument/share/native/libinstrument \ |
|
27736
8c9bd4be4a86
8058631: Rename posix to unix in build system to match file name changes
ihse
parents:
25859
diff
changeset
|
34 |
$(JDK_TOPDIR)/src/java.instrument/$(OPENJDK_TARGET_OS_TYPE)/native/libinstrument \ |
25859 | 35 |
# |
36 |
LIBINSTRUMENT_CFLAGS := $(CFLAGS_JDKLIB) \ |
|
37 |
$(addprefix -I, $(LIBINSTRUMENT_SRC)) \ |
|
27565 | 38 |
-I$(SUPPORT_OUTPUTDIR)/headers/java.instrument \ |
25859 | 39 |
-I$(JDK_TOPDIR)/src/java.base/share/native/libjli \ |
40 |
-I$(JDK_TOPDIR)/src/java.base/share/native/libjava \ |
|
41 |
# |
|
42 |
||
43 |
LIBINSTRUMENT_LDFLAGS := |
|
44 |
LIBINSTRUMENT_LDFLAGS_SUFFIX := |
|
45 |
||
46 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
27565 | 47 |
LIBINSTRUMENT_LDFLAGS += $(SUPPORT_OUTPUTDIR)/native/java.base/jli_static.lib $(WIN_JAVA_LIB) \ |
25859 | 48 |
-export:Agent_OnAttach advapi32.lib |
49 |
# Statically link the C runtime so that there are not dependencies on modules |
|
50 |
# not on the search patch when invoked from the Windows system directory |
|
51 |
# (or elsewhere). |
|
52 |
LIBINSTRUMENT_CFLAGS := $(filter-out -MD, $(LIBINSTRUMENT_CFLAGS)) |
|
53 |
# equivalent of strcasecmp is stricmp on Windows |
|
54 |
LIBINSTRUMENT_CFLAGS += -Dstrcasecmp=stricmp |
|
55 |
else |
|
56 |
LIBINSTRUMENT_LDFLAGS_SUFFIX := -ljava |
|
57 |
endif |
|
58 |
||
59 |
$(eval $(call SetupNativeCompilation,BUILD_LIBINSTRUMENT, \ |
|
60 |
LIBRARY := instrument, \ |
|
61 |
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ |
|
62 |
SRC := $(LIBINSTRUMENT_SRC), \ |
|
63 |
OPTIMIZATION := LOW, \ |
|
31069
14be2fa211f6
8081616: Remove hard-coded CFLAGS_WARNINGS_ARE_ERRORS to fully respect --disable-warnings-as-errors
ihse
parents:
30365
diff
changeset
|
64 |
CFLAGS := $(LIBINSTRUMENT_CFLAGS), \ |
25859 | 65 |
CFLAGS_debug := -DJPLIS_LOGGING, \ |
66 |
CFLAGS_release := -DNO_JPLIS_LOGGING, \ |
|
67 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libinstrument/mapfile-vers, \ |
|
68 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
|
69 |
$(call SET_SHARED_LIBRARY_ORIGIN) \ |
|
70 |
$(LIBINSTRUMENT_LDFLAGS), \ |
|
71 |
LDFLAGS_linux := $(call SET_SHARED_LIBRARY_ORIGIN,/jli), \ |
|
72 |
LDFLAGS_solaris := $(call SET_SHARED_LIBRARY_ORIGIN,/jli), \ |
|
27565 | 73 |
LDFLAGS_macosx := -Xlinker -all_load $(SUPPORT_OUTPUTDIR)/native/java.base/libjli_static.a \ |
25859 | 74 |
-framework Cocoa -framework Security -framework ApplicationServices, \ |
75 |
LDFLAGS_SUFFIX := $(LIBINSTRUMENT_LDFLAGS_SUFFIX), \ |
|
76 |
LDFLAGS_SUFFIX_macosx := -liconv $(LIBZ), \ |
|
27944 | 77 |
LDFLAGS_SUFFIX_solaris := $(LIBZ) -L$(call FindLibDirForModule, java.base)/jli -ljli $(LIBDL) -lc, \ |
78 |
LDFLAGS_SUFFIX_linux := $(LIBZ) -L$(call FindLibDirForModule, java.base)/jli -ljli $(LIBDL), \ |
|
27565 | 79 |
LDFLAGS_SUFFIX_aix := $(LIBZ) -L$(SUPPORT_OUTPUTDIR)/native/java.base -ljli_static $(LIBDL),\ |
25859 | 80 |
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ |
81 |
RC_FLAGS := $(RC_FLAGS) \ |
|
82 |
-D "JDK_FNAME=instrument.dll" \ |
|
83 |
-D "JDK_INTERNAL_NAME=instrument" \ |
|
84 |
-D "JDK_FTYPE=0x2L", \ |
|
27565 | 85 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libinstrument, \ |
25859 | 86 |
DEBUG_SYMBOLS := true)) |
87 |
||
88 |
ifneq (, $(findstring $(OPENJDK_TARGET_OS), macosx windows aix)) |
|
27565 | 89 |
$(BUILD_LIBINSTRUMENT): $(SUPPORT_OUTPUTDIR)/native/java.base/$(LIBRARY_PREFIX)jli_static$(STATIC_LIBRARY_SUFFIX) |
25859 | 90 |
else |
27565 | 91 |
$(BUILD_LIBINSTRUMENT): $(call FindLib, java.base, jli, /jli) |
25859 | 92 |
endif |
93 |
$(BUILD_LIBINSTRUMENT): $(BUILD_LIBJAVA) |
|
94 |
||
27565 | 95 |
TARGETS += $(BUILD_LIBINSTRUMENT) |
25859 | 96 |
|
97 |
################################################################################ |