author | joehw |
Mon, 30 Sep 2019 17:54:11 +0000 | |
changeset 58411 | cece74021580 |
parent 54490 | bf07e140c49c |
child 58665 | 30a5049a36bb |
child 58747 | c6fd655677ec |
permissions | -rw-r--r-- |
37437 | 1 |
# |
53542
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
2 |
# Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved. |
37437 | 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 |
||
47314 | 26 |
$(eval $(call IncludeCustomExtension, hotspot/gensrc/GensrcAdlc.gmk)) |
37437 | 27 |
|
28 |
ifeq ($(call check-jvm-feature, compiler2), true) |
|
29 |
||
30 |
ADLC_SUPPORT_DIR := $(JVM_SUPPORT_DIR)/adlc |
|
31 |
||
32 |
############################################################################## |
|
33 |
# Build the ad compiler (the adlc build tool) |
|
34 |
||
35 |
# Flags depending on the build platform/tool chain |
|
36 |
# NOTE: No optimization or debug flags set here |
|
53683 | 37 |
ifeq ($(call isBuildOs, linux), true) |
37437 | 38 |
ADLC_CFLAGS := -fno-exceptions -DLINUX |
53683 | 39 |
else ifeq ($(call isBuildOs, solaris), true) |
37437 | 40 |
ADLC_LDFLAGS := -m64 |
41 |
ADLC_CFLAGS := -m64 |
|
42 |
ADLC_CFLAGS_WARNINGS := +w |
|
53683 | 43 |
else ifeq ($(call isBuildOs, aix), true) |
37469
ac811846846c
8154087: Fix AIX and Linux/ppc64le after the integration of the new hotspot build
simonis
parents:
37437
diff
changeset
|
44 |
ADLC_LDFLAGS := -q64 |
ac811846846c
8154087: Fix AIX and Linux/ppc64le after the integration of the new hotspot build
simonis
parents:
37437
diff
changeset
|
45 |
ADLC_CFLAGS := -qnortti -qeh -q64 -DAIX |
53683 | 46 |
else ifeq ($(call isBuildOs, windows), true) |
37437 | 47 |
ADLC_LDFLAGS := -nologo |
48 |
ADLC_CFLAGS := -nologo -EHsc |
|
49 |
# NOTE: The old build also have -D_CRT_SECURE_NO_DEPRECATE but it doesn't |
|
50 |
# seem needed any more. |
|
51 |
ADLC_CFLAGS_WARNINGS := -W3 -D_CRT_SECURE_NO_WARNINGS |
|
52 |
endif |
|
53 |
||
39963
5921b7f27d63
8156980: Hotspot build doesn't have -std=gnu++98 gcc option
andrew
parents:
38097
diff
changeset
|
54 |
# Set the C++ standard if supported |
49120 | 55 |
ADLC_CFLAGS += $(ADLC_CXXFLAG) |
49070
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47314
diff
changeset
|
56 |
|
37437 | 57 |
# NOTE: The old build didn't set -DASSERT for windows but it doesn't seem to |
58 |
# hurt. |
|
59 |
ADLC_CFLAGS += -DASSERT |
|
60 |
||
61 |
ADLC_CFLAGS += -D$(HOTSPOT_TARGET_CPU_DEFINE) |
|
62 |
||
47217 | 63 |
ADLC_CFLAGS += -I$(TOPDIR)/src/hotspot/share |
37437 | 64 |
|
65 |
$(eval $(call SetupNativeCompilation, BUILD_ADLC, \ |
|
49070
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47314
diff
changeset
|
66 |
NAME := adlc, \ |
d7859531621b
8198751: Refactor SetupNativeCompilation to take NAME and TYPE
ihse
parents:
47314
diff
changeset
|
67 |
TYPE := EXECUTABLE, \ |
37437 | 68 |
TOOLCHAIN := TOOLCHAIN_BUILD_LINK_CXX, \ |
47217 | 69 |
SRC := $(TOPDIR)/src/hotspot/share/adlc, \ |
70 |
EXTRA_FILES := $(TOPDIR)/src/hotspot/share/opto/opcodes.cpp, \ |
|
37437 | 71 |
CFLAGS := $(ADLC_CFLAGS) $(ADLC_CFLAGS_WARNINGS), \ |
72 |
LDFLAGS := $(ADLC_LDFLAGS), \ |
|
73 |
LIBS := $(ADLC_LIBS), \ |
|
74 |
OBJECT_DIR := $(JVM_VARIANT_OUTPUTDIR)/tools/adlc/objs, \ |
|
75 |
OUTPUT_DIR := $(JVM_VARIANT_OUTPUTDIR)/tools/adlc, \ |
|
76 |
DEBUG_SYMBOLS := false, \ |
|
46630
75aa3e39d02c
8182299: Enable disabled clang warnings, build on OSX 10 + Xcode 8
jwilhelm
parents:
42664
diff
changeset
|
77 |
DISABLED_WARNINGS_clang := tautological-compare, \ |
37437 | 78 |
DISABLED_WARNINGS_solstudio := notemsource, \ |
54490
bf07e140c49c
8221851: Use of THIS_FILE in hotspot invalidates precompiled header on Linux/GCC
erikj
parents:
53997
diff
changeset
|
79 |
DEFINE_THIS_FILE := false, \ |
37437 | 80 |
)) |
81 |
||
82 |
ADLC_TOOL := $(BUILD_ADLC_TARGET) |
|
83 |
||
84 |
############################################################################## |
|
85 |
# Transform the ad source files into C++ source files using adlc |
|
86 |
||
87 |
# Setup flags for the adlc build tool (ADLCFLAGS). |
|
88 |
ADLCFLAGS += -q -T |
|
89 |
||
90 |
# ADLC flags depending on target OS |
|
53683 | 91 |
ifeq ($(call isTargetOs, linux), true) |
37437 | 92 |
ADLCFLAGS += -DLINUX=1 -D_GNU_SOURCE=1 |
53683 | 93 |
else ifeq ($(call isTargetOs, solaris), true) |
37437 | 94 |
ADLCFLAGS += -DSOLARIS=1 -DSPARC_WORKS=1 |
53683 | 95 |
else ifeq ($(call isTargetOs, aix), true) |
37469
ac811846846c
8154087: Fix AIX and Linux/ppc64le after the integration of the new hotspot build
simonis
parents:
37437
diff
changeset
|
96 |
ADLCFLAGS += -DAIX=1 |
53683 | 97 |
else ifeq ($(call isTargetOs, macosx), true) |
37437 | 98 |
ADLCFLAGS += -D_ALLBSD_SOURCE=1 -D_GNU_SOURCE=1 |
99 |
endif |
|
100 |
||
53683 | 101 |
ifeq ($(call isTargetOs, windows), false) |
37437 | 102 |
# NOTE: Windows adlc flags was different in the old build. Is this really |
103 |
# correct? |
|
104 |
||
105 |
# -g makes #line directives in the generated C++ files. |
|
106 |
ADLCFLAGS += -g |
|
107 |
||
108 |
ADLCFLAGS += -D$(HOTSPOT_TARGET_CPU_DEFINE)=1 |
|
109 |
endif |
|
110 |
||
111 |
# This generates checks in the generated C++ files that _LP64 is correctly |
|
112 |
# (un)defined when compiling them. |
|
53683 | 113 |
ifeq ($(call isTargetCpuBits, 64), true) |
37437 | 114 |
ADLCFLAGS += -D_LP64=1 |
115 |
else |
|
116 |
ADLCFLAGS += -U_LP64 |
|
117 |
endif |
|
118 |
||
42664 | 119 |
ifeq ($(HOTSPOT_TARGET_CPU_ARCH), arm) |
120 |
ADLCFLAGS += -DARM=1 |
|
121 |
endif |
|
122 |
||
37437 | 123 |
############################################################################## |
124 |
# Concatenate all ad source files into a single file, which will be fed to |
|
125 |
# adlc. Also include a #line directive at the start of every included file |
|
126 |
# (after the initial header block), stating the original source file name. |
|
127 |
# |
|
128 |
# Normally, debugging is done directly on the ad_<arch>*.cpp files, but the |
|
129 |
# #line directives in those files will be pointing back to <arch>.ad. |
|
130 |
||
131 |
# AD_SRC_ROOTS might have been added to by a custom extension |
|
47217 | 132 |
AD_SRC_ROOTS += $(TOPDIR)/src/hotspot |
37437 | 133 |
|
134 |
AD_SRC_FILES := $(call uniq, $(wildcard $(foreach d, $(AD_SRC_ROOTS), \ |
|
47217 | 135 |
$d/cpu/$(HOTSPOT_TARGET_CPU_ARCH)/$(HOTSPOT_TARGET_CPU).ad \ |
136 |
$d/cpu/$(HOTSPOT_TARGET_CPU_ARCH)/$(HOTSPOT_TARGET_CPU_ARCH).ad \ |
|
137 |
$d/os_cpu/$(HOTSPOT_TARGET_OS)_$(HOTSPOT_TARGET_CPU_ARCH)/$(HOTSPOT_TARGET_OS)_$(HOTSPOT_TARGET_CPU_ARCH).ad \ |
|
37437 | 138 |
))) |
139 |
||
52925
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
140 |
ifeq ($(call check-jvm-feature, shenandoahgc), true) |
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
141 |
AD_SRC_FILES += $(call uniq, $(wildcard $(foreach d, $(AD_SRC_ROOTS), \ |
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
142 |
$d/cpu/$(HOTSPOT_TARGET_CPU_ARCH)/gc/shenandoah/shenandoah_$(HOTSPOT_TARGET_CPU).ad \ |
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
143 |
))) |
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
144 |
endif |
9c18c9d839d3
8214259: Implementation: JEP 189: Shenandoah: A Low-Pause-Time Garbage Collector (Experimental)
rkennke
parents:
49120
diff
changeset
|
145 |
|
53542
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
146 |
ifeq ($(call check-jvm-feature, zgc), true) |
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
147 |
AD_SRC_FILES += $(call uniq, $(wildcard $(foreach d, $(AD_SRC_ROOTS), \ |
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
148 |
$d/cpu/$(HOTSPOT_TARGET_CPU_ARCH)/gc/z/z_$(HOTSPOT_TARGET_CPU).ad \ |
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
149 |
))) |
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
150 |
endif |
5c80e6994d8a
8217856: ZGC: Break out C2 matching rules into separate AD file
pliden
parents:
52925
diff
changeset
|
151 |
|
37437 | 152 |
SINGLE_AD_SRCFILE := $(ADLC_SUPPORT_DIR)/all-ad-src.ad |
153 |
||
154 |
INSERT_FILENAME_AWK_SCRIPT := \ |
|
155 |
'{ \ |
|
156 |
if (CUR_FN != FILENAME) { CUR_FN=FILENAME; NR_BASE=NR-1; need_lineno=1 } \ |
|
157 |
if (need_lineno && $$0 !~ /\/\//) \ |
|
158 |
{ print "\n\n\#line " (NR-NR_BASE) " \"" FILENAME "\""; need_lineno=0 }; \ |
|
159 |
print \ |
|
160 |
}' |
|
161 |
||
162 |
$(SINGLE_AD_SRCFILE): $(AD_SRC_FILES) |
|
163 |
$(call LogInfo, Preprocessing adlc files $(^F)) |
|
164 |
$(call MakeDir, $(@D)) |
|
165 |
$(NAWK) $(INSERT_FILENAME_AWK_SCRIPT) $^ > $@ |
|
166 |
||
167 |
############################################################################## |
|
168 |
# Run the adlc tool on the single concatenated ad source file, and store the |
|
169 |
# output in support/adlc for further processing. |
|
53995 | 170 |
$(eval $(call SetupExecute, adlc_run, \ |
171 |
INFO := Generating adlc files, \ |
|
172 |
DEPS := $(BUILD_ADLC) $(SINGLE_AD_SRCFILE), \ |
|
173 |
OUTPUT_DIR := $(ADLC_SUPPORT_DIR), \ |
|
174 |
COMMAND := $(FIXPATH) $(ADLC_TOOL) $(ADLCFLAGS) $(SINGLE_AD_SRCFILE) \ |
|
175 |
-c$(ADLC_SUPPORT_DIR)/ad_$(HOTSPOT_TARGET_CPU_ARCH).cpp \ |
|
176 |
-h$(ADLC_SUPPORT_DIR)/ad_$(HOTSPOT_TARGET_CPU_ARCH).hpp \ |
|
177 |
-a$(ADLC_SUPPORT_DIR)/dfa_$(HOTSPOT_TARGET_CPU_ARCH).cpp \ |
|
178 |
-v$(ADLC_SUPPORT_DIR)/adGlobals_$(HOTSPOT_TARGET_CPU_ARCH).hpp, \ |
|
179 |
)) |
|
37437 | 180 |
|
181 |
############################################################################## |
|
182 |
# Finally copy the generated files from support/adlc into gensrc/adfiles, |
|
183 |
# and postprocess them by fixing dummy #line directives. |
|
184 |
||
185 |
ADLC_GENERATED_FILES := $(addprefix $(JVM_VARIANT_OUTPUTDIR)/gensrc/adfiles/, \ |
|
40010 | 186 |
ad_$(HOTSPOT_TARGET_CPU_ARCH).cpp \ |
187 |
ad_$(HOTSPOT_TARGET_CPU_ARCH).hpp \ |
|
188 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_clone.cpp \ |
|
189 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_expand.cpp \ |
|
190 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_format.cpp \ |
|
191 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_gen.cpp \ |
|
192 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_misc.cpp \ |
|
193 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_peephole.cpp \ |
|
194 |
ad_$(HOTSPOT_TARGET_CPU_ARCH)_pipeline.cpp \ |
|
195 |
adGlobals_$(HOTSPOT_TARGET_CPU_ARCH).hpp \ |
|
196 |
dfa_$(HOTSPOT_TARGET_CPU_ARCH).cpp \ |
|
37437 | 197 |
) |
198 |
||
53995 | 199 |
$(JVM_VARIANT_OUTPUTDIR)/gensrc/adfiles/%: $(adlc_run_TARGET) |
37437 | 200 |
$(call LogInfo, Postprocessing adlc file $*) |
201 |
$(call MakeDir, $(@D)) |
|
202 |
$(NAWK) \ |
|
203 |
'BEGIN { print "#line 1 \"$*\""; } \ |
|
204 |
/^#line 999999$$/ {print "#line " (NR+1) " \"$*\""; next} \ |
|
205 |
{print}' \ |
|
206 |
< $(ADLC_SUPPORT_DIR)/$* > $@ |
|
207 |
||
53997 | 208 |
TARGETS += $(ADLC_GENERATED_FILES) |
37437 | 209 |
|
210 |
endif |