Mercurial > hg > truffle
annotate make/windows/build.make @ 2619:1586b1b56f0c
Fixed typo.
author | Thomas Wuerthinger <thomas@wuerthinger.net> |
---|---|
date | Mon, 09 May 2011 19:12:45 +0200 |
parents | 34bd82eba3bb |
children | 69e41359aef0 |
rev | line source |
---|---|
0 | 1 # |
1783 | 2 # Copyright (c) 1998, 2010, Oracle and/or its affiliates. All rights reserved. |
0 | 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. | |
8 # | |
9 # This code is distributed in the hope that it will be useful, but WITHOUT | |
10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 # version 2 for more details (a copy is included in the LICENSE file that | |
13 # accompanied this code). | |
14 # | |
15 # You should have received a copy of the GNU General Public License version | |
16 # 2 along with this work; if not, write to the Free Software Foundation, | |
17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 # | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1328
diff
changeset
|
19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1328
diff
changeset
|
20 # or visit www.oracle.com if you need additional information or have any |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1328
diff
changeset
|
21 # questions. |
1783 | 22 # |
0 | 23 # |
24 | |
25 # Note: this makefile is invoked both from build.bat and from the J2SE | |
26 # control workspace in exactly the same manner; the required | |
27 # environment variables (Variant, WorkSpace, BootStrapDir, BuildUser, HOTSPOT_BUILD_VERSION) | |
28 # are passed in as command line arguments. | |
29 | |
1328
39e409a664b3
6938185: 3/4 6923488 breaks Windows command shell builds
dcubed
parents:
1322
diff
changeset
|
30 # Note: Running nmake or build.bat from the Windows command shell requires |
39e409a664b3
6938185: 3/4 6923488 breaks Windows command shell builds
dcubed
parents:
1322
diff
changeset
|
31 # that "sh" be accessible on the PATH. An MKS install does this. |
39e409a664b3
6938185: 3/4 6923488 breaks Windows command shell builds
dcubed
parents:
1322
diff
changeset
|
32 |
0 | 33 # SA components are built if BUILD_WIN_SA=1 is specified. |
34 # See notes in README. This produces files: | |
35 # 1. sa-jdi.jar - This is built before building jvm.dll | |
36 # 2. sawindbg[_g].dll - Native library for SA - This is built after jvm.dll | |
37 # - Also, .lib, .map, .pdb. | |
38 # | |
39 # Please refer to ./makefiles/sa.make | |
40 | |
41 # If we haven't set an ARCH yet use x86 | |
42 # create.bat and build.bat will set it, if used. | |
43 !ifndef ARCH | |
44 ARCH=x86 | |
45 !endif | |
46 | |
47 | |
48 # Must be one of these values (if value comes in from env, can't trust it) | |
49 !if "$(ARCH)" != "x86" | |
50 !if "$(ARCH)" != "ia64" | |
51 ARCH=x86 | |
52 !endif | |
53 !endif | |
54 | |
55 # At this point we should be certain that ARCH has a definition | |
56 # now determine the BUILDARCH | |
57 # | |
58 | |
59 # the default BUILDARCH | |
60 BUILDARCH=i486 | |
61 | |
62 # Allow control workspace to force Itanium or AMD64 builds with LP64 | |
63 ARCH_TEXT= | |
64 !ifdef LP64 | |
65 !if "$(LP64)" == "1" | |
66 ARCH_TEXT=64-Bit | |
67 !if "$(ARCH)" == "x86" | |
68 BUILDARCH=amd64 | |
69 !else | |
70 BUILDARCH=ia64 | |
71 !endif | |
72 !endif | |
73 !endif | |
74 | |
75 !if "$(BUILDARCH)" != "ia64" | |
76 !ifndef CC_INTERP | |
1918 | 77 !ifndef FORCE_TIERED |
0 | 78 FORCE_TIERED=1 |
79 !endif | |
80 !endif | |
1918 | 81 !endif |
0 | 82 |
83 !if "$(BUILDARCH)" == "amd64" | |
84 Platform_arch=x86 | |
85 Platform_arch_model=x86_64 | |
86 !endif | |
87 !if "$(BUILDARCH)" == "i486" | |
88 Platform_arch=x86 | |
89 Platform_arch_model=x86_32 | |
90 !endif | |
91 | |
92 # Supply these from the command line or the environment | |
93 # It doesn't make sense to default this one | |
94 Variant= | |
95 # It doesn't make sense to default this one | |
96 WorkSpace= | |
97 | |
98 variantDir = windows_$(BUILDARCH)_$(Variant) | |
99 | |
100 realVariant=$(Variant) | |
101 VARIANT_TEXT=Core | |
102 !if "$(Variant)" == "compiler1" | |
103 VARIANT_TEXT=Client | |
104 !elseif "$(Variant)" == "compiler2" | |
1918 | 105 !if "$(FORCE_TIERED)" == "1" |
0 | 106 VARIANT_TEXT=Server |
107 realVariant=tiered | |
108 !else | |
109 VARIANT_TEXT=Server | |
110 !endif | |
111 !elseif "$(Variant)" == "tiered" | |
112 VARIANT_TEXT=Tiered | |
113 !elseif "$(Variant)" == "kernel" | |
114 VARIANT_TEXT=Kernel | |
115 !endif | |
116 | |
117 ######################################################################### | |
118 # Parameters for VERSIONINFO resource for jvm[_g].dll. | |
119 # These can be overridden via the nmake.exe command line. | |
120 # They are overridden by RE during the control builds. | |
121 # | |
122 !include "$(WorkSpace)/make/hotspot_version" | |
123 | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
124 # Define HOTSPOT_VM_DISTRO based on settings in make/openjdk_distro |
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
125 # or make/hotspot_distro. |
0 | 126 !ifndef HOTSPOT_VM_DISTRO |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
127 !if exists($(WorkSpace)\src\closed) |
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
128 !include $(WorkSpace)\make\hotspot_distro |
0 | 129 !else |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
130 !include $(WorkSpace)\make\openjdk_distro |
0 | 131 !endif |
132 !endif | |
133 | |
134 # Following the Web Start / Plugin model here.... | |
135 # We can have update versions like "01a", but Windows requires | |
136 # we use only integers in the file version field. So: | |
137 # JDK_UPDATE_VER = JDK_UPDATE_VERSION * 10 + EXCEPTION_VERSION | |
1783 | 138 # |
0 | 139 JDK_UPDATE_VER=0 |
140 JDK_BUILD_NUMBER=0 | |
141 | |
142 HS_FILEDESC=$(HOTSPOT_VM_DISTRO) $(ARCH_TEXT) $(VARIANT_TEXT) VM | |
143 | |
144 # JDK ProductVersion: | |
145 # 1.5.0_<wx>-b<yz> will have DLL version 5.0.wx*10.yz | |
146 # Thus, 1.5.0_10-b04 will be 5.0.100.4 | |
147 # 1.6.0-b01 will be 6.0.0.1 | |
148 # 1.6.0_01a-b02 will be 6.0.11.2 | |
149 # | |
150 # JDK_* variables are defined in make/hotspot_version or on command line | |
1783 | 151 # |
0 | 152 JDK_VER=$(JDK_MINOR_VER),$(JDK_MICRO_VER),$(JDK_UPDATE_VER),$(JDK_BUILD_NUMBER) |
153 JDK_DOTVER=$(JDK_MINOR_VER).$(JDK_MICRO_VER).$(JDK_UPDATE_VER).$(JDK_BUILD_NUMBER) | |
154 !if "$(JRE_RELEASE_VERSION)" == "" | |
155 JRE_RELEASE_VER=$(JDK_MAJOR_VER).$(JDK_MINOR_VER).$(JDK_MICRO_VER) | |
156 !else | |
157 JRE_RELEASE_VER=$(JRE_RELEASE_VERSION) | |
158 !endif | |
159 !if "$(JDK_MKTG_VERSION)" == "" | |
160 JDK_MKTG_VERSION=$(JDK_MINOR_VER).$(JDK_MICRO_VER) | |
161 !endif | |
162 | |
163 # Hotspot Express VM FileVersion: | |
164 # 10.0-b<yz> will have DLL version 10.0.0.yz (need 4 numbers). | |
1783 | 165 # |
0 | 166 # HS_* variables are defined in make/hotspot_version |
167 # | |
168 HS_VER=$(HS_MAJOR_VER),$(HS_MINOR_VER),0,$(HS_BUILD_NUMBER) | |
169 HS_DOTVER=$(HS_MAJOR_VER).$(HS_MINOR_VER).0.$(HS_BUILD_NUMBER) | |
170 | |
171 !if "$(HOTSPOT_RELEASE_VERSION)" == "" | |
172 HOTSPOT_RELEASE_VERSION=$(HS_MAJOR_VER).$(HS_MINOR_VER)-b$(HS_BUILD_NUMBER) | |
173 !endif | |
174 | |
175 !if "$(HOTSPOT_BUILD_VERSION)" == "" | |
176 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION) | |
177 !else | |
178 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION) | |
179 !endif | |
180 | |
181 # End VERSIONINFO parameters | |
182 | |
183 | |
184 # We don't support SA on ia64, and we can't | |
1783 | 185 # build it if we are using a version of Vis Studio |
0 | 186 # older than .Net 2003. |
187 # SA_INCLUDE and SA_LIB are hold-overs from a previous | |
188 # implementation in which we could build SA using | |
189 # Debugging Tools For Windows, in which the .h/.lib files | |
190 # and the .dlls are in different places than | |
191 # they are for Vis Studio .Net 2003. | |
192 # If that code ever needs to be resurrected, these vars | |
193 # can be set here. They are used in makefiles/sa.make. | |
194 | |
195 checkSA:: | |
196 | |
197 !if "$(BUILD_WIN_SA)" != "1" | |
198 checkSA:: | |
199 @echo Not building SA: BUILD_WIN_SA != 1 | |
200 | |
201 !elseif "$(ARCH)" == "ia64" | |
202 BUILD_WIN_SA = 0 | |
203 checkSA:: | |
204 @echo Not building SA: ARCH = ia64 | |
205 | |
206 !endif # ! "$(BUILD_WIN_SA)" != "1" | |
207 | |
208 ######################################################################### | |
209 | |
210 # With the jvm_g.dll now being named jvm.dll, we can't build both and place | |
211 # the dll's in the same directory, so we only build one at a time, | |
212 # re-directing the output to different output directories (done by user | |
213 # of this makefile). | |
214 # | |
215 defaultTarget: product | |
216 | |
217 # The product or release build is an optimized build, and is the default | |
218 | |
219 # note that since all the build targets depend on local.make that BUILDARCH | |
220 # and Platform_arch and Platform_arch_model will get set in local.make | |
221 # and there is no need to pass them thru here on the command line | |
222 # | |
223 product release optimized: checks $(variantDir) $(variantDir)\local.make sanity | |
224 cd $(variantDir) | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
225 nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=product ARCH=$(ARCH) |
0 | 226 |
227 # The debug or jvmg (all the same thing) is an optional build | |
228 debug jvmg: checks $(variantDir) $(variantDir)\local.make sanity | |
229 cd $(variantDir) | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
230 nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=debug ARCH=$(ARCH) |
0 | 231 fastdebug: checks $(variantDir) $(variantDir)\local.make sanity |
232 cd $(variantDir) | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
233 nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=fastdebug ARCH=$(ARCH) |
0 | 234 |
235 develop: checks $(variantDir) $(variantDir)\local.make sanity | |
236 cd $(variantDir) | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
237 nmake -nologo -f $(WorkSpace)\make\windows\makefiles\top.make BUILD_FLAVOR=product DEVELOP=1 ARCH=$(ARCH) |
0 | 238 |
1322
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
239 # target to create just the directory structure |
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
240 tree: checks $(variantDir) $(variantDir)\local.make sanity |
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
241 mkdir $(variantDir)\product |
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
242 mkdir $(variantDir)\debug |
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
243 mkdir $(variantDir)\fastdebug |
21141e23627a
6923488: 4/4 need minor tweaks to HotSpot build for Cygwin
dcubed
parents:
456
diff
changeset
|
244 |
0 | 245 sanity: |
246 @ echo; | |
247 @ cd $(variantDir) | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
248 @ nmake -nologo -f $(WorkSpace)\make\windows\makefiles\sanity.make |
0 | 249 @ cd .. |
250 @ echo; | |
251 | |
252 clean: checkVariant | |
253 - rm -r -f $(variantDir) | |
254 | |
255 $(variantDir): | |
256 mkdir $(variantDir) | |
257 | |
258 $(variantDir)\local.make: checks | |
259 @ echo # Generated file > $@ | |
260 @ echo Variant=$(realVariant) >> $@ | |
261 @ echo WorkSpace=$(WorkSpace) >> $@ | |
262 @ echo BootStrapDir=$(BootStrapDir) >> $@ | |
263 @ if "$(USERNAME)" NEQ "" echo BuildUser=$(USERNAME) >> $@ | |
264 @ echo HS_VER=$(HS_VER) >> $@ | |
265 @ echo HS_DOTVER=$(HS_DOTVER) >> $@ | |
266 @ echo HS_COMPANY=$(COMPANY_NAME) >> $@ | |
267 @ echo HS_FILEDESC=$(HS_FILEDESC) >> $@ | |
268 @ echo HOTSPOT_VM_DISTRO=$(HOTSPOT_VM_DISTRO) >> $@ | |
269 @ echo HS_COPYRIGHT=$(HOTSPOT_VM_COPYRIGHT) >> $@ | |
270 @ echo HS_NAME=$(PRODUCT_NAME) $(JDK_MKTG_VERSION) >> $@ | |
271 @ echo HS_BUILD_VER=$(HS_BUILD_VER) >> $@ | |
272 @ echo BUILD_WIN_SA=$(BUILD_WIN_SA) >> $@ | |
273 @ echo SA_BUILD_VERSION=$(HS_BUILD_VER) >> $@ | |
274 @ echo SA_INCLUDE=$(SA_INCLUDE) >> $@ | |
275 @ echo SA_LIB=$(SA_LIB) >> $@ | |
276 @ echo JDK_VER=$(JDK_VER) >> $@ | |
277 @ echo JDK_DOTVER=$(JDK_DOTVER) >> $@ | |
278 @ echo JRE_RELEASE_VER=$(JRE_RELEASE_VER) >> $@ | |
279 @ echo BUILDARCH=$(BUILDARCH) >> $@ | |
280 @ echo Platform_arch=$(Platform_arch) >> $@ | |
281 @ echo Platform_arch_model=$(Platform_arch_model) >> $@ | |
91
a294fd0c4b38
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
0
diff
changeset
|
282 @ sh $(WorkSpace)/make/windows/get_msc_ver.sh >> $@ |
0 | 283 |
284 checks: checkVariant checkWorkSpace checkSA | |
285 | |
286 checkVariant: | |
287 @ if "$(Variant)"=="" echo Need to specify "Variant=[tiered|compiler2|compiler1|kernel|core]" && false | |
288 @ if "$(Variant)" NEQ "tiered" if "$(Variant)" NEQ "compiler2" if "$(Variant)" NEQ "compiler1" if "$(Variant)" NEQ "kernel" if "$(Variant)" NEQ "core" \ | |
289 echo Need to specify "Variant=[tiered|compiler2|compiler1|kernel|core]" && false | |
290 | |
291 checkWorkSpace: | |
292 @ if "$(WorkSpace)"=="" echo Need to specify "WorkSpace=..." && false | |
293 | |
294 checkBuildID: | |
295 @ if "$(BuildID)"=="" echo Need to specify "BuildID=..." && false |