This commit is contained in:
Christine Lu 2011-03-23 17:43:38 -07:00
commit 23fcdda219
2 changed files with 302 additions and 97 deletions

9
README
View File

@ -29,13 +29,14 @@ Simple Build Instructions:
Set the environment variable ALT_BOOTDIR to the location of JDK 6. Set the environment variable ALT_BOOTDIR to the location of JDK 6.
2. Check the sanity of doing a build with your current system: 2. Check the sanity of doing a build with your current system:
gnumake sanity make sanity
See README-builds.html if you run into problems. See README-builds.html if you run into problems.
3. Do a complete build of the OpenJDK: 3. Do a complete build of the OpenJDK:
gnumake all make all
The resulting JDK image should be found in build/*/j2sdk-image The resulting JDK image should be found in build/*/j2sdk-image
where gnumake is GNU make 3.81 or newer, /usr/bin/make on Linux and where make is GNU make 3.81 or newer, /usr/bin/make on Linux usually
/usr/sfw/bin/gmake or /opt/sfw/bin/gmake on Solaris. is 3.81 or newer.
Complete details are available in README-builds.html.

View File

@ -54,7 +54,11 @@
<li><a href="#opensolaris">OpenSolaris</a></li> <li><a href="#opensolaris">OpenSolaris</a></li>
</ul> </ul>
</li> </li>
<li><a href="#directories">Source Directory Structure</a> </li> <li><a href="#directories">Source Directory Structure</a>
<ul>
<li><a href="#drops">Managing the Source Drops</a></li>
</ul>
</li>
<li><a href="#building">Build Information</a> <li><a href="#building">Build Information</a>
<ul> <ul>
<li><a href="#gmake">GNU Make (<tt><i>gmake</i></tt>)</a> </li> <li><a href="#gmake">GNU Make (<tt><i>gmake</i></tt>)</a> </li>
@ -65,7 +69,7 @@
<ul> <ul>
<li><a href="#bootjdk">Bootstrap JDK</a> </li> <li><a href="#bootjdk">Bootstrap JDK</a> </li>
<li><a href="#importjdk">Optional Import JDK</a> </li> <li><a href="#importjdk">Optional Import JDK</a> </li>
<li><a href="#ant">Ant</a> </li> <li><a href="#ant">Ant 1.7.1</a> </li>
<li><a href="#cacerts">Certificate Authority File (cacert)</a> </li> <li><a href="#cacerts">Certificate Authority File (cacert)</a> </li>
<li><a href="#compilers">Compilers</a> <li><a href="#compilers">Compilers</a>
<ul> <ul>
@ -114,13 +118,13 @@
<a href="http://mercurial.selenic.com/wiki/Mercurial">Mercurial</a>. <a href="http://mercurial.selenic.com/wiki/Mercurial">Mercurial</a>.
If you are new to Mercurial, please see the If you are new to Mercurial, please see the
<a href="http://mercurial.selenic.com/wiki/BeginnersGuides">Beginner Guides</a> <a href="http://mercurial.selenic.com/wiki/BeginnersGuides">Beginner Guides</a>
or refer to the <a href=""http://hgbook.red-bean.com/">Mercurial Book</a>. or refer to the <a href="http://hgbook.red-bean.com/">Mercurial Book</a>.
The first few chapters of the book provide an excellent overview of The first few chapters of the book provide an excellent overview of
Mercurial, what it is and how it works. Mercurial, what it is and how it works.
<br> <br>
For using Mercurial with the OpenJDK refer to the For using Mercurial with the OpenJDK refer to the
<a href=""http://openjdk.java.net/guide/repositories.html#installConfig"> <a href="http://openjdk.java.net/guide/repositories.html#installConfig">
Developer Guide: Installing and Configuring Mercurial</a> Developer Guide: Installing and Configuring Mercurial</a>
section for more information. section for more information.
The Forest Extension is not part of the Mercurial install, The Forest Extension is not part of the Mercurial install,
and is optional, and is optional,
@ -146,14 +150,14 @@
using the Forest Extension: using the Forest Extension:
<blockquote> <blockquote>
<tt> <tt>
hg fclone http://openjdk.java.net/jdk7/jdk7 <i>YourOpenJDK</i> hg fclone http://hg.openjdk.java.net/jdk7/jdk7 <i>YourOpenJDK</i>
</tt> </tt>
</blockquote> </blockquote>
To get the entire set of OpenJDK Mercurial repositories To get the entire set of OpenJDK Mercurial repositories
without using the Forest Extension: without using the Forest Extension:
<blockquote> <blockquote>
<tt> <tt>
hg clone http://openjdk.java.net/jdk7/jdk7 <i>YourOpenJDK</i> hg clone http://hg.openjdk.java.net/jdk7/jdk7 <i>YourOpenJDK</i>
<br>cd <i>YourOpenJDK</i> <br>cd <i>YourOpenJDK</i>
<br>sh ./get_source.sh <br>sh ./get_source.sh
</tt> </tt>
@ -207,66 +211,50 @@
<tr> <tr>
<td>Linux X86 (32-bit)</td> <td>Linux X86 (32-bit)</td>
<td>Fedora 9</td> <td>Fedora 9</td>
<td>gcc 4 </td> <td>gcc 4.3 </td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Linux X64 (64-bit)</td> <td>Linux X64 (64-bit)</td>
<td>Fedora 9</td> <td>Fedora 9</td>
<td>gcc 4 </td> <td>gcc 4.3 </td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Solaris SPARC (32-bit)</td> <td>Solaris SPARC (32-bit)</td>
<td>Solaris 10u2 + patches <td>Solaris 10 Update 6</td>
<br>
See <a href="http://sunsolve.sun.com/pub-cgi/show.pl?target=patches/JavaSE" target="_blank">
SunSolve</a> for patch downloads.
</td>
<td>Sun Studio 12 Update 1 + patches</td> <td>Sun Studio 12 Update 1 + patches</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Solaris SPARCV9 (64-bit)</td> <td>Solaris SPARCV9 (64-bit)</td>
<td>Solaris 10u2 + patches <td>Solaris 10 Update 6</td>
<br>
See <a href="http://sunsolve.sun.com/pub-cgi/show.pl?target=patches/JavaSE" target="_blank">
SunSolve</a> for patch downloads.
</td>
<td>Sun Studio 12 Update 1 + patches</td> <td>Sun Studio 12 Update 1 + patches</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Solaris X86 (32-bit)</td> <td>Solaris X86 (32-bit)</td>
<td>Solaris 10u2 + patches <td>Solaris 10 Update 6</td>
<br>
See <a href="http://sunsolve.sun.com/pub-cgi/show.pl?target=patches/JavaSE" target="_blank">
SunSolve</a> for patch downloads.
</td>
<td>Sun Studio 12 Update 1 + patches</td> <td>Sun Studio 12 Update 1 + patches</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Solaris X64 (64-bit)</td> <td>Solaris X64 (64-bit)</td>
<td>Solaris 10u2 + patches <td>Solaris 10 Update 6</td>
<br>
See <a href="http://sunsolve.sun.com/pub-cgi/show.pl?target=patches/JavaSE" target="_blank">
SunSolve</a> for patch downloads.
</td>
<td>Sun Studio 12 Update 1 + patches</td> <td>Sun Studio 12 Update 1 + patches</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Windows X86 (32-bit)</td> <td>Windows X86 (32-bit)</td>
<td>Windows XP</td> <td>Windows XP</td>
<td>Microsoft Visual Studio C++ 2010 Professional Edition</td> <td>Microsoft Visual Studio C++ 2010 Professional Edition</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
<tr> <tr>
<td>Windows X64 (64-bit)</td> <td>Windows X64 (64-bit)</td>
<td>Windows Server 2003 - Enterprise x64 Edition</td> <td>Windows Server 2003 - Enterprise x64 Edition</td>
<td>Microsoft Visual Studio C++ 2010 Professional Edition</td> <td>Microsoft Visual Studio C++ 2010 Professional Edition</td>
<td>JDK 6u14 FCS </td> <td>JDK 6u18</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
@ -300,7 +288,7 @@
way to do it is to execute the following commands as user way to do it is to execute the following commands as user
<tt>root</tt>: <tt>root</tt>:
<p/> <p/>
<code>yum-builddep java-openjdk</code> <code>yum-builddep java-1.6.0-openjdk</code>
<p/> <p/>
<code>yum install gcc gcc-c++</code> <code>yum install gcc gcc-c++</code>
<p/> <p/>
@ -345,10 +333,10 @@
</blockquote> </blockquote>
</blockquote> </blockquote>
<!-- ------------------------------------------------------ --> <!-- ------------------------------------------------------ -->
<h3><a name="centos">CentOS 5.2</a></h3> <h3><a name="centos">CentOS 5.5</a></h3>
<blockquote> <blockquote>
After installing After installing
<a href="http://www.centos.org/">CentOS 5.2</a> <a href="http://www.centos.org/">CentOS 5.5</a>
you need to make sure you have you need to make sure you have
the following Development bundles installed: the following Development bundles installed:
<blockquote> <blockquote>
@ -356,7 +344,7 @@
<li>Development Libraries</li> <li>Development Libraries</li>
<li>Development Tools</li> <li>Development Tools</li>
<li>Java Development</li> <li>Java Development</li>
<li>X Software Development</li> <li>X Software Development (Including XFree86-devel)</li>
</ul> </ul>
</blockquote> </blockquote>
<p> <p>
@ -552,15 +540,105 @@
building the OpenJDK runtime libraries and misc files. building the OpenJDK runtime libraries and misc files.
The top level <tt>Makefile</tt> The top level <tt>Makefile</tt>
is used to build the entire OpenJDK. is used to build the entire OpenJDK.
<h3><a name="drops">Managing the Source Drops</a></h3>
<blockquote>
<p>
The repositories <tt>jaxp</tt> and <tt>jaxws</tt> actually
do not contain the sources for JAXP or JAX-WS.
These products have their own open source procedures at their
<a href="http://jaxp.java.net/">JAXP</a> and
<a href="http://jax-ws.java.net/">JAX-WS</a> home pages.
The OpenJDK project does need access to these sources to build
a complete JDK image because JAXP and JAX-WS are part of the JDK.
The current process for delivery of the JAXP and JAX-WS sources
involves so called "source drop bundles" downloaded from a public
website.
There are many reasons for this current mechanism, and it is
understood that this is not ideal for the open source community.
It is possible this process could change in the future.
<br>
<b>NOTE:</b> The <a href="http://download.java.net/openjdk/jdk7/">
Complete OpenJDK Source Bundles</a> <u>will</u> contain the JAXP and
JAX-WS sources.
</p>
<h4><a name="dropcreation">Creation of New Source Drop Bundles</a></h4>
<blockquote>
<ol>
<li>
The JAXP or JAX-WS team prepares a new zip bundle,
places a copy in a public download area on java.net,
sends us a link and a list of CRs (Change Request Numbers).
The older download bundles should not be deleted.
It is the responsibility of the JAXP and JAX-WS team to
place the proper GPL legal notices on the sources
and do any filtering or java re-packaging for the
OpenJDK instances of these classes.
</li>
<li>
The OpenJDK team copies this new bundle into shared
area (e.g. <tt>/java/devtools/share/jdk7-drops</tt>).
Older bundles are never deleted so we retain the history.
</li>
<li>
The OpenJDK team edits the ant property file
<tt>jaxp/jaxp.properties</tt> or
<tt>jaxws/jaxws.properties</tt> to update the
base URL, the zip bundle name, and the MD5 checksum
of the zip bundle
(on Solaris: <tt>sum -c md5 <i>bundlename</i></tt>)
</li>
<li>
OpenJDK team reviews and commits those changes with the
given CRs.
</li>
</ol>
</blockquote>
<h4><a name="dropusage">Using Source Drop Bundles</a></h4>
<blockquote>
<p>
The ant scripts that build <tt>jaxp</tt> and <tt>jaxws</tt>
will attempt to locate these zip bundles from the directory
in the environment variable
<tt><a href="#ALT_DROPS_DIR">ALT_DROPS_DIR</a></tt>.
The checksums protect from getting the wrong, corrupted, or
improperly modified sources.
Once the sources are made available, the population will not
happen again unless a <tt>make clobber</tt> is requested
or the <tt>jaxp/drop/</tt> or <tt>jaxws/drop/</tt>
directory is explicitly deleted.
<br>
<b>NOTE:</b> The default Makefile and ant script behavior
is to NOT download these bundles from the public http site.
In general, doing downloads
during the build process is not advised, it creates too much
unpredictability in the build process.
However, you can use <tt>make ALLOW_DOWNLOADS=true</tt> to
tell the ant script that the download of the zip bundle is
acceptable.
</p>
<p>
The recommended procedure for keeping a cache of these
source bundles would be to download them once, place them
in a directory outside the repositories, and then set
<tt><a href="#ALT_DROPS_DIR">ALT_DROPS_DIR</a></tt> to refer
to that directory.
These drop bundles do change occasionally, so the newer
bundles may need to be added to this area from time to time.
</p>
</blockquote>
</blockquote>
</blockquote> </blockquote>
<!-- ------------------------------------------------------ --> <!-- ------------------------------------------------------ -->
<hr> <hr>
<h2><a name="building">Build Information</a></h2> <h2><a name="building">Build Information</a></h2>
<blockquote> <blockquote>
Building the OpenJDK Building the OpenJDK
is done with a <tt><i>gmake</i></tt> is done with a <a href="#gmake">GNU <tt>make</tt></a> command line
command line and various and various
environment or make variable settings that direct the make rules environment or make variable settings that direct the makefile rules
to where various components have been installed. to where various components have been installed.
Where possible the makefiles will attempt to located the various Where possible the makefiles will attempt to located the various
components in the default locations or any component specific components in the default locations or any component specific
@ -578,7 +656,7 @@
<pre><tt> <pre><tt>
bash bash
. jdk/make/jdk_generic_profile.sh . jdk/make/jdk_generic_profile.sh
<i>gmake</i> sanity &amp;&amp; <i>gmake</i> <a href="#gmake"><tt>make</tt></a> sanity &amp;&amp; <a href="#gmake"><tt>make</tt></a>
</tt></pre> </tt></pre>
</blockquote> </blockquote>
<p> <p>
@ -599,25 +677,31 @@
A few notes about using GNU make: A few notes about using GNU make:
<ul> <ul>
<li> <li>
In general, you need GNU make version 3.81 or newer. You need GNU make version 3.81 or newer.
</li> </li>
<li> <li>
Place the location of the GNU make binary in the <tt>PATH</tt>. Place the location of the GNU make binary in the <tt>PATH</tt>.
</li> </li>
<li> <li>
<strong>Linux:</strong> <strong>Linux:</strong>
The <tt>/usr/bin/make</tt> command should work fine for you. The <tt>/usr/bin/make</tt> should be 3.81 or newer
and should work fine for you.
If this version is not 3.81 or newer,
see the <a href="#buildgmake">"Building GNU make"</a> section.
</li> </li>
<li> <li>
<strong>Solaris:</strong> <strong>Solaris:</strong>
Do NOT use <tt>/usr/bin/make</tt> on Solaris. Do NOT use <tt>/usr/bin/make</tt> on Solaris.
If your Solaris system has the software If your Solaris system has the software
from the Solaris Companion CD installed, from the Solaris Companion CD installed,
you should use <tt>gmake</tt> you should try and use <tt>gmake</tt>
which will be located in either the <tt>/opt/sfw/bin</tt> or which will be located in either the <tt>/opt/sfw/bin</tt> or
<tt>/usr/sfw/bin</tt> directory. <tt>/usr/sfw/bin</tt> directory.
In more recent versions of Solaris GNU make can be found In more recent versions of Solaris GNU make might be found
at <tt>/usr/bin/gmake</tt>. at <tt>/usr/bin/gmake</tt>.<br>
<b>NOTE:</b> It is very likely that this <tt>gmake</tt>
could be 3.80, you need 3.81, in which case,
see the <a href="#buildgmake">"Building GNU make"</a> section.
</li> </li>
<li> <li>
<strong>Windows:</strong> <strong>Windows:</strong>
@ -627,30 +711,25 @@
as a <tt>make.exe</tt> built for something like as a <tt>make.exe</tt> built for something like
<a href="http://www.mkssoftware.com/">MKS</a>). <a href="http://www.mkssoftware.com/">MKS</a>).
<br> <br>
<b>WARNING:</b> Watch out for make version 3.81, it may <b>WARNING:</b> Watch out on some make 3.81 versions, it may
not work due to a lack of support for MS-DOS drive letter paths not work due to a lack of support for MS-DOS drive letter paths
like <tt>C:/</tt> or <tt>C:\</tt>. like <tt>C:/</tt> or <tt>C:\</tt>.
Use a 3.80 version, or find a newer
version that has this problem fixed.
The older 3.80 version of make.exe can be downloaded with this
<a href="http://cygwin.paracoda.com/release/make/make-3.80-1.tar.bz2" target="_blank">
link</a>.
Use of this older 3.80 make.exe may require that you install the
libintl2.dll library or libintl2 cygwin package which is
no longer installed by default by the cygwin installer.
<br> <br>
Also see the You may be able to use the information at the
<a href="http://developer.mozilla.org/en/docs/Windows_build_prerequisites_using_cygwin#make" target="_blank"> <a href="http://developer.mozilla.org/en/docs/Windows_build_prerequisites_using_cygwin#make" target="_blank">
mozilla developer center</a> mozilla developer center</a>
on this topic. on this topic.
<br> <br>
It's hoped that when make 3.82 starts shipping in a future cygwin It's hoped that when make 3.82 starts shipping in a future cygwin
release that this MS-DOS path issue will be fixed. release that this MS-DOS path issue will be fixed.
In addition to the above 3.80 make.exe you can download <br>
this It may be possible to download the version at
<a href="http://www.cmake.org/files/cygwin/make.exe"> <a href="http://www.cmake.org/files/cygwin/make.exe">
www.cmake.org make.exe</a> which will not have a libintl2.dll www.cmake.org make.exe</a>.
dependency. <br>
It might be necessary for you to build your own GNU make 3.81,
see the <a href="#buildgmake">"Building GNU make"</a> section
in that case.
</li> </li>
</ul> </ul>
<p> <p>
@ -662,6 +741,34 @@
The latest source to GNU make is available at The latest source to GNU make is available at
<a href="http://ftp.gnu.org/pub/gnu/make/" target="_blank"> <a href="http://ftp.gnu.org/pub/gnu/make/" target="_blank">
ftp.gnu.org/pub/gnu/make/</a>. ftp.gnu.org/pub/gnu/make/</a>.
</p>
<!-- ------------------------------------------------------ -->
<h4><a name="buildgmake">Building GNU make</a></h4>
<blockquote>
First step is to get the GNU make 3.81 source from
<a href="http://ftp.gnu.org/pub/gnu/make/" target="_blank">
ftp.gnu.org/pub/gnu/make/</a>.
Building is a little different depending on the OS and unix toolset
on Windows:
<ul>
<li>
<strong>Linux:</strong>
<tt>./configure && make</tt>
</li>
<li>
<strong>Solaris:</strong>
<tt>./configure && gmake CC=gcc</tt>
</li>
<li>
<strong>Windows for CYGWIN:</strong>
<tt>./configure && make</tt>
</li>
<li>
<strong>Windows for MKS: (CYGWIN is recommended)</strong>
<tt>./configure && make -f Makefile.win32</tt>
</li>
</ul>
</blockquote>
</blockquote> </blockquote>
<!-- ------------------------------------------------------ --> <!-- ------------------------------------------------------ -->
<hr> <hr>
@ -713,7 +820,7 @@
</li> </li>
<li> <li>
Install Install
<a href="#ant">Ant</a>, <a href="#ant">Ant 1.7.1 or newer</a>,
make sure it is in your PATH. make sure it is in your PATH.
</li> </li>
</ol> </ol>
@ -776,7 +883,7 @@
</li> </li>
<li> <li>
Install Install
<a href="#ant">Ant</a>, <a href="#ant">Ant 1.7.1 or newer</a>,
make sure it is in your PATH. make sure it is in your PATH.
</li> </li>
</ol> </ol>
@ -862,7 +969,7 @@
</li> </li>
<li> <li>
Install Install
<a href="#ant">Ant</a>, <a href="#ant">Ant 1.7.1 or newer</a>,
make sure it is in your PATH and set make sure it is in your PATH and set
<tt><a href="#ANT_HOME">ANT_HOME</a></tt>. <tt><a href="#ANT_HOME">ANT_HOME</a></tt>.
</li> </li>
@ -923,14 +1030,20 @@
<blockquote> <blockquote>
All OpenJDK builds require access to least Ant 1.7.1. All OpenJDK builds require access to least Ant 1.7.1.
The Ant tool is available from the The Ant tool is available from the
<a href="http://ant.apache.org" target="_blank"> <a href="http://archive.apache.org/dist/ant/binaries/apache-ant-1.7.1-bin.zip" target="_blank">
Ant download site</a>. Ant 1.7.1 archive download site</a>.
You should always make sure <tt>ant</tt> is in your PATH, and You should always make sure <tt>ant</tt> is in your PATH, and
on Windows you may also need to set on Windows you may also need to set
<tt><a href="#ANT_HOME">ANT_HOME</a></tt> <tt><a href="#ANT_HOME">ANT_HOME</a></tt>
to point to the location of to point to the location of
the Ant installation, this is the directory pathname the Ant installation, this is the directory pathname
that contains a <tt>bin and lib</tt>. that contains a <tt>bin and lib</tt>.
<br>
<b>WARNING:</b> Ant versions used from IDE tools like NetBeans
or installed via system packages may not operate the same
as the one obtained from the Ant download bundles.
These system and IDE installers sometimes choose to change
the ant installation enough to cause differences.
</blockquote> </blockquote>
<!-- ------------------------------------------------------ --> <!-- ------------------------------------------------------ -->
<h4><a name="cacerts">Certificate Authority File (cacert)</a></h4> <h4><a name="cacerts">Certificate Authority File (cacert)</a></h4>
@ -962,7 +1075,7 @@
<blockquote> <blockquote>
<strong><a name="gcc">Linux gcc/binutils</a></strong> <strong><a name="gcc">Linux gcc/binutils</a></strong>
<blockquote> <blockquote>
The GNU gcc compiler version should be 4 or newer. The GNU gcc compiler version should be 4.3 or newer.
The compiler used should be the default compiler installed The compiler used should be the default compiler installed
in <tt>/usr/bin</tt>. in <tt>/usr/bin</tt>.
</blockquote> </blockquote>
@ -1047,21 +1160,16 @@
<strong><a name="msvc32">Windows i586: Microsoft Visual Studio 2010 Compilers</a></strong> <strong><a name="msvc32">Windows i586: Microsoft Visual Studio 2010 Compilers</a></strong>
<blockquote> <blockquote>
<p> <p>
<b>BEGIN WARNING</b>: At this time (Spring/Summer 2010) JDK 7 is starting a transition to <b>BEGIN WARNING</b>: JDK 7 has transitioned to
use the newest VS2010 Microsoft compilers. These build instructions are updated use the newest VS2010 Microsoft compilers.
to show where we are going. We have a QA process to go through before No other compilers are known to build the entire JDK,
official builds actually use VS2010. So for now, official builds are
still using VS2003. No other compilers are known to build the entire JDK,
including non-open portions. including non-open portions.
So for now you should be able to build with either VS2003 or VS2010.
We do not guarantee that VS2008 will work, although there is sufficient
makefile support to make at least basic JDK builds plausible.
Visual Studio 2010 Express compilers are now able to build all the Visual Studio 2010 Express compilers are now able to build all the
open source repositories, but this is 32 bit only. To build 64 bit open source repositories, but this is 32 bit only. To build 64 bit
Windows binaries use the the 7.1 Windows SDK.<b>END WARNING.</b> Windows binaries use the the 7.1 Windows SDK.
<b>END WARNING.</b>
<p> <p>
The 32-bit OpenJDK Windows build The 32-bit OpenJDK Windows build requires
requires
Microsoft Visual Studio C++ 2010 (VS2010) Professional Microsoft Visual Studio C++ 2010 (VS2010) Professional
Edition or Express compiler. Edition or Express compiler.
The compiler and other tools are expected to reside The compiler and other tools are expected to reside
@ -1088,11 +1196,10 @@
</blockquote> </blockquote>
<strong><a name="msvc64">Windows x64: Microsoft Visual Studio 2010 Professional Compiler</a></strong> <strong><a name="msvc64">Windows x64: Microsoft Visual Studio 2010 Professional Compiler</a></strong>
<blockquote> <blockquote>
For <b>X64</b>, builds, when using the VS2010 Professional For <b>X64</b>, the set up is much the same as 32 bit
compiler, the 64 bit build set up is much the same as 32 bit
except that you run <tt>amd64\VCVARS64.BAT</tt> except that you run <tt>amd64\VCVARS64.BAT</tt>
to set the compiler environment variables. to set the compiler environment variables.
Previously 64 bit builds had used the 64 bit compiler in Previously 64 bit builds had to use the 64 bit compiler in
an unbundled Windows SDK but this is no longer necessary if an unbundled Windows SDK but this is no longer necessary if
you have VS2010 Professional. you have VS2010 Professional.
</blockquote> </blockquote>
@ -1614,6 +1721,13 @@
and on Windows with CYGWIN and on Windows with CYGWIN
<tt>/usr/bin</tt>. <tt>/usr/bin</tt>.
</dd> </dd>
<dt><tt><a name="ALT_DROPS_DIR">ALT_DROPS_DIR</a></tt> </dt>
<dd>
The location of any source drop bundles
(see <a href="#drops">Managing the Source Drops</a>).
The default will be
<tt>$(ALT_JDK_DEVTOOLS_PATH)/share/jdk7-drops</tt>.
</dd>
<dt><a name="ALT_UNIXCCS_PATH"><tt>ALT_UNIXCCS_PATH</tt></a></dt> <dt><a name="ALT_UNIXCCS_PATH"><tt>ALT_UNIXCCS_PATH</tt></a></dt>
<dd> <dd>
<strong>Solaris only:</strong> <strong>Solaris only:</strong>
@ -1659,9 +1773,8 @@
located. located.
The default is whatever WINDOWSSDKDIR is set to The default is whatever WINDOWSSDKDIR is set to
(or WindowsSdkDir) or the path (or WindowsSdkDir) or the path
<pre> <br>
c:\Program Files\Microsoft SDKs\Windows\v6.1a <tt>c:\Program Files\Microsoft SDKs\Windows\v7.0a</tt>
</pre>
</dd> </dd>
<dt><tt><a name="ALT_DXSDK_PATH">ALT_DXSDK_PATH</a></tt> </dt> <dt><tt><a name="ALT_DXSDK_PATH">ALT_DXSDK_PATH</a></tt> </dt>
<dd> <dd>
@ -1682,6 +1795,81 @@
</blockquote> </blockquote>
<!-- ------------------------------------------------------ --> <!-- ------------------------------------------------------ -->
<hr> <hr>
<h2><a name="hints">Hints and Tips</a></h2>
<blockquote>
You don't have to use all these hints and tips, and in fact people do actually
build with systems that contradict these, but they might prove to be
helpful to some.
<ul>
<li>
If <tt>make sanity</tt> does not work, find out why, fix that
before going any further. Or at least understand what the
complaints are from it.
</li>
<li>
JDK: Keep in mind that you are building a JDK, but you need
a JDK (BOOTDIR JDK) to build this JDK.
</li>
<li>
Ant: The ant utility is a java application and besides having
ant available to you, it's important that ant finds the right
java to run with. Make sure you can type <tt>ant -version</tt>
and get clean results with no error messages.
</li>
<li>
Linux: Try and favor the system packages over building your own
or getting packages from other areas.
Most Linux builds should be possible with the system's
available packages.
</li>
<li>
Solaris: Typically you will need to get compilers on your systems
and occasionally GNU make 3.81 if a gmake binary is not available.
The gmake binary might not be 3.81, be careful.
</li>
<li>
Windows VS2010:
<ul>
<li>
Only the C++ part of VS2010 is needed.
Try to let the installation go to the default install directory.
Always reboot your system after installing VS2010.
The system environment variable VS100COMNTOOLS should be
set in your environment.
</li>
<li>
Make sure that TMP and TEMP are also set in the environment
and refer to Windows paths that exist, like <tt>C:\temp</tt>,
not <tt>/tmp</tt>, not <tt>/cygdrive/c/temp</tt>, and not <tt>C:/temp</tt>.
<tt>C:\temp</tt> is just an example, it is assumed that this area is
private to the user, so by default after installs you should
see a unique user path in these variables.
</li>
<li>
You need to use vsvars32.bat or vsvars64.bat to get the
PATH, INCLUDE, LIB, LIBPATH, and WINDOWSSDKDIR
variables set in your shell environment.
These bat files are not easy to use from a shell environment.
However, there is a script placed in the root jdk7 repository called
vsvars.sh that can help, it should only be done once in a shell
that will be doing the build, e.g.<br>
<tt>sh ./make/scripts/vsvars.sh -v10 > settings<br>
eval `cat settings`</tt><br>
Or just <tt>eval `sh ./make/scripts/vsvars.sh -v10`</tt>.
</li>
</ul>
</li>
<li>
Windows: PATH order is critical, see the
<a href="#paths">paths</a> section for more information.
</li>
<li>
Windows 64bit builds: Use ARCH_DATA_MODEL=64.
</li>
</ul>
</blockquote>
<!-- ------------------------------------------------------ -->
<hr>
<h2><a name="troubleshooting">Troubleshooting</a></h2> <h2><a name="troubleshooting">Troubleshooting</a></h2>
<blockquote> <blockquote>
A build can fail for any number of reasons. A build can fail for any number of reasons.
@ -1706,6 +1894,19 @@
Some of the more common problems with builds are briefly described Some of the more common problems with builds are briefly described
below, with suggestions for remedies. below, with suggestions for remedies.
<ul> <ul>
<li>
<b>Corrupted Bundles on Windows:</b>
<blockquote>
Some virus scanning software has been known to corrupt the
downloading of zip bundles.
It may be necessary to disable the 'on access' or 'real time'
virus scanning features to prevent this corruption.
This type of "real time" virus scanning can also slow down the
build process significantly.
Temporarily disabling the feature, or excluding the build
output directory may be necessary to get correct and faster builds.
</blockquote>
</li>
<li> <li>
<b>Slow Builds:</b> <b>Slow Builds:</b>
<blockquote> <blockquote>
@ -1801,7 +2002,11 @@
</blockquote> </blockquote>
</li> </li>
<li> <li>
<b>Windows Error Message: <tt>*** fatal error - couldn't allocate heap, ... </tt></b> <b>Windows Error Messages:</b><br>
<tt>*** fatal error - couldn't allocate heap, ... </tt><br>
<tt>rm fails with "Directory not empty"</tt><br>
<tt>unzip fails with "cannot create ... Permission denied"</tt><br>
<tt>unzip fails with "cannot create ... Error 50"</tt><br>
<blockquote> <blockquote>
The CYGWIN software can conflict with other non-CYGWIN The CYGWIN software can conflict with other non-CYGWIN
software. See the CYGWIN FAQ section on software. See the CYGWIN FAQ section on
@ -1810,12 +2015,11 @@
</blockquote> </blockquote>
</li> </li>
<li> <li>
<b>Windows Error Message: <tt>*** multiple target patterns. Stop.</tt></b> <b>Windows Error Message: <tt>spawn failed</tt></b>
<blockquote> <blockquote>
The CYGWIN make version 3.81 may not like the Windows <tt>C:/</tt> Try rebooting the system, or there could be some kind of
style paths, it may not like the ':' character in the path issue with the disk or disk partition being used.
when used in a makefile target definition. Sometimes it comes with a "Permission Denied" message.
See the <a href="#gmake"><tt><i>gmake</i></tt></a> section.
</blockquote> </blockquote>
</li> </li>
</ul> </ul>