author | iris |
Mon, 17 Aug 2015 13:03:00 -0700 | |
changeset 34028 | 5f5be07214a7 |
parent 31246 | dfc58fd4feec |
child 33989 | 88dca824e58c |
child 32267 | 4e96a9ee01b1 |
permissions | -rw-r--r-- |
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
1 |
# |
29374
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
2 |
# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. |
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
4 |
# |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
5 |
# This code is free software; you can redistribute it and/or modify it |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
7 |
# published by the Free Software Foundation. Oracle designates this |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
8 |
# particular file as subject to the "Classpath" exception as provided |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
9 |
# by Oracle in the LICENSE file that accompanied this code. |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
10 |
# |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
15 |
# accompanied this code). |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
16 |
# |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
17 |
# You should have received a copy of the GNU General Public License version |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
20 |
# |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
22 |
# or visit www.oracle.com if you need additional information or have any |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
23 |
# questions. |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
24 |
# |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
25 |
|
27565 | 26 |
WIN_VERIFY_LIB := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libverify/verify.lib |
13702 | 27 |
|
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
28 |
########################################################################################## |
29374
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
29 |
# libfdlibm is statically linked with libjava below and not delivered into the |
26191
a0ff4b39d34b
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25859
diff
changeset
|
30 |
# product on its own. |
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
31 |
|
20547 | 32 |
BUILD_LIBFDLIBM_OPTIMIZATION := HIGH |
13164 | 33 |
|
34 |
ifneq ($(OPENJDK_TARGET_OS), solaris) |
|
20547 | 35 |
BUILD_LIBFDLIBM_OPTIMIZATION := NONE |
12892 | 36 |
endif |
37 |
||
25859 | 38 |
LIBFDLIBM_SRC := $(JDK_TOPDIR)/src/java.base/share/native/libfdlibm |
39 |
LIBFDLIBM_CFLAGS := -I$(LIBFDLIBM_SRC) |
|
40 |
||
20547 | 41 |
ifneq ($(OPENJDK_TARGET_OS), macosx) |
42 |
$(eval $(call SetupNativeCompilation,BUILD_LIBFDLIBM, \ |
|
43 |
STATIC_LIBRARY := fdlibm, \ |
|
27565 | 44 |
OUTPUT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE), \ |
25859 | 45 |
SRC := $(LIBFDLIBM_SRC), \ |
20547 | 46 |
OPTIMIZATION := $(BUILD_LIBFDLIBM_OPTIMIZATION), \ |
25859 | 47 |
CFLAGS := $(CFLAGS_JDKLIB) $(LIBFDLIBM_CFLAGS), \ |
20547 | 48 |
CFLAGS_windows_debug := -DLOGGING, \ |
22594 | 49 |
CFLAGS_aix := -qfloat=nomaf, \ |
29374
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
50 |
DISABLED_WARNINGS_gcc := sign-compare, \ |
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
51 |
DISABLED_WARNINGS_microsoft := 4146 4244 4018, \ |
20547 | 52 |
ARFLAGS := $(ARFLAGS), \ |
27565 | 53 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libfdlibm, \ |
20547 | 54 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
13164 | 55 |
|
12892 | 56 |
else |
14855
d104ff4d4bb9
8005178: build-infra: Dependency on libfdlibm on mac is broken
erikj
parents:
14789
diff
changeset
|
57 |
|
20890 | 58 |
# On macosx the old build does partial (incremental) linking of fdlibm instead of |
59 |
# a plain static library. |
|
20547 | 60 |
$(eval $(call SetupNativeCompilation,BUILD_LIBFDLIBM_MAC, \ |
61 |
LIBRARY := fdlibm, \ |
|
27565 | 62 |
OUTPUT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libfdlibm, \ |
25859 | 63 |
SRC := $(LIBFDLIBM_SRC), \ |
64 |
CFLAGS := $(CFLAGS_JDKLIB) $(LIBFDLIBM_CFLAGS), \ |
|
20547 | 65 |
LDFLAGS := -nostdlib -r -arch x86_64, \ |
27565 | 66 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libfdlibm, \ |
20547 | 67 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
68 |
||
27565 | 69 |
BUILD_LIBFDLIBM := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/$(LIBRARY_PREFIX)fdlibm$(STATIC_LIBRARY_SUFFIX) |
20547 | 70 |
$(BUILD_LIBFDLIBM): $(BUILD_LIBFDLIBM_MAC) |
16636
1cc691bcfe50
8008373: JFR JTReg tests fail with CompilationError on MacOSX; missing '._sunec.jar'
erikj
parents:
16513
diff
changeset
|
71 |
$(call install-file) |
12892 | 72 |
|
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
73 |
endif |
20890 | 74 |
|
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
75 |
########################################################################################## |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
76 |
|
13164 | 77 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
20547 | 78 |
ifneq ($(OPENJDK_TARGET_CPU), x86_64) |
21805 | 79 |
BUILD_LIBVERIFY_REORDER := $(JDK_TOPDIR)/make/mapfiles/libverify/reorder-$(OPENJDK_TARGET_CPU) |
20547 | 80 |
endif |
13164 | 81 |
endif |
82 |
||
20547 | 83 |
LIBVERIFY_OPTIMIZATION := HIGH |
84 |
ifneq ($(findstring $(OPENJDK_TARGET_OS), solaris linux), ) |
|
85 |
ifeq ($(ENABLE_DEBUG_SYMBOLS), true) |
|
86 |
LIBVERIFY_OPTIMIZATION := LOW |
|
87 |
endif |
|
13702 | 88 |
endif |
89 |
||
20547 | 90 |
$(eval $(call SetupNativeCompilation,BUILD_LIBVERIFY, \ |
91 |
LIBRARY := verify, \ |
|
92 |
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ |
|
25859 | 93 |
SRC := $(JDK_TOPDIR)/src/java.base/share/native/libverify, \ |
20547 | 94 |
OPTIMIZATION := $(LIBVERIFY_OPTIMIZATION), \ |
95 |
CFLAGS := $(CFLAGS_JDKLIB), \ |
|
29374
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
96 |
DISABLED_WARNINGS_microsoft := 4244 4267, \ |
21805 | 97 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libverify/mapfile-vers, \ |
20547 | 98 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
99 |
$(call SET_SHARED_LIBRARY_ORIGIN), \ |
|
27736
8c9bd4be4a86
8058631: Rename posix to unix in build system to match file name changes
ihse
parents:
27186
diff
changeset
|
100 |
LDFLAGS_SUFFIX_unix := -ljvm -lc, \ |
20547 | 101 |
LDFLAGS_SUFFIX_windows := jvm.lib, \ |
25859 | 102 |
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ |
20547 | 103 |
RC_FLAGS := $(RC_FLAGS) \ |
104 |
-D "JDK_FNAME=verify.dll" \ |
|
105 |
-D "JDK_INTERNAL_NAME=verify" \ |
|
106 |
-D "JDK_FTYPE=0x2L", \ |
|
107 |
REORDER := $(BUILD_LIBVERIFY_REORDER), \ |
|
27565 | 108 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libverify, \ |
20547 | 109 |
DEBUG_SYMBOLS := true)) |
13164 | 110 |
|
27565 | 111 |
TARGETS += $(BUILD_LIBVERIFY) |
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
112 |
|
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
113 |
########################################################################################## |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
114 |
|
25859 | 115 |
LIBJAVA_SRC_DIRS := $(call FindSrcDirsForLib, java.base, java) |
20547 | 116 |
|
25859 | 117 |
LIBJAVA_CFLAGS := $(addprefix -I, $(LIBJAVA_SRC_DIRS)) \ |
118 |
-I$(JDK_TOPDIR)/src/java.base/share/native/libfdlibm \ |
|
27565 | 119 |
-I$(SUPPORT_OUTPUTDIR)/headers/java.base \ |
20547 | 120 |
-DARCHPROPNAME='"$(OPENJDK_TARGET_CPU_OSARCH)"' |
13164 | 121 |
|
122 |
LIBJAVA_CFLAGS += -DJDK_MAJOR_VERSION='"$(JDK_MAJOR_VERSION)"' \ |
|
20547 | 123 |
-DJDK_MINOR_VERSION='"$(JDK_MINOR_VERSION)"' \ |
124 |
-DJDK_MICRO_VERSION='"$(JDK_MICRO_VERSION)"' \ |
|
125 |
-DJDK_BUILD_NUMBER='"$(JDK_BUILD_NUMBER)"' |
|
126 |
||
127 |
ifneq (, $(JDK_UPDATE_VERSION)) |
|
128 |
LIBJAVA_CFLAGS += -DJDK_UPDATE_VERSION='"$(JDK_UPDATE_VERSION)"' |
|
13164 | 129 |
endif |
130 |
||
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
131 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
20547 | 132 |
BUILD_LIBJAVA_java_props_md.c_CFLAGS := -x objective-c |
133 |
BUILD_LIBJAVA_java_props_macosx.c_CFLAGS := -x objective-c |
|
13164 | 134 |
endif |
135 |
||
136 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
|
20547 | 137 |
ifneq ($(OPENJDK_TARGET_CPU), x86_64) |
21805 | 138 |
LIBJAVA_REORDER := $(JDK_TOPDIR)/make/mapfiles/libjava/reorder-$(OPENJDK_TARGET_CPU) |
20547 | 139 |
endif |
13164 | 140 |
endif |
141 |
||
20547 | 142 |
$(eval $(call SetupNativeCompilation,BUILD_LIBJAVA, \ |
143 |
LIBRARY := java, \ |
|
144 |
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ |
|
145 |
SRC := $(LIBJAVA_SRC_DIRS), \ |
|
146 |
OPTIMIZATION := HIGH, \ |
|
147 |
CFLAGS := $(CFLAGS_JDKLIB) \ |
|
148 |
$(LIBJAVA_CFLAGS), \ |
|
21805 | 149 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjava/mapfile-vers, \ |
20547 | 150 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
151 |
$(call SET_SHARED_LIBRARY_ORIGIN), \ |
|
27736
8c9bd4be4a86
8058631: Rename posix to unix in build system to match file name changes
ihse
parents:
27186
diff
changeset
|
152 |
LDFLAGS_SUFFIX_unix := -ljvm -lverify, \ |
20547 | 153 |
LDFLAGS_SUFFIX_solaris := -lsocket -lnsl -lscf $(LIBDL) $(BUILD_LIBFDLIBM) -lc, \ |
154 |
LDFLAGS_SUFFIX_linux := $(LIBDL) $(BUILD_LIBFDLIBM), \ |
|
22594 | 155 |
LDFLAGS_SUFFIX_aix := $(LIBDL) $(BUILD_LIBFDLIBM) -lm,\ |
27565 | 156 |
LDFLAGS_SUFFIX_macosx := -L$(SUPPORT_OUTPUTDIR)/native/$(MODULE)/ -lfdlibm \ |
20547 | 157 |
-framework CoreFoundation \ |
158 |
-framework Foundation \ |
|
159 |
-framework Security -framework SystemConfiguration, \ |
|
160 |
LDFLAGS_SUFFIX_windows := -export:winFileHandleOpen -export:handleLseek \ |
|
27184 | 161 |
-export:getLastErrorString \ |
20547 | 162 |
jvm.lib $(BUILD_LIBFDLIBM) $(WIN_VERIFY_LIB) \ |
163 |
shell32.lib delayimp.lib -DELAYLOAD:shell32.dll \ |
|
31246
dfc58fd4feec
8066504: GetVersionEx in java.base/windows/native/libjava/java_props_md.c might not get correct Windows version 0
rriggs
parents:
30784
diff
changeset
|
164 |
advapi32.lib version.lib, \ |
25859 | 165 |
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ |
20547 | 166 |
RC_FLAGS := $(RC_FLAGS) \ |
167 |
-D "JDK_FNAME=java.dll" \ |
|
168 |
-D "JDK_INTERNAL_NAME=java" \ |
|
169 |
-D "JDK_FTYPE=0x2L", \ |
|
170 |
REORDER := $(LIBJAVA_REORDER), \ |
|
27565 | 171 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjava, \ |
20547 | 172 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
13164 | 173 |
|
27565 | 174 |
TARGETS += $(BUILD_LIBJAVA) |
20547 | 175 |
|
176 |
$(BUILD_LIBJAVA): $(BUILD_LIBVERIFY) |
|
177 |
||
178 |
$(BUILD_LIBJAVA): $(BUILD_LIBFDLIBM) |
|
12317
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
179 |
|
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
180 |
########################################################################################## |
9670c1610c53
7074397: Build infrastructure changes (makefile re-write)
ohair
parents:
diff
changeset
|
181 |
|
20547 | 182 |
BUILD_LIBZIP_EXCLUDES := |
183 |
ifeq ($(USE_EXTERNAL_LIBZ), true) |
|
24710
c019dc4104b2
8044725: Bug in zlib 1.2.5 prevents inflation of some gzipped files
sherman
parents:
23562
diff
changeset
|
184 |
LIBZIP_EXCLUDES += zlib-1.2.8 |
20547 | 185 |
endif |
186 |
||
187 |
BUILD_LIBZIP_REORDER := |
|
188 |
ifeq ($(OPENJDK_TARGET_OS), solaris) |
|
189 |
ifneq ($(OPENJDK_TARGET_CPU), x86_64) |
|
21805 | 190 |
BUILD_LIBZIP_REORDER := $(JDK_TOPDIR)/make/mapfiles/libzip/reorder-$(OPENJDK_TARGET_CPU) |
20547 | 191 |
endif |
192 |
endif |
|
193 |
||
194 |
ifeq ($(LIBZIP_CAN_USE_MMAP), true) |
|
195 |
BUILD_LIBZIP_MMAP := -DUSE_MMAP |
|
196 |
endif |
|
197 |
||
198 |
$(eval $(call SetupNativeCompilation,BUILD_LIBZIP, \ |
|
199 |
LIBRARY := zip, \ |
|
200 |
OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ |
|
201 |
OPTIMIZATION := LOW, \ |
|
25859 | 202 |
SRC := $(JDK_TOPDIR)/src/java.base/share/native/libzip, \ |
20547 | 203 |
EXCLUDES := $(LIBZIP_EXCLUDES), \ |
204 |
CFLAGS := $(CFLAGS_JDKLIB) \ |
|
205 |
$(ZLIB_CPPFLAGS) \ |
|
25859 | 206 |
-I$(JDK_TOPDIR)/src/java.base/share/native/libjava \ |
27736
8c9bd4be4a86
8058631: Rename posix to unix in build system to match file name changes
ihse
parents:
27186
diff
changeset
|
207 |
-I$(JDK_TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS_TYPE)/native/libjava \ |
27565 | 208 |
-I$(SUPPORT_OUTPUTDIR)/headers/java.base, \ |
27736
8c9bd4be4a86
8058631: Rename posix to unix in build system to match file name changes
ihse
parents:
27186
diff
changeset
|
209 |
CFLAGS_unix := $(BUILD_LIBZIP_MMAP) -UDEBUG, \ |
29374
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
210 |
DISABLED_WARNINGS_gcc := parentheses, \ |
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
211 |
DISABLED_WARNINGS_clang := dangling-else, \ |
f031a666744a
8074096: Disable (most) native warnings in JDK on a per-library basis
ihse
parents:
28999
diff
changeset
|
212 |
DISABLED_WARNINGS_microsoft := 4267, \ |
21805 | 213 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libzip/mapfile-vers, \ |
20547 | 214 |
REORDER := $(BUILD_LIBZIP_REORDER), \ |
215 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
|
216 |
$(call SET_SHARED_LIBRARY_ORIGIN) \ |
|
217 |
$(EXPORT_ZIP_FUNCS), \ |
|
218 |
LDFLAGS_windows := -export:ZIP_Open -export:ZIP_Close -export:ZIP_FindEntry \ |
|
27565 | 219 |
-export:ZIP_ReadEntry -export:ZIP_GetNextEntry \ |
220 |
-export:ZIP_InflateFully -export:ZIP_CRC32 \ |
|
221 |
jvm.lib $(WIN_JAVA_LIB), \ |
|
20547 | 222 |
LDFLAGS_SUFFIX_linux := -ljvm -ljava $(LIBZ), \ |
223 |
LDFLAGS_SUFFIX_solaris := -ljvm -ljava $(LIBZ) -lc, \ |
|
22595
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
224 |
LDFLAGS_SUFFIX_aix := -ljvm -ljava $(LIBZ),\ |
20547 | 225 |
LDFLAGS_SUFFIX_macosx := $(LIBZ) -ljava -ljvm, \ |
25859 | 226 |
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ |
20547 | 227 |
RC_FLAGS := $(RC_FLAGS) \ |
228 |
-D "JDK_FNAME=zip.dll" \ |
|
229 |
-D "JDK_INTERNAL_NAME=zip" \ |
|
230 |
-D "JDK_FTYPE=0x2L", \ |
|
27565 | 231 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libzip, \ |
20547 | 232 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
233 |
||
234 |
||
235 |
$(BUILD_LIBZIP): $(BUILD_LIBJAVA) |
|
236 |
||
27565 | 237 |
TARGETS += $(BUILD_LIBZIP) |
20547 | 238 |
|
239 |
########################################################################################## |
|
240 |
||
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
241 |
LIBJLI_SRC_DIRS := $(call FindSrcDirsForLib, java.base, jli) |
22951
5fd21112b2b6
8034043: Native methods for preferences API should not be in libjava
alanb
parents:
22941
diff
changeset
|
242 |
|
25859 | 243 |
LIBJLI_CFLAGS := $(CFLAGS_JDKLIB) |
20547 | 244 |
|
245 |
ifeq ($(JVM_VARIANT_ZERO), true) |
|
246 |
ERGO_FAMILY := zero |
|
247 |
else |
|
248 |
ifeq ($(OPENJDK_TARGET_CPU_ARCH), x86) |
|
249 |
ERGO_FAMILY := i586 |
|
250 |
else |
|
251 |
ERGO_FAMILY := $(OPENJDK_TARGET_CPU_ARCH) |
|
252 |
endif |
|
253 |
endif |
|
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
254 |
LIBJLI_ALL_ERGO := $(wildcard $(addsuffix /ergo_*.c, $(LIBJLI_SRC_DIRS))) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
255 |
LIBJLI_EXCLUDE_ERGO := $(filter-out %/ergo_$(ERGO_FAMILY).c, $(LIBJLI_ALL_ERGO)) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
256 |
# If all specialized ergo files are excluded, use generic ergo |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
257 |
ifeq ($(LIBJLI_ALL_ERGO), $(LIBJLI_EXCLUDE_ERGO)) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
258 |
LIBJLI_CFLAGS += -DUSE_GENERIC_ERGO |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
259 |
endif |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
260 |
LIBJLI_EXCLUDE_FILES += $(notdir $(LIBJLI_EXCLUDE_ERGO)) |
20547 | 261 |
|
262 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
29742
b73f38796859
8074840: Resolve disabled warnings for libjli and libjli_static
mikael
parents:
29374
diff
changeset
|
263 |
LIBJLI_EXCLUDE_FILES += java_md_solinux.c ergo.c ergo_i586.c |
20547 | 264 |
|
265 |
BUILD_LIBJLI_java_md_macosx.c_CFLAGS := -x objective-c |
|
266 |
BUILD_LIBJLI_STATIC_java_md_macosx.c_CFLAGS := -x objective-c |
|
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
267 |
|
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
268 |
LIBJLI_CFLAGS += -DPACKAGE_PATH=\"$(PACKAGE_PATH)\" |
20547 | 269 |
endif |
270 |
||
271 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
272 |
# Staticically link with c runtime on windows. |
|
273 |
LIBJLI_CFLAGS := $(filter-out -MD, $(LIBJLI_CFLAGS)) |
|
274 |
LIBJLI_OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE) |
|
28984
12031ba2dc38
8042707: Source changes needed to build JDK 9 with Visual Studio 2013 (VS2013)
erikj
parents:
27799
diff
changeset
|
275 |
# Supply the name of the C runtime lib. |
12031ba2dc38
8042707: Source changes needed to build JDK 9 with Visual Studio 2013 (VS2013)
erikj
parents:
27799
diff
changeset
|
276 |
LIBJLI_CFLAGS += -DMSVCR_DLL_NAME='"$(notdir $(MSVCR_DLL))"' |
12031ba2dc38
8042707: Source changes needed to build JDK 9 with Visual Studio 2013 (VS2013)
erikj
parents:
27799
diff
changeset
|
277 |
ifneq ($(MSVCP_DLL), ) |
12031ba2dc38
8042707: Source changes needed to build JDK 9 with Visual Studio 2013 (VS2013)
erikj
parents:
27799
diff
changeset
|
278 |
LIBJLI_CFLAGS += -DMSVCP_DLL_NAME='"$(notdir $(MSVCP_DLL))"' |
12031ba2dc38
8042707: Source changes needed to build JDK 9 with Visual Studio 2013 (VS2013)
erikj
parents:
27799
diff
changeset
|
279 |
endif |
20547 | 280 |
else |
281 |
LIBJLI_OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE)/jli |
|
282 |
endif |
|
283 |
||
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
284 |
LIBJLI_CFLAGS += $(addprefix -I, $(LIBJLI_SRC_DIRS)) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
285 |
|
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
286 |
# Append defines depending on target platform |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
287 |
LIBJLI_CFLAGS += $(OPENJDK_TARGET_CPU_JLI_CFLAGS) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
288 |
|
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
289 |
ifneq ($(USE_EXTERNAL_LIBZ), true) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
290 |
LIBJLI_CFLAGS += $(ZLIB_CPPFLAGS) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
291 |
LIBJLI_EXTRA_FILES += \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
292 |
$(addprefix $(JDK_TOPDIR)/src/java.base/share/native/libzip/zlib-1.2.8/, \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
293 |
inflate.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
294 |
inftrees.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
295 |
inffast.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
296 |
zadler32.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
297 |
zcrc32.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
298 |
zutil.c \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
299 |
) |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
300 |
endif |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
301 |
|
20547 | 302 |
$(eval $(call SetupNativeCompilation,BUILD_LIBJLI, \ |
303 |
LIBRARY := jli, \ |
|
304 |
OUTPUT_DIR := $(LIBJLI_OUTPUT_DIR), \ |
|
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
305 |
SRC := $(LIBJLI_SRC_DIRS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
306 |
EXCLUDE_FILES := $(LIBJLI_EXCLUDE_FILES), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
307 |
EXTRA_FILES := $(LIBJLI_EXTRA_FILES), \ |
20547 | 308 |
OPTIMIZATION := HIGH, \ |
309 |
CFLAGS := $(LIBJLI_CFLAGS), \ |
|
29742
b73f38796859
8074840: Resolve disabled warnings for libjli and libjli_static
mikael
parents:
29374
diff
changeset
|
310 |
DISABLED_WARNINGS_solstudio := E_ASM_DISABLES_OPTIMIZATION, \ |
21805 | 311 |
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjli/mapfile-vers, \ |
20547 | 312 |
LDFLAGS := $(LDFLAGS_JDKLIB) \ |
313 |
$(call SET_SHARED_LIBRARY_ORIGIN), \ |
|
314 |
LDFLAGS_linux := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ |
|
315 |
LDFLAGS_solaris := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ |
|
316 |
LDFLAGS_macosx := -framework Cocoa -framework Security -framework ApplicationServices, \ |
|
317 |
LDFLAGS_SUFFIX_solaris := $(LIBZ) $(LIBDL) -lc, \ |
|
21606 | 318 |
LDFLAGS_SUFFIX_linux := $(LIBZ) $(LIBDL) -lc -lpthread, \ |
22595
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
319 |
LDFLAGS_SUFFIX_aix := $(LIBZ) $(LIBDL),\ |
20547 | 320 |
LDFLAGS_SUFFIX_macosx := $(LIBZ), \ |
321 |
LDFLAGS_SUFFIX_windows := \ |
|
322 |
-export:JLI_Launch \ |
|
323 |
-export:JLI_ManifestIterate \ |
|
324 |
-export:JLI_SetTraceLauncher \ |
|
325 |
-export:JLI_ReportErrorMessage \ |
|
326 |
-export:JLI_ReportErrorMessageSys \ |
|
327 |
-export:JLI_ReportMessage \ |
|
328 |
-export:JLI_ReportExceptionDescription \ |
|
329 |
-export:JLI_MemAlloc \ |
|
330 |
-export:JLI_CmdToArgs \ |
|
331 |
-export:JLI_GetStdArgc \ |
|
332 |
-export:JLI_GetStdArgs \ |
|
333 |
advapi32.lib \ |
|
334 |
comctl32.lib \ |
|
335 |
user32.lib, \ |
|
25859 | 336 |
VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ |
20547 | 337 |
RC_FLAGS := $(RC_FLAGS) \ |
338 |
-D "JDK_FNAME=jli.dll" \ |
|
339 |
-D "JDK_INTERNAL_NAME=jli" \ |
|
340 |
-D "JDK_FTYPE=0x2L", \ |
|
27565 | 341 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli, \ |
20547 | 342 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
343 |
||
27565 | 344 |
TARGETS += $(BUILD_LIBJLI) |
20547 | 345 |
|
346 |
# On windows, the static library has the same suffix as the import library created by |
|
347 |
# with the shared library, so the static library is given a different name. No harm |
|
348 |
# in doing it for all platform to reduce complexity. |
|
349 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
350 |
$(eval $(call SetupNativeCompilation,BUILD_LIBJLI_STATIC, \ |
|
351 |
STATIC_LIBRARY := jli_static, \ |
|
27565 | 352 |
OUTPUT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE), \ |
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
353 |
SRC := $(LIBJLI_SRC_DIRS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
354 |
EXCLUDE_FILES := $(LIBJLI_EXCLUDE_FILES), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
355 |
EXTRA_FILES := $(LIBJLI_EXTRA_FILES), \ |
20547 | 356 |
OPTIMIZATION := HIGH, \ |
357 |
CFLAGS := $(STATIC_LIBRARY_FLAGS) $(LIBJLI_CFLAGS), \ |
|
358 |
ARFLAGS := $(ARFLAGS), \ |
|
27565 | 359 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli_static, \ |
20547 | 360 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
361 |
||
27565 | 362 |
TARGETS += $(BUILD_LIBJLI_STATIC) |
20547 | 363 |
|
364 |
else ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
365 |
# |
|
366 |
# On macosx they do partial (incremental) linking of libjli_static.a |
|
367 |
# code it here...rather than add support to NativeCompilation |
|
368 |
# as this is first time I see it |
|
369 |
$(eval $(call SetupNativeCompilation,BUILD_LIBJLI_STATIC, \ |
|
370 |
LIBRARY := jli_static, \ |
|
27565 | 371 |
OUTPUT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE), \ |
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
372 |
SRC := $(LIBJLI_SRC_DIRS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
373 |
EXCLUDE_FILES := $(LIBJLI_EXCLUDE_FILES), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
374 |
EXTRA_FILES := $(LIBJLI_EXTRA_FILES), \ |
20547 | 375 |
OPTIMIZATION := HIGH, \ |
376 |
CFLAGS := $(CFLAGS_JDKLIB) $(LIBJLI_CFLAGS), \ |
|
377 |
LDFLAGS := -nostdlib -r, \ |
|
27565 | 378 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli_static, \ |
20547 | 379 |
DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) |
380 |
||
27565 | 381 |
$(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli_static.a: $(BUILD_LIBJLI_STATIC) |
20547 | 382 |
$(call install-file) |
383 |
||
27565 | 384 |
TARGETS += $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli_static.a |
22595
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
385 |
|
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
386 |
else ifeq ($(OPENJDK_TARGET_OS), aix) |
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
387 |
# AIX also requires a static libjli because the compiler doesn't support '-rpath' |
28658
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
388 |
$(eval $(call SetupNativeCompilation,BUILD_LIBJLI_STATIC, \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
389 |
STATIC_LIBRARY := jli_static, \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
390 |
OUTPUT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
391 |
SRC := $(LIBJLI_SRC_DIRS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
392 |
EXCLUDE_FILES := $(LIBJLI_EXCLUDE_FILES), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
393 |
EXTRA_FILES := $(LIBJLI_EXTRA_FILES), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
394 |
OPTIMIZATION := HIGH, \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
395 |
CFLAGS := $(STATIC_LIBRARY_FLAGS) $(LIBJLI_CFLAGS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
396 |
ARFLAGS := $(ARFLAGS), \ |
344426303820
8055190: Cleanup include and exclude of core-libs native libraries after source code restructure
erikj
parents:
27799
diff
changeset
|
397 |
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjli_static)) |
22595
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
398 |
|
27565 | 399 |
TARGETS += $(BUILD_LIBJLI_STATIC) |
22595
aaa6b141196c
8028066: PPC64: 8025715 changes broke AIX build after sync
simonis
parents:
22594
diff
changeset
|
400 |
|
20547 | 401 |
endif |