author | rfield |
Fri, 25 Mar 2016 18:36:19 -0700 | |
changeset 36718 | bf40906bf49d |
parent 36511 | 9d0388c6b336 |
permissions | -rw-r--r-- |
25859 | 1 |
# |
36110
91a3a6df36ec
8150203: Incremental update from build-infra project
ihse
parents:
35276
diff
changeset
|
2 |
# Copyright (c) 2011, 2016, 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 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
44 |
# Statically link the C runtime so that there are not dependencies on modules |
|
45 |
# not on the search patch when invoked from the Windows system directory |
|
46 |
# (or elsewhere). |
|
47 |
LIBINSTRUMENT_CFLAGS := $(filter-out -MD, $(LIBINSTRUMENT_CFLAGS)) |
|
48 |
# equivalent of strcasecmp is stricmp on Windows |
|
49 |
LIBINSTRUMENT_CFLAGS += -Dstrcasecmp=stricmp |
|
50 |
endif |
|
51 |
||
52 |
$(eval $(call SetupNativeCompilation,BUILD_LIBINSTRUMENT, \ |
|
53 |
LIBRARY := instrument, \ |
|
54 |
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ |
|
55 |
SRC := $(LIBINSTRUMENT_SRC), \ |
|
56 |
OPTIMIZATION := LOW, \ |
|
31069
14be2fa211f6
8081616: Remove hard-coded CFLAGS_WARNINGS_ARE_ERRORS to fully respect --disable-warnings-as-errors
ihse
parents:
30365
diff
changeset
|
57 |
CFLAGS := $(LIBINSTRUMENT_CFLAGS), \ |
25859 | 58 |
CFLAGS_debug := -DJPLIS_LOGGING, \ |
59 |
CFLAGS_release := -DNO_JPLIS_LOGGING, \ |
|
60 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libinstrument/mapfile-vers, \ |
|
61 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
|
62 |
$(call SET_SHARED_LIBRARY_ORIGIN) \ |
|
63 |
$(LIBINSTRUMENT_LDFLAGS), \ |
|
33406 | 64 |
LDFLAGS_linux := $(call SET_SHARED_LIBRARY_ORIGIN,/jli) \ |
65 |
-L$(call FindLibDirForModule, java.base)/jli, \ |
|
66 |
LDFLAGS_solaris := $(call SET_SHARED_LIBRARY_ORIGIN,/jli) \ |
|
67 |
-L$(call FindLibDirForModule, java.base)/jli, \ |
|
34695
7a6cc9982d22
8142907: Integration of minor fixes from the build-infra project
ihse
parents:
33518
diff
changeset
|
68 |
LDFLAGS_macosx := -Wl$(COMMA)-all_load, \ |
33406 | 69 |
LDFLAGS_aix := -L$(SUPPORT_OUTPUTDIR)/native/java.base, \ |
33518
3f1644328d06
8141290: AIX: fix build after '8140661: Rename LDFLAGS_SUFFIX to LIBS'
simonis
parents:
33406
diff
changeset
|
70 |
LIBS := $(JDKLIB_LIBS), \ |
36511 | 71 |
LIBS_unix := -ljava -ljvm $(LIBZ), \ |
33406 | 72 |
LIBS_linux := -ljli $(LIBDL), \ |
33518
3f1644328d06
8141290: AIX: fix build after '8140661: Rename LDFLAGS_SUFFIX to LIBS'
simonis
parents:
33406
diff
changeset
|
73 |
LIBS_solaris := -ljli $(LIBDL), \ |
3f1644328d06
8141290: AIX: fix build after '8140661: Rename LDFLAGS_SUFFIX to LIBS'
simonis
parents:
33406
diff
changeset
|
74 |
LIBS_aix := -liconv -ljli_static $(LIBDL), \ |
33406 | 75 |
LIBS_macosx := -liconv -framework Cocoa -framework Security \ |
34695
7a6cc9982d22
8142907: Integration of minor fixes from the build-infra project
ihse
parents:
33518
diff
changeset
|
76 |
-framework ApplicationServices \ |
7a6cc9982d22
8142907: Integration of minor fixes from the build-infra project
ihse
parents:
33518
diff
changeset
|
77 |
$(SUPPORT_OUTPUTDIR)/native/java.base/libjli_static.a, \ |
36511 | 78 |
LIBS_windows := jvm.lib $(WIN_JAVA_LIB) advapi32.lib \ |
33406 | 79 |
$(SUPPORT_OUTPUTDIR)/native/java.base/jli_static.lib, \ |
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, \ |
35276 | 86 |
)) |
25859 | 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 |
################################################################################ |