author | plevart |
Sat, 13 Jul 2019 10:43:45 +0000 | |
changeset 55697 | 7fd4446c02ee |
parent 55292 | f4b2d5b83ebf |
child 55447 | 95794e32352e |
permissions | -rw-r--r-- |
14111 | 1 |
# |
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
2 |
# Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. |
14111 | 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 |
||
25854 | 26 |
################################################################################ |
27 |
# This is the main makefile containing most actual top level targets. It needs |
|
28 |
# to be called with a SPEC file defined. |
|
29662 | 29 |
################################################################################ |
25854 | 30 |
|
31 |
# Declare default target |
|
32 |
default: |
|
14111 | 33 |
|
29662 | 34 |
ifeq ($(wildcard $(SPEC)),) |
35 |
$(error Main.gmk needs SPEC set to a proper spec.gmk) |
|
36 |
endif |
|
37 |
||
14111 | 38 |
# Now load the spec |
39 |
include $(SPEC) |
|
40 |
||
47217 | 41 |
include $(TOPDIR)/make/MainSupport.gmk |
25854 | 42 |
|
20363 | 43 |
# Load the vital tools for all the makefiles. |
47217 | 44 |
include $(TOPDIR)/make/common/MakeBase.gmk |
45 |
include $(TOPDIR)/make/common/Modules.gmk |
|
46 |
include $(TOPDIR)/make/common/FindTests.gmk |
|
14111 | 47 |
|
25854 | 48 |
# Declare ALL_TARGETS as an immediate variable. This variable is a list of all |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
49 |
# valid top level targets. It's used to declare them all as PHONY and to |
25854 | 50 |
# generate the -only targets. |
51 |
ALL_TARGETS := |
|
52 |
||
22714
a752920c4317
8034191: Move relevant parts of build system to new closed repo
ihse
parents:
22031
diff
changeset
|
53 |
# Hook to include the corresponding custom file, if present. |
47314 | 54 |
$(eval $(call IncludeCustomExtension, Main.gmk)) |
14111 | 55 |
|
25854 | 56 |
# All modules for the current target platform. |
34116
b746e382da18
8142336: Convert the SA agent build to modular build-infra makefiles
erikj
parents:
33722
diff
changeset
|
57 |
ALL_MODULES := $(call FindAllModules) |
25854 | 58 |
|
59 |
################################################################################ |
|
60 |
################################################################################ |
|
61 |
# |
|
62 |
# Recipes for all targets. Only recipes, dependencies are declared later. |
|
63 |
# |
|
64 |
################################################################################ |
|
65 |
||
66 |
################################################################################ |
|
67 |
# Interim/build tools targets, compiling tools used during the build |
|
68 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
69 |
buildtools-langtools: |
47217 | 70 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ToolsLangtools.gmk) |
27560 | 71 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
72 |
interim-langtools: |
47217 | 73 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimLangtools.gmk) |
25854 | 74 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
75 |
interim-rmic: |
47217 | 76 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimRmic.gmk) |
25854 | 77 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
78 |
interim-cldrconverter: |
47217 | 79 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopyInterimCLDRConverter.gmk) |
31948 | 80 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
81 |
buildtools-jdk: |
47217 | 82 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileToolsJdk.gmk) |
41171 | 83 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
84 |
buildtools-modules: |
47217 | 85 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileModuleTools.gmk) |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
86 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
87 |
buildtools-hotspot: |
47217 | 88 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileToolsHotspot.gmk) |
25854 | 89 |
|
32806 | 90 |
ALL_TARGETS += buildtools-langtools interim-langtools \ |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
91 |
interim-rmic interim-cldrconverter buildtools-jdk buildtools-modules \ |
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
92 |
buildtools-hotspot |
25854 | 93 |
|
94 |
################################################################################ |
|
95 |
# Special targets for certain modules |
|
96 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
97 |
generate-exported-symbols: |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
98 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f BuildStatic.gmk) |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
99 |
|
50312 | 100 |
ALL_TARGETS += generate-exported-symbols |
14111 | 101 |
|
25854 | 102 |
################################################################################ |
103 |
# Gensrc targets, generating source before java compilation can be done |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
104 |
# |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
105 |
$(eval $(call DeclareRecipesForPhase, GENSRC, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
106 |
TARGET_SUFFIX := gensrc-src, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
107 |
FILE_PREFIX := Gensrc, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
108 |
MAKE_SUBDIR := gensrc, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
109 |
CHECK_MODULES := $(ALL_MODULES), \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
110 |
)) |
47217 | 111 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
112 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-gensrc: $m-gensrc-src)) |
14111 | 113 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
114 |
LANGTOOLS_GENSRC_TARGETS := $(filter $(addsuffix -%, $(LANGTOOLS_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
115 |
INTERIM_LANGTOOLS_GENSRC_TARGETS := $(filter $(addsuffix -%, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
116 |
$(INTERIM_LANGTOOLS_BASE_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
117 |
HOTSPOT_GENSRC_TARGETS := $(filter $(addsuffix -%, $(HOTSPOT_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
118 |
JDK_GENSRC_TARGETS := $(filter-out $(LANGTOOLS_GENSRC_TARGETS) \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
119 |
$(HOTSPOT_GENSRC_TARGETS), $(GENSRC_TARGETS)) |
15053
64278cb83950
8005549: build-infra: Merge NewMakefile.gmk and common/makefiles/Makefile
erikj
parents:
14466
diff
changeset
|
120 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
121 |
GENSRC_MODULEINFO_MODULES := $(ALL_MODULES) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
122 |
GENSRC_MODULEINFO_TARGETS := $(addsuffix -gensrc-moduleinfo, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
123 |
$(GENSRC_MODULEINFO_MODULES)) |
36506 | 124 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
125 |
GENSRC_MODULES := $(GENSRC_MODULEINFO_MODULES) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
126 |
GENSRC_TARGETS += $(sort $(GENSRC_MODULEINFO_TARGETS) \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
127 |
$(addsuffix -gensrc, $(GENSRC_MODULES))) |
36506 | 128 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
129 |
define DeclareModuleInfoRecipe |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
130 |
$1-gensrc-moduleinfo: |
47217 | 131 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
36506 | 132 |
-f GensrcModuleInfo.gmk MODULE=$1) |
133 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
134 |
$1-gensrc: $1-gensrc-moduleinfo |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
135 |
endef |
36506 | 136 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
137 |
$(foreach m, $(GENSRC_MODULEINFO_MODULES), $(eval $(call DeclareModuleInfoRecipe,$m))) |
36506 | 138 |
|
25854 | 139 |
ALL_TARGETS += $(GENSRC_TARGETS) |
140 |
||
141 |
################################################################################ |
|
142 |
# Generate data targets |
|
27560 | 143 |
$(eval $(call DeclareRecipesForPhase, GENDATA, \ |
144 |
TARGET_SUFFIX := gendata, \ |
|
145 |
FILE_PREFIX := Gendata, \ |
|
146 |
MAKE_SUBDIR := gendata, \ |
|
147 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
148 |
USE_WRAPPER := true)) |
|
25854 | 149 |
|
150 |
ALL_TARGETS += $(GENDATA_TARGETS) |
|
151 |
||
152 |
################################################################################ |
|
153 |
# Copy files targets |
|
27560 | 154 |
$(eval $(call DeclareRecipesForPhase, COPY, \ |
155 |
TARGET_SUFFIX := copy, \ |
|
156 |
FILE_PREFIX := Copy, \ |
|
157 |
MAKE_SUBDIR := copy, \ |
|
158 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
159 |
USE_WRAPPER := true, \ |
47217 | 160 |
)) |
25854 | 161 |
|
36506 | 162 |
ALL_COPY_MODULES += $(COPY_MODULES) |
163 |
ALL_COPY_TARGETS += $(COPY_TARGETS) |
|
164 |
||
165 |
IMPORT_COPY_MODULES := $(call FindImportedModules) |
|
166 |
IMPORT_COPY_TARGETS := $(addsuffix -copy, $(IMPORT_COPY_MODULES)) |
|
167 |
ALL_COPY_MODULES += $(IMPORT_COPY_MODULES) |
|
168 |
ALL_COPY_TARGETS += $(IMPORT_COPY_TARGETS) |
|
169 |
||
170 |
define DeclareImportCopyRecipe |
|
171 |
$1-copy: |
|
47217 | 172 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
36506 | 173 |
-f CopyImportModules.gmk MODULE=$1) |
174 |
endef |
|
175 |
||
176 |
$(foreach m, $(IMPORT_COPY_MODULES), $(eval $(call DeclareImportCopyRecipe,$m))) |
|
177 |
||
178 |
ALL_TARGETS += $(ALL_COPY_TARGETS) |
|
15395
e5d837c6e999
8007093: build-infra: Make should fail if spec is older than configure files
erikj
parents:
15060
diff
changeset
|
179 |
|
25854 | 180 |
################################################################################ |
50313 | 181 |
# Targets for compiling all java modules. |
36506 | 182 |
JAVA_MODULES := $(ALL_MODULES) |
25854 | 183 |
JAVA_TARGETS := $(addsuffix -java, $(JAVA_MODULES)) |
14111 | 184 |
|
25854 | 185 |
define DeclareCompileJavaRecipe |
186 |
$1-java: |
|
47217 | 187 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
188 |
-f CompileJavaModules.gmk MODULE=$1) |
25854 | 189 |
endef |
190 |
||
50313 | 191 |
$(foreach m, $(JAVA_MODULES), $(eval $(call DeclareCompileJavaRecipe,$m))) |
14111 | 192 |
|
25854 | 193 |
ALL_TARGETS += $(JAVA_TARGETS) |
194 |
||
195 |
################################################################################ |
|
196 |
# Targets for running rmic. |
|
27560 | 197 |
$(eval $(call DeclareRecipesForPhase, RMIC, \ |
198 |
TARGET_SUFFIX := rmic, \ |
|
199 |
FILE_PREFIX := Rmic, \ |
|
200 |
MAKE_SUBDIR := rmic, \ |
|
201 |
CHECK_MODULES := $(ALL_MODULES))) |
|
25854 | 202 |
|
203 |
ALL_TARGETS += $(RMIC_TARGETS) |
|
204 |
||
205 |
################################################################################ |
|
206 |
# Targets for compiling native libraries |
|
27560 | 207 |
$(eval $(call DeclareRecipesForPhase, LIBS, \ |
208 |
TARGET_SUFFIX := libs, \ |
|
209 |
FILE_PREFIX := Lib, \ |
|
210 |
MAKE_SUBDIR := lib, \ |
|
211 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
212 |
USE_WRAPPER := true)) |
|
14111 | 213 |
|
27560 | 214 |
ALL_TARGETS += $(LIBS_TARGETS) |
14111 | 215 |
|
25854 | 216 |
################################################################################ |
217 |
# Targets for compiling native executables |
|
27560 | 218 |
$(eval $(call DeclareRecipesForPhase, LAUNCHER, \ |
219 |
TARGET_SUFFIX := launchers, \ |
|
220 |
FILE_PREFIX := Launcher, \ |
|
221 |
MAKE_SUBDIR := launcher, \ |
|
222 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
223 |
USE_WRAPPER := true)) |
|
25854 | 224 |
|
225 |
ALL_TARGETS += $(LAUNCHER_TARGETS) |
|
226 |
||
227 |
################################################################################ |
|
228 |
# Build hotspot target |
|
14111 | 229 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
230 |
HOTSPOT_VARIANT_TARGETS := $(addprefix hotspot-, $(JVM_VARIANTS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
231 |
HOTSPOT_VARIANT_GENSRC_TARGETS := $(addsuffix -gensrc, $(HOTSPOT_VARIANT_TARGETS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
232 |
HOTSPOT_VARIANT_LIBS_TARGETS := $(addsuffix -libs, $(HOTSPOT_VARIANT_TARGETS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
233 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
234 |
define DeclareHotspotGensrcRecipe |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
235 |
hotspot-$1-gensrc: |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
236 |
$$(call LogInfo, Building JVM variant '$1' with features '$(JVM_FEATURES_$1)') |
47217 | 237 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f gensrc/GenerateSources.gmk \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
238 |
JVM_VARIANT=$1) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
239 |
endef |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
240 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
241 |
$(foreach v, $(JVM_VARIANTS), $(eval $(call DeclareHotspotGensrcRecipe,$v))) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
242 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
243 |
define DeclareHotspotLibsRecipe |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
244 |
hotspot-$1-libs: |
47217 | 245 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f lib/CompileLibraries.gmk \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
246 |
JVM_VARIANT=$1) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
247 |
endef |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
248 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
249 |
$(foreach v, $(JVM_VARIANTS), $(eval $(call DeclareHotspotLibsRecipe,$v))) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
250 |
|
37402 | 251 |
hotspot-ide-project: |
47217 | 252 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f ide/CreateVSProject.gmk) |
37402 | 253 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
254 |
ALL_TARGETS += $(HOTSPOT_VARIANT_TARGETS) $(HOTSPOT_VARIANT_GENSRC_TARGETS) \ |
49423 | 255 |
$(HOTSPOT_VARIANT_LIBS_TARGETS) hotspot-ide-project |
15903 | 256 |
|
25854 | 257 |
################################################################################ |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
258 |
# Generate libs and launcher targets for creating compile_commands.json fragments |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
259 |
define DeclareCompileCommandsRecipe |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
260 |
$1-compile-commands: |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
261 |
$$(call LogInfo, Generating compile_commands.json fragments for $1) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
262 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Main.gmk $1-only \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
263 |
GENERATE_COMPILE_COMMANDS_ONLY=true) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
264 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
265 |
COMPILE_COMMANDS_TARGETS_$2 += $1-compile-commands |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
266 |
endef |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
267 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
268 |
$(foreach t, $(HOTSPOT_VARIANT_LIBS_TARGETS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
269 |
$(eval $(call DeclareCompileCommandsRecipe,$t,HOTSPOT)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
270 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
271 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
272 |
$(foreach t, $(LIBS_TARGETS) $(LAUNCHER_TARGETS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
273 |
$(eval $(call DeclareCompileCommandsRecipe,$t,JDK)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
274 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
275 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
276 |
compile-commands compile-commands-hotspot: |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
277 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileCommands.gmk) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
278 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
279 |
ALL_TARGETS += $(COMPILE_COMMANDS_TARGETS_HOTSPOT) $(COMPILE_COMMANDS_TARGETS_JDK) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
280 |
ALL_TARGETS += compile-commands compile-commands-hotspot |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
281 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
282 |
################################################################################ |
55166
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
283 |
# VS Code projects |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
284 |
vscode-project: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
285 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
286 |
VSCODE_INDEXER=cpptools) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
287 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
288 |
vscode-project-clangd: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
289 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
290 |
VSCODE_INDEXER=clangd) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
291 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
292 |
vscode-project-rtags: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
293 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
294 |
VSCODE_INDEXER=rtags) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
295 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
296 |
vscode-project-ccls: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
297 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
298 |
VSCODE_INDEXER=ccls) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
299 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
300 |
ALL_TARGETS += vscode-project vscode-project-clangd vscode-project-rtags \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
301 |
vscode-project-ccls |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
302 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
303 |
################################################################################ |
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
304 |
# Build demos targets |
14111 | 305 |
|
31310 | 306 |
demos-jdk: |
47217 | 307 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk) |
14111 | 308 |
|
45096 | 309 |
test-image-demos-jdk: |
47217 | 310 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk images) |
45096 | 311 |
|
312 |
ALL_TARGETS += demos-jdk test-image-demos-jdk |
|
14111 | 313 |
|
25854 | 314 |
################################################################################ |
36506 | 315 |
# Jigsaw specific data and analysis targets. |
316 |
||
317 |
generate-summary: |
|
47217 | 318 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f GenerateModuleSummary.gmk) |
36506 | 319 |
|
320 |
ALL_TARGETS += generate-summary |
|
321 |
||
322 |
################################################################################ |
|
323 |
# Jmod targets |
|
324 |
||
325 |
JMOD_MODULES := $(ALL_MODULES) |
|
326 |
JMOD_TARGETS := $(addsuffix -jmod, $(JMOD_MODULES)) |
|
327 |
||
328 |
define DeclareJmodRecipe |
|
329 |
$1-jmod: |
|
47217 | 330 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CreateJmods.gmk \ |
36506 | 331 |
MODULE=$1) |
332 |
endef |
|
333 |
||
334 |
$(foreach m, $(JMOD_MODULES), $(eval $(call DeclareJmodRecipe,$m))) |
|
335 |
||
336 |
ALL_TARGETS += $(JMOD_TARGETS) |
|
337 |
||
338 |
################################################################################ |
|
339 |
# Images targets |
|
14111 | 340 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
341 |
store-source-revision: |
47217 | 342 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk store-source-revision) |
39110
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
343 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
344 |
create-source-revision-tracker: |
47217 | 345 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk create-source-revision-tracker) |
14111 | 346 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
347 |
BOOTCYCLE_TARGET := product-images |
25854 | 348 |
bootcycle-images: |
37980
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
349 |
ifneq ($(COMPILE_TYPE), cross) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
350 |
$(call LogWarn, Boot cycle build step 2: Building a new JDK image using previously built image) |
54426 | 351 |
$(call MakeDir, $(OUTPUTDIR)/bootcycle-build) |
47217 | 352 |
+$(MAKE) $(MAKE_ARGS) -f $(TOPDIR)/make/Init.gmk PARALLEL_TARGETS=$(BOOTCYCLE_TARGET) \ |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
353 |
LOG_PREFIX="[bootcycle] " JOBS= SPEC=$(dir $(SPEC))bootcycle-spec.gmk main |
37980
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
354 |
else |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
355 |
$(call LogWarn, Boot cycle build disabled when cross compiling) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
356 |
endif |
27560 | 357 |
|
358 |
zip-security: |
|
47217 | 359 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ZipSecurity.gmk) |
27560 | 360 |
|
361 |
zip-source: |
|
47217 | 362 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ZipSource.gmk) |
27560 | 363 |
|
364 |
jrtfs-jar: |
|
47217 | 365 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f JrtfsJar.gmk) |
27560 | 366 |
|
41260 | 367 |
jdk-image: |
47217 | 368 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jdk) |
41260 | 369 |
|
50490 | 370 |
legacy-jre-image: |
47217 | 371 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jre) |
41260 | 372 |
|
373 |
symbols-image: |
|
47217 | 374 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk symbols) |
27560 | 375 |
|
50490 | 376 |
mac-jdk-bundle: |
377 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk jdk-bundle) |
|
378 |
||
379 |
mac-legacy-jre-bundle: |
|
380 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk jre-bundle) |
|
27560 | 381 |
|
42292 | 382 |
release-file: |
47217 | 383 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ReleaseFile.gmk) |
42292 | 384 |
|
41171 | 385 |
exploded-image-optimize: |
47217 | 386 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ExplodedImageOptimize.gmk) |
41171 | 387 |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
388 |
ifeq ($(JCOV_ENABLED), true) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
389 |
jcov-image: |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
390 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Coverage.gmk jcov-image) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
391 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
392 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
393 |
ALL_TARGETS += store-source-revision create-source-revision-tracker bootcycle-images zip-security \ |
50490 | 394 |
zip-source jrtfs-jar jdk-image legacy-jre-image \ |
395 |
symbols-image mac-jdk-bundle mac-legacy-jre-bundle \ |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
396 |
release-file exploded-image-optimize jcov-image |
25854 | 397 |
|
398 |
################################################################################ |
|
399 |
# Docs targets |
|
400 |
||
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
401 |
# If building full docs, to complete docs-*-api we need both the javadoc and |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
402 |
# modulegraph targets. |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
403 |
docs-jdk-api-javadoc: |
47217 | 404 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-api-javadoc) |
44397
f932d6b9f7fe
8173303: Add module-subgraph images to main platform documentation
mchung
parents:
44078
diff
changeset
|
405 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
406 |
docs-jdk-api-modulegraph: |
47217 | 407 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-api-modulegraph) |
25854 | 408 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
409 |
docs-javase-api-javadoc: |
47217 | 410 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-javase-api-javadoc) |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
411 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
412 |
docs-javase-api-modulegraph: |
47217 | 413 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-javase-api-modulegraph) |
44725
8747b14eb49c
8172312: Update docs target and image for new combined docs
ihse
parents:
44724
diff
changeset
|
414 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
415 |
docs-reference-api-javadoc: |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
416 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-reference-api-javadoc) |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
417 |
|
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
418 |
docs-reference-api-modulegraph: |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
419 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-reference-api-modulegraph) |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
420 |
|
44733 | 421 |
docs-jdk-specs: |
47217 | 422 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-specs) |
25854 | 423 |
|
45105 | 424 |
docs-jdk-index: |
47217 | 425 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-index) |
45105 | 426 |
|
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
427 |
docs-zip: |
47217 | 428 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-zip) |
37034
b63fd4af003e
8154313: Generated javadoc scattered all over the place
neugens
parents:
37031
diff
changeset
|
429 |
|
44078
673240c54c2e
8176509: Use pandoc for converting build readme to html
ihse
parents:
44027
diff
changeset
|
430 |
update-build-docs: |
47217 | 431 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UpdateBuildDocs.gmk) |
44078
673240c54c2e
8176509: Use pandoc for converting build readme to html
ihse
parents:
44027
diff
changeset
|
432 |
|
49133 | 433 |
update-x11wrappers: |
434 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UpdateX11Wrappers.gmk) |
|
435 |
||
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
436 |
ALL_TARGETS += docs-jdk-api-javadoc docs-jdk-api-modulegraph \ |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
437 |
docs-javase-api-javadoc docs-javase-api-modulegraph \ |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
438 |
docs-reference-api-javadoc docs-reference-api-modulegraph docs-jdk-specs \ |
49133 | 439 |
docs-jdk-index docs-zip update-build-docs update-x11wrappers |
25854 | 440 |
|
441 |
################################################################################ |
|
36506 | 442 |
# Cross compilation support |
443 |
||
37770 | 444 |
ifeq ($(CREATING_BUILDJDK), true) |
36506 | 445 |
# This target is only called by the recursive call below. |
37770 | 446 |
create-buildjdk-interim-image-helper: interim-image jdk.jlink-launchers \ |
447 |
java.base-copy jdk.jdeps-launchers |
|
36506 | 448 |
endif |
449 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
450 |
BUILDJDK_MODULES := $(sort $(foreach m, jdk.jlink $(INTERIM_IMAGE_MODULES), \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
451 |
$(call FindTransitiveDepsForModule, $m) $m)) |
36506 | 452 |
|
37770 | 453 |
create-buildjdk-interim-image: |
47217 | 454 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Main.gmk \ |
36506 | 455 |
$@-helper \ |
456 |
SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
457 |
HOTSPOT_SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
458 |
CREATING_BUILDJDK=true \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
459 |
LOG_PREFIX="[buildjdk] " \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
460 |
JAVA_MODULES="$(BUILDJDK_MODULES)" \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
461 |
) |
36506 | 462 |
|
37770 | 463 |
ALL_TARGETS += create-buildjdk-copy create-buildjdk-interim-image |
464 |
||
465 |
################################################################################ |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
466 |
# The interim-image is a small jlinked image that is used to generate artifacts |
37770 | 467 |
# at build time for use when linking the real images. |
468 |
||
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
469 |
INTERIM_JMOD_TARGETS := $(addsuffix -interim-jmod, $(INTERIM_IMAGE_MODULES)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
470 |
|
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
471 |
define DeclareInterimJmodRecipe |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
472 |
$1-interim-jmod: |
47217 | 473 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CreateJmods.gmk \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
474 |
MODULE=$1 \ |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
475 |
JMODS_DIR=$(INTERIM_JMODS_DIR) \ |
53995 | 476 |
JMODS_SUPPORT_DIR=$(INTERIM_JMODS_DIR)/support \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
477 |
INTERIM_JMOD=true \ |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
478 |
) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
479 |
endef |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
480 |
|
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
481 |
$(foreach m, $(INTERIM_IMAGE_MODULES), $(eval $(call DeclareInterimJmodRecipe,$m))) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
482 |
|
37770 | 483 |
interim-image: |
47217 | 484 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f InterimImage.gmk) |
37770 | 485 |
|
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
486 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
487 |
generate-link-opt-data: |
47217 | 488 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f GenerateLinkOptData.gmk) |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
489 |
endif |
37770 | 490 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
491 |
ALL_TARGETS += $(INTERIM_JMOD_TARGETS) interim-image generate-link-opt-data |
36506 | 492 |
|
493 |
################################################################################ |
|
44027 | 494 |
# Generate test names for all JTReg test groups |
495 |
# |
|
496 |
||
497 |
define DeclareRunTestRecipe |
|
52342 | 498 |
test-$1: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
499 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
500 |
TEST="$1") |
44027 | 501 |
|
52342 | 502 |
exploded-test-$1: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
503 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
45266
29347d0c7122
8180651: Make target to run tests on exploded image
erikj
parents:
45105
diff
changeset
|
504 |
TEST="$1" JDK_IMAGE_DIR=$(JDK_OUTPUTDIR)) |
44027 | 505 |
endef |
506 |
||
507 |
# ALL_NAMED_TESTS is defined in FindTests.gmk |
|
508 |
$(foreach t, $(ALL_NAMED_TESTS), $(eval $(call DeclareRunTestRecipe,$t))) |
|
52342 | 509 |
ALL_TEST_TARGETS := $(addprefix test-, $(ALL_NAMED_TESTS)) |
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
510 |
|
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
511 |
# We only support the "exploded-test-gtest" shortcut |
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
512 |
ALL_EXPLODED_TESTS := gtest |
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
513 |
ALL_EXPLODED_TEST_TARGETS := $(addprefix exploded-test-, $(ALL_EXPLODED_TESTS)) |
44027 | 514 |
|
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
515 |
ALL_TARGETS += $(ALL_TEST_TARGETS) $(ALL_EXPLODED_TEST_TARGETS) |
44027 | 516 |
|
517 |
################################################################################ |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
518 |
# Build tests and microbenchmarks |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
519 |
# |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
520 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
521 |
prepare-test-image: |
47984 | 522 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f TestImage.gmk prepare-test-image) |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
523 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
524 |
build-test-hotspot-jtreg-native: |
47217 | 525 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeHotspot.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
526 |
build-test-hotspot-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
527 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
528 |
test-image-hotspot-jtreg-native: |
47217 | 529 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeHotspot.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
530 |
test-image-hotspot-jtreg-native) |
25854 | 531 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
532 |
build-test-jdk-jtreg-native: |
47217 | 533 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeJdk.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
534 |
build-test-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
535 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
536 |
test-image-jdk-jtreg-native: |
47217 | 537 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeJdk.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
538 |
test-image-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
539 |
|
50908 | 540 |
build-test-hotspot-jtreg-graal: |
541 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregGraalUnit.gmk \ |
|
542 |
build-test-hotspot-jtreg-graal) |
|
543 |
||
544 |
test-image-hotspot-jtreg-graal: |
|
545 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregGraalUnit.gmk \ |
|
546 |
test-image-hotspot-jtreg-graal) |
|
547 |
||
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
548 |
ifeq ($(BUILD_GTEST), true) |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
549 |
test-image-hotspot-gtest: |
47217 | 550 |
+($(CD) $(TOPDIR)/make/hotspot/test && $(MAKE) $(MAKE_ARGS) -f GtestImage.gmk) |
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
551 |
endif |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
552 |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
553 |
build-test-lib: |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
554 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f BuildTestLib.gmk) |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
555 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
556 |
ifeq ($(BUILD_FAILURE_HANDLER), true) |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
557 |
# Builds the failure handler jtreg extension |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
558 |
build-test-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
559 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
560 |
-f BuildFailureHandler.gmk build) |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
561 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
562 |
# Copies the failure handler jtreg extension into the test image |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
563 |
test-image-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
564 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
565 |
-f BuildFailureHandler.gmk images) |
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
566 |
endif |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
567 |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
568 |
build-microbenchmark: |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
569 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f test/BuildMicrobenchmark.gmk) |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
570 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
571 |
ALL_TARGETS += prepare-test-image build-test-hotspot-jtreg-native \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
572 |
test-image-hotspot-jtreg-native build-test-jdk-jtreg-native \ |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
573 |
test-image-jdk-jtreg-native build-test-lib build-test-failure-handler \ |
44027 | 574 |
test-failure-handler test-image-failure-handler test-image-hotspot-gtest \ |
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
575 |
test-image-hotspot-jtreg-graal build-test-hotspot-jtreg-graal \ |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
576 |
build-microbenchmark |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
577 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
578 |
################################################################################ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
579 |
# Run tests |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
580 |
|
25854 | 581 |
test: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
582 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
583 |
TEST="$(TEST)") |
37974 | 584 |
|
52342 | 585 |
exploded-test: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
586 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
52342 | 587 |
TEST="$(TEST)" JDK_IMAGE_DIR=$(JDK_OUTPUTDIR)) |
25854 | 588 |
|
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
589 |
jcov-test: |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
590 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
591 |
TEST="$(TEST)" TEST_OPTS_JCOV=true) |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
592 |
|
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
593 |
ALL_TARGETS += test exploded-test jcov-test |
25854 | 594 |
|
595 |
################################################################################ |
|
37972 | 596 |
# Bundles |
597 |
||
598 |
product-bundles: |
|
599 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk product-bundles) |
|
600 |
||
54348 | 601 |
legacy-bundles: |
602 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk legacy-bundles) |
|
603 |
||
37972 | 604 |
test-bundles: |
605 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk test-bundles) |
|
606 |
||
607 |
docs-bundles: |
|
608 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk docs-bundles) |
|
609 |
||
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
610 |
ifeq ($(JCOV_ENABLED), true) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
611 |
jcov-bundles: |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
612 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk jcov-bundles) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
613 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
614 |
|
54348 | 615 |
ALL_TARGETS += product-bundles legacy-bundles test-bundles docs-bundles jcov-bundles |
37972 | 616 |
|
617 |
################################################################################ |
|
25854 | 618 |
# Install targets |
619 |
||
620 |
install: |
|
47217 | 621 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Install.gmk) |
25854 | 622 |
|
623 |
ALL_TARGETS += install |
|
624 |
||
625 |
################################################################################ |
|
626 |
# |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
627 |
# Dependency declarations between targets. |
25854 | 628 |
# |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
629 |
# These are declared in two groups. First all dependencies between targets that |
25854 | 630 |
# have recipes above as these dependencies may be disabled. Then the aggregator |
631 |
# targets that do not have recipes of their own, which will never have their |
|
632 |
# dependencies disabled. |
|
633 |
# |
|
634 |
################################################################################ |
|
635 |
# Targets with recipes above |
|
636 |
||
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
637 |
# If running an *-only target, parallel execution and dependencies between |
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
638 |
# recipe targets are disabled. This makes it possible to run a select set of |
25854 | 639 |
# recipe targets in order. It's the responsibility of the user to make sure |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
640 |
# all prerequisites are fulfilled. |
25854 | 641 |
ifneq ($(findstring -only, $(MAKECMDGOALS)), ) |
642 |
.NOTPARALLEL: |
|
643 |
else |
|
27560 | 644 |
$(LANGTOOLS_GENSRC_TARGETS): buildtools-langtools |
645 |
||
47364 | 646 |
interim-langtools: $(INTERIM_LANGTOOLS_GENSRC_TARGETS) |
25854 | 647 |
|
31948 | 648 |
buildtools-jdk: interim-langtools interim-cldrconverter |
25854 | 649 |
|
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
650 |
buildtools-hotspot: interim-langtools |
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
651 |
|
41171 | 652 |
buildtools-modules: exploded-image-base |
653 |
||
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
654 |
$(HOTSPOT_GENSRC_TARGETS): interim-langtools buildtools-hotspot |
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
655 |
|
27560 | 656 |
$(JDK_GENSRC_TARGETS): interim-langtools buildtools-jdk |
25854 | 657 |
|
36506 | 658 |
$(GENSRC_MODULEINFO_TARGETS): buildtools-jdk |
659 |
||
27560 | 660 |
$(GENDATA_TARGETS): interim-langtools buildtools-jdk |
25854 | 661 |
|
662 |
interim-rmic: interim-langtools |
|
663 |
||
32806 | 664 |
$(RMIC_TARGETS): interim-langtools interim-rmic |
25854 | 665 |
|
31310 | 666 |
$(JAVA_TARGETS): interim-langtools |
667 |
||
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
668 |
# Declare dependencies between hotspot-<variant>* targets |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
669 |
$(foreach v, $(JVM_VARIANTS), \ |
52802 | 670 |
$(eval hotspot-$v-gensrc: java.base-copy) \ |
48355 | 671 |
$(eval hotspot-$v-libs: hotspot-$v-gensrc java.base-copy) \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
672 |
) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
673 |
|
37402 | 674 |
hotspot-ide-project: hotspot exploded-image |
675 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
676 |
generate-exported-symbols: java.base-libs jdk.jdwp.agent-libs |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
677 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
678 |
# If not already set, set the JVM variant target so that the JVM will be built. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
679 |
JVM_MAIN_LIB_TARGETS ?= hotspot-$(JVM_VARIANT_MAIN)-libs |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
680 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
681 |
# Building one JVM variant is enough to start building the other libs |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
682 |
$(LIBS_TARGETS): $(JVM_MAIN_LIB_TARGETS) |
25854 | 683 |
|
684 |
$(LAUNCHER_TARGETS): java.base-libs |
|
685 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
686 |
ifeq ($(STATIC_BUILD), true) |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
687 |
$(LAUNCHER_TARGETS): generate-exported-symbols |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
688 |
endif |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
689 |
|
26115
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
690 |
# The demos are currently linking to libjvm and libjava, just like all other |
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
691 |
# jdk libs, even though they don't need to. To avoid warnings, make sure they |
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
692 |
# aren't built until after libjava and libjvm are available to link to. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
693 |
demos-jdk: java.base-libs exploded-image |
45096 | 694 |
test-image-demos-jdk: demos-jdk |
25854 | 695 |
|
696 |
# Declare dependency from <module>-java to <module>-gensrc |
|
697 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-java: $m-gensrc)) |
|
698 |
||
699 |
# Declare dependencies between java modules |
|
700 |
$(foreach m, $(JAVA_MODULES), \ |
|
701 |
$(eval $m-java: $(addsuffix -java, $(filter $(JAVA_MODULES), \ |
|
702 |
$(call FindDepsForModule,$m))))) |
|
703 |
||
704 |
# Declare dependencies between <module>-rmic to <module>-java |
|
705 |
$(foreach m, $(RMIC_MODULES), $(eval $m-rmic: $m-java)) |
|
706 |
||
707 |
# Declare dependencies from <module>-lib to <module>-java |
|
37770 | 708 |
# Skip modules that do not have java source. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
709 |
$(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs: $m-java)) |
25854 | 710 |
|
711 |
# Declare dependencies from all other <module>-lib to java.base-lib |
|
27560 | 712 |
$(foreach t, $(filter-out java.base-libs, $(LIBS_TARGETS)), \ |
25854 | 713 |
$(eval $t: java.base-libs)) |
714 |
||
29851
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
715 |
# jdk.accessibility depends on java.desktop |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
716 |
jdk.accessibility-libs: java.desktop-libs |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
717 |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
718 |
# This dependency needs to be explicitly declared. jdk.jdi-gensrc generates a |
27560 | 719 |
# header file used by jdk.jdwp.agent-libs. The jdk.jdwp.agent-gensrc is a |
720 |
# virtual target. |
|
721 |
jdk.jdwp.agent-libs: jdk.jdwp.agent-gensrc |
|
722 |
||
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
723 |
# The swing beans need to have java base properly generated to avoid errors |
48355 | 724 |
# in javadoc. The X11 wrappers need the java.base include files to have been |
725 |
# copied and processed. |
|
726 |
java.desktop-gensrc-src: java.base-gensrc java.base-copy |
|
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
727 |
|
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
728 |
# The annotation processing for jdk.internal.vm.compiler |
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
729 |
# and jdk.internal.vm.compiler.management needs classes from the current JDK. |
47217 | 730 |
jdk.internal.vm.compiler-gensrc-src: $(addsuffix -java, \ |
43925 | 731 |
$(call FindTransitiveDepsForModule, jdk.internal.vm.compiler)) |
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
732 |
jdk.internal.vm.compiler.management-gensrc-src: $(addsuffix -java, \ |
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
733 |
$(call FindTransitiveDepsForModule, jdk.internal.vm.compiler.management)) |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
734 |
|
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
735 |
# For these modules, the gensrc step is generating a module-info.java.extra |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
736 |
# file to be processed by the gensrc-moduleinfo target. |
47217 | 737 |
jdk.internal.vm.compiler-gensrc-moduleinfo: jdk.internal.vm.compiler-gensrc-src |
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
738 |
jdk.internal.vm.compiler.management-gensrc-moduleinfo: jdk.internal.vm.compiler.management-gensrc-src |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
739 |
|
30742 | 740 |
jdk.jdeps-gendata: java rmic |
26132
11df1233e1e8
8055856: checkdeps build target doesn't work for cross-compilation builds
mchung
parents:
26128
diff
changeset
|
741 |
|
45873
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
742 |
# The ct.sym generation uses all the moduleinfos as input |
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
743 |
jdk.compiler-gendata: $(GENSRC_MODULEINFO_TARGETS) |
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
744 |
|
42285
864475e2cf63
8169816: Move src.zip and jrt-fs.jar under the lib directory
mchung
parents:
42282
diff
changeset
|
745 |
# Declare dependencies between jmod targets. |
864475e2cf63
8169816: Move src.zip and jrt-fs.jar under the lib directory
mchung
parents:
42282
diff
changeset
|
746 |
# java.base jmod needs jrt-fs.jar and access to the other jmods to be built. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
747 |
# When creating the BUILDJDK, we don't need to add hashes to java.base, thus |
37770 | 748 |
# we don't need to depend on all other jmods |
749 |
ifneq ($(CREATING_BUILDJDK), true) |
|
43655 | 750 |
java.base-jmod: jrtfs-jar $(filter-out java.base-jmod, $(JMOD_TARGETS)) |
37770 | 751 |
endif |
36506 | 752 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
753 |
# If not already set, set the JVM target so that the JVM will be built. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
754 |
JVM_MAIN_TARGETS ?= hotspot |
49133 | 755 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
756 |
# Building java.base-jmod requires all of VM (ie hotspot) to be built. |
49133 | 757 |
java.base-jmod: $(JVM_MAIN_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
758 |
|
36506 | 759 |
# Declare dependencies from <module>-jmod to all other module targets |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
760 |
$(foreach m, $(JAVA_MODULES), $(eval $m_JMOD_DEPS += $m-java)) |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
761 |
$(foreach m, $(GENDATA_MODULES), $(eval $m_JMOD_DEPS += $m-gendata)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
762 |
$(foreach m, $(RMIC_MODULES), $(eval $m_JMOD_DEPS += $m-rmic)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
763 |
$(foreach m, $(LIBS_MODULES), $(eval $m_JMOD_DEPS += $m-libs)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
764 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m_JMOD_DEPS += $m-launchers)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
765 |
$(foreach m, $(COPY_MODULES), $(eval $m_JMOD_DEPS += $m-copy)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
766 |
$(foreach m, $(ALL_MODULES), $(eval $m-jmod: $($(m)_JMOD_DEPS))) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
767 |
$(foreach m, $(INTERIM_IMAGE_MODULES), $(eval $m-interim-jmod: $($(m)_JMOD_DEPS))) |
36506 | 768 |
|
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
769 |
# Setup the minimal set of generated native source dependencies for hotspot |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
770 |
$(foreach v, $(JVM_VARIANTS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
771 |
$(eval hotspot-$v-libs-compile-commands: hotspot-$v-gensrc) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
772 |
$(foreach m, $(filter java.desktop jdk.hotspot.agent, $(GENSRC_MODULES)), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
773 |
$(eval hotspot-$v-libs-compile-commands: $m-gensrc)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
774 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
775 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
776 |
# For the full JDK compile commands, create all possible generated sources |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
777 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-libs-compile-commands: $m-gensrc)) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
778 |
$(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs-compile-commands: $m-java)) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
779 |
|
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
780 |
$(COMPILE_COMMANDS_TARGETS_HOTSPOT): clean-compile-commands |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
781 |
$(COMPILE_COMMANDS_TARGETS_JDK): clean-compile-commands |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
782 |
compile-commands-hotspot: $(COMPILE_COMMANDS_TARGETS_HOTSPOT) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
783 |
compile-commands: $(COMPILE_COMMANDS_TARGETS_HOTSPOT) $(COMPILE_COMMANDS_TARGETS_JDK) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
784 |
|
55166
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
785 |
vscode-project: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
786 |
vscode-project-clangd: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
787 |
vscode-project-rtags: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
788 |
vscode-project-ccls: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
789 |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
790 |
# Jmods cannot be created until we have the jmod tool ready to run. During |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
791 |
# a normal build we run it from the exploded image, but when cross compiling |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
792 |
# it's run from the buildjdk, which is either created at build time or user |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
793 |
# supplied. |
36506 | 794 |
ifeq ($(CREATE_BUILDJDK), true) |
37770 | 795 |
ifneq ($(CREATING_BUILDJDK), true) |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
796 |
# When cross compiling and buildjdk is to be created, simply depend on |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
797 |
# creating the buildjdk. |
37770 | 798 |
$(JMOD_TARGETS): create-buildjdk |
41171 | 799 |
buildtools-modules: create-buildjdk |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
800 |
else |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
801 |
# While actually creating the buildjdk, we need to list the bare |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
802 |
# minimum dependencies needed before running jmod, to avoid building |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
803 |
# more than necessary. This includes: |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
804 |
# * all java modules |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
805 |
# * jdk.jlink-launchers |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
806 |
# * copy jvm.cfg (done in java.base-copy) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
807 |
# * tzdb.dat (done in java.base-gendata) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
808 |
# Without all of these jimage, jlink and jmod won't start. |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
809 |
$(JMOD_TARGETS) $(INTERIM_JMOD_TARGETS): java.base-libs java.base-copy \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
810 |
java.base-gendata jdk.jlink-launchers java |
37770 | 811 |
endif |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
812 |
else |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
813 |
# The normal non cross compilation case uses needs to wait for the full |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
814 |
# exploded-image to avoid a race with the optimize target. |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
815 |
$(JMOD_TARGETS) $(INTERIM_JMOD_TARGETS): exploded-image |
36506 | 816 |
endif |
817 |
||
42505
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
818 |
# All modules include the main license files from java.base. |
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
819 |
$(JMOD_TARGETS): java.base-copy |
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
820 |
|
27560 | 821 |
zip-security: java.base-java java.security.jgss-java java.security.jgss-libs \ |
822 |
$(filter jdk.crypto%, $(JAVA_TARGETS)) |
|
25854 | 823 |
|
27560 | 824 |
zip-source: gensrc rmic |
825 |
||
36506 | 826 |
jrtfs-jar: interim-langtools |
25854 | 827 |
|
52607
da785658408b
8214045: Missing explicit dependencies of build-microbenchmark cause intermittent build failure
redestad
parents:
52595
diff
changeset
|
828 |
build-microbenchmark: interim-langtools exploded-image |
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
829 |
|
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
830 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
831 |
ifeq ($(CREATE_BUILDJDK), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
832 |
# If creating a buildjdk, the interim image needs to be based on that. |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
833 |
generate-link-opt-data: create-buildjdk |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
834 |
else ifeq ($(EXTERNAL_BUILDJDK), false) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
835 |
# If an external buildjdk has been provided, we skip generating an |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
836 |
# interim-image and just use the external buildjdk for generating |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
837 |
# classlist. |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
838 |
generate-link-opt-data: interim-image |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
839 |
endif |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
840 |
generate-link-opt-data: buildtools-jdk |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
841 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
842 |
# The generated classlist needs to go into java.base-jmod. |
50490 | 843 |
java.base-jmod jdk.jlink-jmod jdk-image legacy-jre-image: generate-link-opt-data |
37770 | 844 |
endif |
845 |
||
42292 | 846 |
release-file: create-source-revision-tracker |
25854 | 847 |
|
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
848 |
jdk-image: jmods zip-source demos release-file |
50490 | 849 |
legacy-jre-image: jmods release-file |
42506
54b0b4fffab5
8170878: JDK 9 fails to build when enabling Hotspot code coverage
erikj
parents:
42505
diff
changeset
|
850 |
symbols-image: $(LIBS_TARGETS) $(LAUNCHER_TARGETS) |
42292 | 851 |
|
50490 | 852 |
mac-jdk-bundle: jdk-image |
853 |
mac-legacy-jre-bundle: legacy-jre-image |
|
25854 | 854 |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
855 |
ifeq ($(JCOV_INPUT_JDK), ) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
856 |
jcov-image: jdk-image |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
857 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
858 |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
859 |
# The optimize target can run as soon as the modules dir has been completely |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
860 |
# populated (java, copy and gendata targets) and the basic libs and launchers |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
861 |
# have been built. |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
862 |
exploded-image-optimize: java copy gendata java.base-libs java.base-launchers \ |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
863 |
buildtools-modules |
41171 | 864 |
|
41260 | 865 |
bootcycle-images: jdk-image |
25854 | 866 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
867 |
docs-jdk-api-javadoc: $(GENSRC_TARGETS) rmic |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
868 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
869 |
docs-javase-api-javadoc: $(GENSRC_TARGETS) rmic |
44397
f932d6b9f7fe
8173303: Add module-subgraph images to main platform documentation
mchung
parents:
44078
diff
changeset
|
870 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
871 |
docs-reference-api-javadoc: $(GENSRC_TARGETS) rmic |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
872 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
873 |
docs-jdk-api-modulegraph: exploded-image buildtools-modules |
25854 | 874 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
875 |
docs-javase-api-modulegraph: exploded-image buildtools-modules |
44725
8747b14eb49c
8172312: Update docs target and image for new combined docs
ihse
parents:
44724
diff
changeset
|
876 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
877 |
docs-reference-api-modulegraph: exploded-image buildtools-modules |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
878 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
879 |
# If not already set, then set the JVM specific docs targets |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
880 |
JVM_DOCS_TARGETS ?= hotspot-$(JVM_VARIANT_MAIN)-gensrc |
49133 | 881 |
|
44733 | 882 |
# The gensrc steps for hotspot and jdk.jdi create html spec files. |
55112 | 883 |
docs-jdk-specs: buildtools-jdk $(JVM_DOCS_TARGETS) jdk.jdi-gensrc \ |
45229
88a3fab6006f
8180426: Use standard css file for new docs bundle index.html page
ihse
parents:
45105
diff
changeset
|
884 |
docs-jdk-index |
25854 | 885 |
|
44733 | 886 |
docs-zip: docs-jdk |
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
887 |
|
52342 | 888 |
# Tests |
41260 | 889 |
test: jdk-image test-image |
25854 | 890 |
|
52342 | 891 |
exploded-test: exploded-image test-image |
892 |
||
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
893 |
jcov-test: jcov-image test-image |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
894 |
|
52342 | 895 |
test-make: clean-test-make compile-commands |
896 |
||
897 |
test-make-compile-commands: compile-commands |
|
44027 | 898 |
|
899 |
# Declare dependency for all generated test targets |
|
52342 | 900 |
$(foreach t, $(filter-out test-make%, $(ALL_TEST_TARGETS)), $(eval $t: jdk-image test-image)) |
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
901 |
$(foreach t, $(ALL_EXPLODED_TEST_TARGETS), $(eval $t: exploded-image test-image)) |
44027 | 902 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
903 |
interim-image: $(INTERIM_JMOD_TARGETS) |
25854 | 904 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
905 |
build-test-lib: exploded-image |
33436 | 906 |
|
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
907 |
build-test-failure-handler: interim-langtools |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
908 |
|
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
909 |
test-image-failure-handler: build-test-failure-handler |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
910 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
911 |
build-test-hotspot-jtreg-native: buildtools-jdk \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
912 |
hotspot-$(JVM_VARIANT_MAIN)-libs |
29159
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
913 |
|
45555
9b00774291d5
8181147: JNU_GetStringPlatformChars should have a fast path for UTF-8
redestad
parents:
45271
diff
changeset
|
914 |
build-test-jdk-jtreg-native: buildtools-jdk java.base-libs |
29159
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
915 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
916 |
build-test-hotspot-jtreg-graal: exploded-image |
50908 | 917 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
918 |
test-image-hotspot-jtreg-native: build-test-hotspot-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
919 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
920 |
test-image-jdk-jtreg-native: build-test-jdk-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
921 |
|
50908 | 922 |
test-image-hotspot-jtreg-graal: build-test-hotspot-jtreg-graal |
923 |
||
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
924 |
test-image-hotspot-gtest: hotspot |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
925 |
|
33722
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
926 |
install: product-images |
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
927 |
|
37972 | 928 |
product-bundles: product-images |
929 |
||
54348 | 930 |
legacy-bundles: legacy-images |
931 |
||
37972 | 932 |
test-bundles: test-image |
933 |
||
934 |
docs-bundles: docs-image |
|
935 |
||
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
936 |
jcov-bundles: jcov-image |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
937 |
|
41171 | 938 |
generate-summary: jmods buildtools-modules |
36506 | 939 |
|
49133 | 940 |
update-x11wrappers: java.base-copy buildtools-jdk |
941 |
||
25854 | 942 |
endif |
943 |
||
944 |
################################################################################ |
|
945 |
# Virtual targets without recipes |
|
946 |
||
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
947 |
# If not already set, set the JVM specific tools targets |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
948 |
JVM_TOOLS_TARGETS ?= buildtools-hotspot |
32806 | 949 |
buildtools: buildtools-langtools interim-langtools interim-rmic \ |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
950 |
buildtools-jdk $(JVM_TOOLS_TARGETS) |
27560 | 951 |
|
54422
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
952 |
# Declare dependencies from hotspot-<variant> targets |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
953 |
$(foreach v, $(JVM_VARIANTS), \ |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
954 |
$(eval hotspot-$v: hotspot-$v-gensrc hotspot-$v-libs) \ |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
955 |
) |
49423 | 956 |
hotspot: $(HOTSPOT_VARIANT_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
957 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
958 |
# Create targets hotspot-libs and hotspot-gensrc. |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
959 |
$(foreach v, $(JVM_VARIANTS), \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
960 |
$(eval hotspot-libs: hotspot-$v-libs) \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
961 |
$(eval hotspot-gensrc: hotspot-$v-gensrc) \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
962 |
) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
963 |
|
25854 | 964 |
gensrc: $(GENSRC_TARGETS) |
965 |
||
966 |
gendata: $(GENDATA_TARGETS) |
|
967 |
||
36506 | 968 |
copy: $(ALL_COPY_TARGETS) |
25854 | 969 |
|
970 |
java: $(JAVA_TARGETS) |
|
971 |
||
972 |
rmic: $(RMIC_TARGETS) |
|
973 |
||
27560 | 974 |
libs: $(LIBS_TARGETS) |
25854 | 975 |
|
976 |
launchers: $(LAUNCHER_TARGETS) |
|
977 |
||
36506 | 978 |
jmods: $(JMOD_TARGETS) |
979 |
||
27560 | 980 |
# Explicitly declare dependency for virtual target jdk.jdwp.agent-gensrc which |
981 |
# is actually handled by jdk.jdi-gensrc |
|
982 |
jdk.jdwp.agent-gensrc: jdk.jdi-gensrc |
|
25854 | 983 |
|
984 |
# Declare dependencies from <module> to all the individual targets specific |
|
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
985 |
# to that module <module>-*, that are needed for the exploded image. |
25854 | 986 |
$(foreach m, $(GENSRC_MODULES), $(eval $m: $m-gensrc)) |
987 |
$(foreach m, $(JAVA_MODULES), $(eval $m: $m-java)) |
|
988 |
$(foreach m, $(GENDATA_MODULES), $(eval $m: $m-gendata)) |
|
989 |
$(foreach m, $(RMIC_MODULES), $(eval $m: $m-rmic)) |
|
27560 | 990 |
$(foreach m, $(LIBS_MODULES), $(eval $m: $m-libs)) |
25854 | 991 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m: $m-launchers)) |
36506 | 992 |
$(foreach m, $(ALL_COPY_MODULES), $(eval $m: $m-copy)) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
993 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
994 |
# Building java.base includes building all of hotspot. |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
995 |
java.base: $(JVM_MAIN_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
996 |
|
31310 | 997 |
demos: demos-jdk |
998 |
||
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
999 |
# The "exploded image" is a locally runnable JDK in $(OUTPUTDIR)/jdk. |
41171 | 1000 |
exploded-image-base: $(ALL_MODULES) |
42292 | 1001 |
exploded-image: exploded-image-base release-file |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1002 |
# When cross compiling, no need to optimize the exploded image since it won't |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1003 |
# be runnable on the host platform anyway. |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1004 |
ifneq ($(COMPILE_TYPE), cross) |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1005 |
exploded-image: exploded-image-optimize |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1006 |
endif |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1007 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
1008 |
create-buildjdk: create-buildjdk-interim-image |
36506 | 1009 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1010 |
docs-jdk-api: docs-jdk-api-javadoc |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1011 |
docs-javase-api: docs-javase-api-javadoc |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1012 |
docs-reference-api: docs-reference-api-javadoc |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1013 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1014 |
# If we're building full docs, we must also generate the module graphs to |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1015 |
# get non-broken api documentation. |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1016 |
ifeq ($(ENABLE_FULL_DOCS), true) |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1017 |
docs-jdk-api: docs-jdk-api-modulegraph |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1018 |
docs-javase-api: docs-javase-api-modulegraph |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1019 |
docs-reference-api: docs-reference-api-modulegraph |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1020 |
endif |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1021 |
|
45105 | 1022 |
docs-jdk: docs-jdk-api docs-jdk-specs docs-jdk-index |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1023 |
docs-javase: docs-javase-api |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1024 |
docs-reference: docs-reference-api |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1025 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1026 |
# alias for backwards compatibility |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1027 |
docs-javadoc: docs-jdk-api |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1028 |
|
50490 | 1029 |
mac-bundles: mac-jdk-bundle |
31310 | 1030 |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1031 |
# The $(OUTPUTDIR)/images directory contain the resulting deliverables, |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1032 |
# and in line with this, our targets for creating these are named *-image[s]. |
25854 | 1033 |
|
50490 | 1034 |
# This target builds the product images, e.g. the JDK image |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1035 |
# (and possibly other, more specific versions) |
50490 | 1036 |
product-images: jdk-image symbols-image exploded-image |
41260 | 1037 |
|
54348 | 1038 |
# This target builds the legacy images, e.g. the legacy JRE image |
1039 |
legacy-images: legacy-jre-image |
|
1040 |
||
41260 | 1041 |
# zip-security is actually a bundle, but for now it needs to be considered |
1042 |
# an image until this can be cleaned up properly. |
|
1043 |
product-images: zip-security |
|
36506 | 1044 |
|
37770 | 1045 |
# The module summary cannot be run when: |
1046 |
# * Cross compiling and building a partial BUILDJDK for the build host |
|
1047 |
# * An external buildjdk has been supplied since it may not match the |
|
1048 |
# module selection of the target jdk |
|
36506 | 1049 |
ifneq ($(CREATE_BUILDJDK), true) |
37770 | 1050 |
ifeq ($(EXTERNAL_BUILDJDK), false) |
1051 |
product-images: generate-summary |
|
1052 |
endif |
|
36506 | 1053 |
endif |
25854 | 1054 |
|
53683 | 1055 |
ifeq ($(call isTargetOs, macosx), true) |
50490 | 1056 |
product-images: mac-jdk-bundle |
54348 | 1057 |
|
1058 |
legacy-images: mac-legacy-jre-bundle |
|
27560 | 1059 |
endif |
25854 | 1060 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1061 |
# This target builds the documentation image |
44733 | 1062 |
docs-image: docs-jdk |
25854 | 1063 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1064 |
# If not already set, set the JVM specific targets to build the test image |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1065 |
JVM_TEST_IMAGE_TARGETS ?= test-image-hotspot-jtreg-native test-image-hotspot-gtest |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1066 |
|
50908 | 1067 |
ifeq ($(INCLUDE_GRAAL), true) |
1068 |
JVM_TEST_IMAGE_TARGETS += test-image-hotspot-jtreg-graal |
|
1069 |
endif |
|
1070 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1071 |
# This target builds the test image |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1072 |
test-image: prepare-test-image \ |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1073 |
test-image-jdk-jtreg-native test-image-failure-handler \ |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1074 |
test-image-demos-jdk $(JVM_TEST_IMAGE_TARGETS) |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1075 |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1076 |
ifneq ($(JMH_CORE_JAR), ) |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1077 |
test-image: build-microbenchmark |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1078 |
endif |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1079 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1080 |
################################################################################ |
28285 | 1081 |
|
37972 | 1082 |
# all-images builds all our deliverables as images. |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1083 |
all-images: product-images test-image docs-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1084 |
|
37972 | 1085 |
# all-bundles packages all our deliverables as tar.gz bundles. |
1086 |
all-bundles: product-bundles test-bundles docs-bundles |
|
1087 |
||
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1088 |
ALL_TARGETS += buildtools hotspot hotspot-libs hotspot-gensrc gensrc gendata \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1089 |
copy java rmic libs launchers jmods \ |
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
1090 |
jdk.jdwp.agent-gensrc $(ALL_MODULES) demos \ |
41171 | 1091 |
exploded-image-base exploded-image \ |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1092 |
create-buildjdk docs-jdk-api docs-javase-api docs-reference-api docs-jdk \ |
54348 | 1093 |
docs-javase docs-reference docs-javadoc mac-bundles product-images legacy-images \ |
43043
bf14e07c9075
8172241: Cleanup mistakes in jib publish support change
erikj
parents:
42981
diff
changeset
|
1094 |
docs-image test-image all-images \ |
37972 | 1095 |
all-bundles |
25854 | 1096 |
|
1097 |
################################################################################ |
|
1098 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1099 |
# Traditional targets typically run by users. |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1100 |
# These can be considered aliases for the targets now named by a more |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1101 |
# "modern" naming scheme. |
34491 | 1102 |
default: $(DEFAULT_MAKE_TARGET) |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1103 |
jdk: exploded-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1104 |
images: product-images |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1105 |
docs: docs-image |
37972 | 1106 |
bundles: all-bundles |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1107 |
all: all-images |
25854 | 1108 |
|
37972 | 1109 |
ALL_TARGETS += default jdk images docs bundles all |
25854 | 1110 |
|
52342 | 1111 |
# Aliases used for running tests. |
1112 |
||
1113 |
# Let "run-test" be an alias for "test" |
|
1114 |
$(foreach t, $(ALL_NAMED_TESTS), $(eval run-test-$t: test-$t)) |
|
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
1115 |
RUN_TEST_TARGETS := $(addprefix run-test-, $(ALL_NAMED_TESTS)) |
52342 | 1116 |
|
1117 |
run-test: test |
|
1118 |
exploded-run-test: exploded-test |
|
1119 |
||
1120 |
# "make check" is a common idiom for running basic testing |
|
1121 |
check: test-tier1 |
|
1122 |
||
1123 |
# Keep some old names as aliases |
|
1124 |
test-hotspot-jtreg: test-hotspot_all |
|
1125 |
test-hotspot-jtreg-native: test-hotspot_native_sanity |
|
1126 |
test-hotspot-gtest: exploded-test-gtest |
|
1127 |
test-jdk-jtreg-native: test-jdk_native_sanity |
|
1128 |
||
1129 |
ALL_TARGETS += $(RUN_TEST_TARGETS) run-test exploded-run-test check \ |
|
1130 |
test-hotspot-jtreg test-hotspot-jtreg-native test-hotspot-gtest \ |
|
1131 |
test-jdk-jtreg-native |
|
1132 |
||
25854 | 1133 |
################################################################################ |
1134 |
################################################################################ |
|
1135 |
# |
|
1136 |
# Clean targets |
|
1137 |
# |
|
1138 |
################################################################################ |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
1139 |
# Clean targets are automatically run serially by the Makefile calling this |
26398
ca1f84f97e20
8057537: Serialize reconfigure and fix make clean-foo foo
erikj
parents:
26285
diff
changeset
|
1140 |
# file. |
25854 | 1141 |
|
27560 | 1142 |
CLEAN_DIRS += hotspot jdk bootcycle-build test buildtools support \ |
53995 | 1143 |
images make-support test-make bundles buildjdk test-results test-support \ |
1144 |
support/images |
|
27560 | 1145 |
CLEAN_DIR_TARGETS := $(addprefix clean-, $(CLEAN_DIRS)) |
33437 | 1146 |
CLEAN_SUPPORT_DIRS += demos |
1147 |
CLEAN_SUPPORT_DIR_TARGETS := $(addprefix clean-, $(CLEAN_SUPPORT_DIRS)) |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
1148 |
CLEAN_TESTS += hotspot-jtreg-native jdk-jtreg-native lib |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1149 |
CLEAN_TEST_TARGETS += $(addprefix clean-test-, $(CLEAN_TESTS)) |
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1150 |
CLEAN_PHASES := gensrc java native include |
27560 | 1151 |
CLEAN_PHASE_TARGETS := $(addprefix clean-, $(CLEAN_PHASES)) |
1152 |
CLEAN_MODULE_TARGETS := $(addprefix clean-, $(ALL_MODULES)) |
|
1153 |
# Construct targets of the form clean-$module-$phase |
|
1154 |
CLEAN_MODULE_PHASE_TARGETS := $(addprefix clean-, $(foreach m, $(ALL_MODULES), \ |
|
1155 |
$(addprefix $m-, $(CLEAN_PHASES)))) |
|
14111 | 1156 |
|
1157 |
# Remove everything, except the output from configure. |
|
27560 | 1158 |
clean: $(CLEAN_DIR_TARGETS) |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
1159 |
($(CD) $(OUTPUTDIR) && $(RM) -r build*.log* compile_commands.json) |
25854 | 1160 |
$(ECHO) Cleaned all build artifacts. |
1161 |
||
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1162 |
clean-docs: |
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1163 |
$(call CleanDocs) |
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1164 |
|
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1165 |
clean-compile-commands: |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1166 |
$(call CleanMakeSupportDir,compile-commands) |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1167 |
|
27560 | 1168 |
$(CLEAN_DIR_TARGETS): |
1169 |
$(call CleanDir,$(patsubst clean-%, %, $@)) |
|
1170 |
||
33437 | 1171 |
$(CLEAN_SUPPORT_DIR_TARGETS): |
1172 |
$(call CleanSupportDir,$(patsubst clean-%, %, $@)) |
|
1173 |
||
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1174 |
$(CLEAN_TEST_TARGETS): |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1175 |
$(call CleanTest,$(patsubst clean-test-%, %, $@)) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1176 |
|
27560 | 1177 |
$(CLEAN_PHASE_TARGETS): |
1178 |
$(call Clean-$(patsubst clean-%,%, $@)) |
|
1179 |
||
1180 |
$(CLEAN_MODULE_TARGETS): |
|
1181 |
$(call CleanModule,$(patsubst clean-%, %, $@)) |
|
1182 |
||
1183 |
$(CLEAN_MODULE_PHASE_TARGETS): |
|
1184 |
$(call Clean-$(word 3, $(subst -,$(SPACE),$@)), \ |
|
1185 |
$(word 2, $(subst -,$(SPACE),$@))) |
|
1186 |
||
1187 |
# When removing the support dir, we must also remove jdk. Building classes has |
|
1188 |
# the side effect of generating native headers. The headers end up in support |
|
1189 |
# while classes and touch files end up in jdk. |
|
1190 |
clean-support: clean-jdk |
|
25854 | 1191 |
|
47940 | 1192 |
clean-test: clean-test-results clean-test-support |
1193 |
||
53995 | 1194 |
# When cleaning images, also clean the support/images directory. |
1195 |
clean-images: clean-support/images |
|
1196 |
||
29790 | 1197 |
# Remove everything, including configure configuration. If the output |
1198 |
# directory was created by configure and now becomes empty, remove it as well. |
|
14111 | 1199 |
dist-clean: clean |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1200 |
($(CD) $(OUTPUTDIR) && \ |
51678
2fdfe34f7262
8081858: make dist-clean does not delete all log files
ihse
parents:
50908
diff
changeset
|
1201 |
$(RM) -r *spec.gmk $(CONFIGURESUPPORT_OUTPUTDIR) Makefile compare.sh ide \ |
2fdfe34f7262
8081858: make dist-clean does not delete all log files
ihse
parents:
50908
diff
changeset
|
1202 |
configure.log* build.log*) |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1203 |
$(if $(filter $(CONF_NAME),$(notdir $(OUTPUTDIR))), \ |
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1204 |
if test "x`$(LS) $(OUTPUTDIR)`" != x; then \ |
20363 | 1205 |
$(ECHO) "Warning: Not removing non-empty configuration directory for '$(CONF_NAME)'" ; \ |
1206 |
else \ |
|
47217 | 1207 |
($(CD) $(TOPDIR) && $(ECHO) "Removing configuration directory for '$(CONF_NAME)'" \ |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1208 |
&& $(RM) -r $(OUTPUTDIR)) \ |
20363 | 1209 |
fi \ |
1210 |
) |
|
25854 | 1211 |
$(ECHO) Cleaned everything, you will have to re-run configure. |
1212 |
||
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1213 |
ALL_TARGETS += clean clean-docs clean-compile-commands dist-clean $(CLEAN_DIR_TARGETS) \ |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1214 |
$(CLEAN_SUPPORT_DIR_TARGETS) $(CLEAN_TEST_TARGETS) $(CLEAN_PHASE_TARGETS) \ |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1215 |
$(CLEAN_MODULE_TARGETS) $(CLEAN_MODULE_PHASE_TARGETS) |
25854 | 1216 |
|
1217 |
################################################################################ |
|
1218 |
# Declare *-only targets for each normal target |
|
1219 |
$(foreach t, $(ALL_TARGETS), $(eval $(t)-only: $(t))) |
|
14111 | 1220 |
|
29662 | 1221 |
ALL_TARGETS += $(addsuffix -only, $(filter-out dist-clean clean%, $(ALL_TARGETS))) |
1222 |
||
1223 |
################################################################################ |
|
1224 |
||
29788 | 1225 |
# The following targets are intentionally not added to ALL_TARGETS since they |
1226 |
# are internal only, to support Init.gmk. |
|
1227 |
||
29662 | 1228 |
print-targets: |
1229 |
@$(ECHO) $(sort $(ALL_TARGETS)) |
|
1230 |
||
1231 |
print-modules: |
|
1232 |
@$(ECHO) $(sort $(ALL_MODULES)) |
|
1233 |
||
44027 | 1234 |
print-tests: |
1235 |
@$(ECHO) $(sort $(ALL_NAMED_TESTS)) |
|
1236 |
||
29788 | 1237 |
create-main-targets-include: |
35008 | 1238 |
$(call LogInfo, Generating main target list) |
29788 | 1239 |
@$(ECHO) ALL_MAIN_TARGETS := $(sort $(ALL_TARGETS)) > \ |
1240 |
$(MAKESUPPORT_OUTPUTDIR)/main-targets.gmk |
|
25854 | 1241 |
|
1242 |
################################################################################ |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1243 |
# Hook to include the corresponding custom file, if present. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1244 |
$(eval $(call IncludeCustomExtension, Main-post.gmk)) |
25854 | 1245 |
|
1246 |
.PHONY: $(ALL_TARGETS) |
|
1247 |
||
14111 | 1248 |
FRC: # Force target |