author | dfuchs |
Wed, 09 May 2018 16:45:54 -0700 | |
branch | http-client-branch |
changeset 56538 | 9bdcfc7d2b9c |
parent 49534 | 210cf224b690 |
child 50126 | 98f57dff16f3 |
child 56421 | 92bea2b7732a |
permissions | -rw-r--r-- |
25859 | 1 |
# |
49070
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47217
diff
changeset
|
2 |
# Copyright (c) 2011, 2018, 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 |
||
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
26 |
include JdkNativeCompilation.gmk |
25859 | 27 |
|
28 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
|
29 |
ORIGIN_ARG := $(call SET_EXECUTABLE_ORIGIN) |
|
30 |
else |
|
35781 | 31 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
32 |
endif |
|
42753
40f61533b93d
8066474: Remove the lib/ directory from Linux and Solaris images
erikj
parents:
36511
diff
changeset
|
33 |
ORIGIN_ARG := $(call SET_EXECUTABLE_ORIGIN,/../lib/jli) |
25859 | 34 |
|
33523 | 35 |
# Applications expect to be able to link against libjawt without invoking |
36 |
# System.loadLibrary("jawt") first. This was the behaviour described in the |
|
37 |
# devloper documentation of JAWT and what worked with OpenJDK6. |
|
38 |
ifneq ($(findstring $(OPENJDK_TARGET_OS), linux solaris), ) |
|
42753
40f61533b93d
8066474: Remove the lib/ directory from Linux and Solaris images
erikj
parents:
36511
diff
changeset
|
39 |
ORIGIN_ARG += $(call SET_EXECUTABLE_ORIGIN,/../lib) |
33523 | 40 |
endif |
25859 | 41 |
endif |
42 |
||
49534 | 43 |
# Tell the compiler not to export any functions unless declared so in |
44 |
# the source code. On Windows, this is the default and cannot be changed. |
|
45 |
# On Mac, we have always exported all symbols, probably due to oversight |
|
46 |
# and/or misunderstanding. To emulate this, don't hide any symbols |
|
47 |
# by default. |
|
48 |
# Also provide an override for non-conformant libraries. |
|
49 |
ifeq ($(TOOLCHAIN_TYPE), gcc) |
|
50 |
LAUNCHER_CFLAGS += -fvisibility=hidden |
|
51 |
LDFLAGS_JDKEXE += -Wl,--exclude-libs,ALL |
|
52 |
else ifeq ($(TOOLCHAIN_TYPE), clang) |
|
53 |
ifneq ($(OPENJDK_TARGET_OS), macosx) |
|
54 |
LAUNCHER_CFLAGS += -fvisibility=hidden |
|
55 |
endif |
|
56 |
else ifeq ($(TOOLCHAIN_TYPE), solstudio) |
|
57 |
LAUNCHER_CFLAGS += -xldscope=hidden |
|
58 |
else ifeq ($(TOOLCHAIN_TYPE), xlc) |
|
59 |
LAUNCHER_CFLAGS += -qvisibility=hidden |
|
60 |
endif |
|
61 |
||
47217 | 62 |
LAUNCHER_SRC := $(TOPDIR)/src/java.base/share/native/launcher |
49534 | 63 |
LAUNCHER_CFLAGS += -I$(TOPDIR)/src/java.base/share/native/launcher \ |
47217 | 64 |
-I$(TOPDIR)/src/java.base/share/native/libjli \ |
65 |
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS_TYPE)/native/libjli \ |
|
66 |
-I$(TOPDIR)/src/java.base/$(OPENJDK_TARGET_OS)/native/libjli \ |
|
25859 | 67 |
# |
47217 | 68 |
GLOBAL_VERSION_INFO_RESOURCE := $(TOPDIR)/src/java.base/windows/native/common/version.rc |
69 |
JAVA_VERSION_INFO_RESOURCE := $(TOPDIR)/src/java.base/windows/native/launcher/java.rc |
|
70 |
MACOSX_PLIST_DIR := $(TOPDIR)/src/java.base/macosx/native/launcher |
|
71 |
JAVA_MANIFEST := $(TOPDIR)/src/java.base/windows/native/launcher/java.manifest |
|
25859 | 72 |
|
33523 | 73 |
################################################################################ |
74 |
# Build standard launcher. |
|
25859 | 75 |
|
33523 | 76 |
# Setup make rules for building a standard launcher. |
77 |
# |
|
78 |
# Parameter 1 is the name of the rule. This name is used as variable prefix, |
|
79 |
# and the targets generated are listed in a variable by that name. It is also |
|
80 |
# used as the name of the executable. |
|
81 |
# |
|
82 |
# Remaining parameters are named arguments. These include: |
|
36511 | 83 |
# MAIN_MODULE The module of the main class to launch if different from the |
84 |
# current module |
|
33523 | 85 |
# MAIN_CLASS The Java main class to launch |
45463
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
86 |
# JAVA_ARGS Processed into a -DJAVA_ARGS and added to CFLAGS |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
87 |
# EXTRA_JAVA_ARGS Processed into a -DEXTRA_JAVA_ARGS and is prepended |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
88 |
# before JAVA_ARGS to CFLAGS, primarily to allow long string literal |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
89 |
# compile time defines exceeding Visual Studio 2013 limitations. |
33523 | 90 |
# CFLAGS Additional CFLAGS |
91 |
# CFLAGS_windows Additional CFLAGS_windows |
|
92 |
# LIBS_unix Additional LIBS_unix |
|
93 |
# LIBS_windows Additional LIBS_windows |
|
94 |
# LDFLAGS_solaris Additional LDFLAGS_solaris |
|
95 |
# RC_FLAGS Additional RC_FLAGS |
|
96 |
# MACOSX_SIGNED On macosx, sign this binary |
|
97 |
# WINDOWS_STATIC_LINK On windows, link statically with C runtime and libjli. |
|
98 |
# OPTIMIZATION Override default optimization level (LOW) |
|
99 |
# OUTPUT_DIR Override default output directory |
|
100 |
# VERSION_INFO_RESOURCE Override default Windows resource file |
|
101 |
# NO_JAVA_MS Do not add -ms8m to JAVA_ARGS. |
|
102 |
SetupBuildLauncher = $(NamedParamsMacroTemplate) |
|
103 |
define SetupBuildLauncherBody |
|
104 |
# Setup default values (unless overridden) |
|
105 |
ifeq ($$($1_OPTIMIZATION), ) |
|
106 |
$1_OPTIMIZATION := LOW |
|
107 |
endif |
|
108 |
||
109 |
ifneq ($$($1_NO_JAVA_MS), true) |
|
110 |
# The norm is to append -ms8m, unless otherwise instructed. |
|
111 |
$1_JAVA_ARGS += -ms8m |
|
112 |
endif |
|
113 |
||
36511 | 114 |
ifeq ($$($1_MAIN_MODULE), ) |
115 |
$1_MAIN_MODULE := $(MODULE) |
|
116 |
endif |
|
117 |
||
33523 | 118 |
ifneq ($$($1_JAVA_ARGS), ) |
45463
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
119 |
ifneq ($$($1_EXTRA_JAVA_ARGS), ) |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
120 |
$1_EXTRA_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \ |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
121 |
$$(addprefix -J, $$($1_EXTRA_JAVA_ARGS)), "$$a"$(COMMA) )) }' |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
122 |
$1_CFLAGS += -DEXTRA_JAVA_ARGS=$$($1_EXTRA_JAVA_ARGS_STR) |
d9325138bac6
8180334: Unable to build jaotc launcher on windows
ksrini
parents:
42753
diff
changeset
|
123 |
endif |
33523 | 124 |
$1_JAVA_ARGS_STR := '{ $$(strip $$(foreach a, \ |
36511 | 125 |
$$(addprefix -J, $$($1_JAVA_ARGS)) -m $$($1_MAIN_MODULE)/$$($1_MAIN_CLASS), "$$a"$(COMMA) )) }' |
33523 | 126 |
$1_CFLAGS += -DJAVA_ARGS=$$($1_JAVA_ARGS_STR) |
127 |
endif |
|
128 |
||
33406 | 129 |
$1_LIBS := |
25859 | 130 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
33523 | 131 |
ifeq ($$($1_MACOSX_SIGNED), true) |
132 |
$1_PLIST_FILE := Info-privileged.plist |
|
25859 | 133 |
$1_CODESIGN := true |
33523 | 134 |
else |
135 |
$1_PLIST_FILE := Info-cmdline.plist |
|
25859 | 136 |
endif |
137 |
||
33523 | 138 |
$1_CFLAGS += -DPACKAGE_PATH='"$(PACKAGE_PATH)"' |
33666 | 139 |
$1_LDFLAGS += -Wl,-all_load \ |
25859 | 140 |
-sectcreate __TEXT __info_plist $(MACOSX_PLIST_DIR)/$$($1_PLIST_FILE) |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
141 |
ifeq ($(STATIC_BUILD), true) |
33666 | 142 |
$1_LDFLAGS += -exported_symbols_list \ |
143 |
$(SUPPORT_OUTPUTDIR)/build-static/exported.symbols |
|
144 |
$1_LIBS += \ |
|
35241 | 145 |
$$(shell $(FIND) $(SUPPORT_OUTPUTDIR)/modules_libs/java.base -name "*.a") \ |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
146 |
$(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libdt_socket.a \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
147 |
$(SUPPORT_OUTPUTDIR)/modules_libs/jdk.jdwp.agent/libjdwp.a \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
148 |
$(SUPPORT_OUTPUTDIR)/native/java.base/$(LIBRARY_PREFIX)fdlibm$(STATIC_LIBRARY_SUFFIX) \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
149 |
-framework CoreFoundation \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
150 |
-framework Foundation \ |
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
151 |
-framework SystemConfiguration \ |
33666 | 152 |
-lstdc++ -liconv |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
153 |
else |
33666 | 154 |
$1_LIBS += $(SUPPORT_OUTPUTDIR)/native/java.base/libjli_static.a |
33653
c1ee09fe3274
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32515
diff
changeset
|
155 |
endif |
33406 | 156 |
$1_LIBS += -framework Cocoa -framework Security \ |
157 |
-framework ApplicationServices |
|
25859 | 158 |
endif |
159 |
||
160 |
ifeq ($(OPENJDK_TARGET_OS), aix) |
|
33406 | 161 |
$1_LDFLAGS += -L$(SUPPORT_OUTPUTDIR)/native/java.base |
162 |
$1_LIBS += -ljli_static |
|
25859 | 163 |
endif |
164 |
||
165 |
ifeq ($(USE_EXTERNAL_LIBZ), true) |
|
33406 | 166 |
$1_LIBS += -lz |
25859 | 167 |
endif |
168 |
||
33523 | 169 |
ifeq ($$($1_WINDOWS_STATIC_LINK), true) |
170 |
$1_CFLAGS += $(filter-out -MD, $(CFLAGS_JDKEXE)) |
|
171 |
$1_WINDOWS_JLI_LIB := $(SUPPORT_OUTPUTDIR)/native/java.base/jli_static.lib |
|
25859 | 172 |
else |
33523 | 173 |
$1_CFLAGS += $(CFLAGS_JDKEXE) |
174 |
$1_WINDOWS_JLI_LIB := $(SUPPORT_OUTPUTDIR)/native/java.base/libjli/jli.lib |
|
25859 | 175 |
endif |
176 |
||
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
177 |
$$(eval $$(call SetupJdkExecutable, BUILD_LAUNCHER_$1, \ |
49070
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47217
diff
changeset
|
178 |
NAME := $1, \ |
35241 | 179 |
EXTRA_FILES := $(LAUNCHER_SRC)/main.c, \ |
33523 | 180 |
OPTIMIZATION := $$($1_OPTIMIZATION), \ |
25859 | 181 |
CFLAGS := $$($1_CFLAGS) \ |
182 |
$(LAUNCHER_CFLAGS) \ |
|
33984
2333676816eb
8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents:
29931
diff
changeset
|
183 |
$(VERSION_CFLAGS) \ |
25859 | 184 |
-DLAUNCHER_NAME='"$(LAUNCHER_NAME)"' \ |
33523 | 185 |
-DPROGNAME='"$1"' \ |
186 |
$$($1_CFLAGS), \ |
|
25859 | 187 |
CFLAGS_linux := -fPIC, \ |
188 |
CFLAGS_solaris := -KPIC -DHAVE_GETHRTIME, \ |
|
33523 | 189 |
CFLAGS_windows := $$($1_CFLAGS_windows), \ |
34695
7a6cc9982d22
8142907: Integration of minor fixes from the build-infra project
ihse
parents:
34389
diff
changeset
|
190 |
LDFLAGS := $$(LDFLAGS_JDKEXE) \ |
33523 | 191 |
$$(ORIGIN_ARG) \ |
25859 | 192 |
$$($1_LDFLAGS), \ |
33406 | 193 |
LDFLAGS_linux := \ |
42753
40f61533b93d
8066474: Remove the lib/ directory from Linux and Solaris images
erikj
parents:
36511
diff
changeset
|
194 |
-L$(SUPPORT_OUTPUTDIR)/modules_libs/java.base/jli, \ |
25859 | 195 |
LDFLAGS_solaris := $$($1_LDFLAGS_solaris) \ |
42753
40f61533b93d
8066474: Remove the lib/ directory from Linux and Solaris images
erikj
parents:
36511
diff
changeset
|
196 |
-L$(SUPPORT_OUTPUTDIR)/modules_libs/java.base/jli, \ |
33406 | 197 |
LIBS := $(JDKEXE_LIBS) $$($1_LIBS), \ |
33523 | 198 |
LIBS_unix := $$($1_LIBS_unix), \ |
49241 | 199 |
LIBS_linux := -lpthread -ljli $(LIBDL), \ |
200 |
LIBS_solaris := -ljli -lthread $(LIBDL), \ |
|
33406 | 201 |
LIBS_windows := $$($1_WINDOWS_JLI_LIB) \ |
33523 | 202 |
$(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib advapi32.lib \ |
203 |
$$($1_LIBS_windows), \ |
|
204 |
OUTPUT_DIR := $$($1_OUTPUT_DIR), \ |
|
25859 | 205 |
VERSIONINFO_RESOURCE := $$($1_VERSION_INFO_RESOURCE), \ |
49244
995a5556edfa
8199639: Introduce SetupJdkLibrary and SetupJdkExecutable
ihse
parents:
49241
diff
changeset
|
206 |
EXTRA_RC_FLAGS := $$($1_EXTRA_RC_FLAGS), \ |
25859 | 207 |
MANIFEST := $(JAVA_MANIFEST), \ |
33984
2333676816eb
8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents:
29931
diff
changeset
|
208 |
MANIFEST_VERSION := $(VERSION_NUMBER_FOUR_POSITIONS), \ |
29925
6d47adfc6b47
8077847: Better handling of Windows executable manifest version
ihse
parents:
27953
diff
changeset
|
209 |
CODESIGN := $$($1_CODESIGN), \ |
33523 | 210 |
)) |
25859 | 211 |
|
33523 | 212 |
$1 += $$(BUILD_LAUNCHER_$1) |
213 |
TARGETS += $$($1) |
|
25859 | 214 |
|
215 |
ifneq (,$(filter $(OPENJDK_TARGET_OS), macosx aix)) |
|
27565 | 216 |
$$(BUILD_LAUNCHER_$1): $(SUPPORT_OUTPUTDIR)/native/java.base/libjli_static.a |
25859 | 217 |
endif |
218 |
||
219 |
ifeq ($(OPENJDK_TARGET_OS), windows) |
|
27565 | 220 |
$$(BUILD_LAUNCHER_$1): $(SUPPORT_OUTPUTDIR)/native/java.base/libjava/java.lib \ |
25859 | 221 |
$$($1_WINDOWS_JLI_LIB) |
222 |
endif |
|
223 |
endef |