IcedTea Bootstrap Process

Michael Franz mvfranz at gmail.com
Fri Jan 16 19:16:15 PST 2009


Andrew,

Thanks for this detail.  It does help.  I have another question, how can I
tell what build I am in?  I run the build and it takes a while.  At some
point JAVA_CMD becomes unset and I end up with:
# Running javac:
-sourcepath
/Users/mfranz/developer/icedtea/apple5/generated:../../../src/solaris/classes:../../../src/share/classes
-bootclasspath
/Users/mfranz/developer/icedtea/apple5/bootstrap/jdk1.7.0/jre/lib/rt-closed.jar::/Users/mfranz/developer/icedtea/apple5/openjdk-ecj/build/bsd-i586/classes
-d /Users/mfranz/developer/icedtea/apple5/openjdk-ecj/build/bsd-i586/classes
@/Users/mfranz/developer/icedtea/apple5/openjdk-ecj/build/bsd-i586/tmp/java/java.lang/java/.classes.list
/bin/sh: -sourcepath: command not found

I am thinking this is the second build, but I could be wrong.  If I define
JAVA_CMD, JAVAH_CMD it gets farther, but I am probably not defining them
correctly, as the build fails.

In this case I am using a remapped Apple JDK 5 with the classpath rt.jar.

Michael

On Tue, Jan 13, 2009 at 11:35 PM, Andrew John Hughes <
gnu_andrew at member.fsf.org> wrote:

> 2009/1/14 Michael Franz <mvfranz at gmail.com>:
> > Hi,
> >
> > I have been trying to find documentation on how the bootstrap build works
> on
> > IcedTea, but have not found it.  I have tried to read the Makefile, but I
> > must admit I am not that proficient with makefiles.
> >
>
> That would be a little difficult, given most of the makefiles are part
> of the OpenJDK build which is downloaded by IcedTea i.e. if you're
> looking at just what comes from a Mercurial checkout or a tarball,
> it'll not make a lot of sense...
>
> > If there is no documentation, perhaps answers to these question will help
> > me.
>
> If you couldn't find any, what there is is too well hidden...
>
> >
> > 1. How many passes (full compilations) are there done on the source
> before
> > the final jdk is complete?
>
> By default, 2.  OpenJDK is built once with the system JDK.  This is
> assumed to be gcj/ecj or some other GNU Classpath variant as these are
> the only Free options other than IcedTea/OpenJDK itself (saying that,
> I suppose there is Harmony but I don't know of anyone trying to build
> with that and whether that also needs a JDK to build too).  This
> applies some additional patches (located in patches/ecj) which disable
> a few things, remove some Sun-specific assumptions, etc.  Sorry to be
> a bit vague, but we probably do need to go through the patch to see
> what's in there and what's still needed.
>
> The built JDK is then tested by being used to build OpenJDK.  If you
> already have IcedTea (say from your distro), you can skip straight to
> this stage using --with-icedtea and --with-icedtea-home to specify a
> path to your existing IcedTea installation if the default is no good
> (these two options should be combined IMO).  The system IcedTea needs
> to be fairly new as some IcedTea plugin stuff is assumed to be
> presented AFAIR.
>
> The alternate builds (zero assembler, shark, cacao) follow the same
> process; their alterations primarily affect HotSpot.
>
> > 2. How much (if any) of the source that is being built is compiled and
> put
> > into the rt-closed.jar?
>
> An ecj step before the OpenJDK build compiles enough of the OpenJDK
> sources separately to satisfy the OpenJDK build.  The OpenJDK build is
> designed only for Sun JDKs it seems, and so relies on a lot of
> Sun-specific classes being present in the build JDK (far over and
> above what's in the spec.).  These are added to rt-closed.jar (the
> naming is from the OpenJDK build assuming this is an existing
> proprietary JDK IIRC).  What is included has been found by trial and
> error.  For instance, javax/script was recently added to the list as
> it's needed by newer versions of HotSpot.  The list can be found as
> ICEDTEA_COPY_DIRS in Makefile.am:
>
> # Sources copied from OpenJDK.
> ICEDTEA_COPY_DIRS = \
>        com/sun/jdi \
>        com/sun/jdi/connect \
>        com/sun/jdi/connect/spi \
>        com/sun/jdi/event \
>        com/sun/jdi/request \
>        com/sun/jmx/snmp/agent \
>        com/sun/tools/jdi \
>        java/io \
>        java/util \
>        java/rmi \
>        sun/awt/ \
>        javax/net/ssl
>
> if WITH_ALT_HSBUILD
> ICEDTEA_COPY_DIRS += \
>        javax/script
> endif
>
> This is from IcedTea6.  Note that the SNMP stuff is stubbed, and
> should probably just be removed and IMPORT_BINARY_PLUGS=false set on
> the OpenJDK build.
>
> > 3. Is rt-closed.jar all that should be needed to compile the JDK the
> first
> > time?
>
> Yes, as explained above.
>
> > 4. What is the expected results of a successful bootstrap?
>
> A fully-compliant 1.6 JDK? :)
> You should get:
>
> IcedTea is served.
>
> when you reach the end.  The results are in
> openjdk/control/build/${OS}-${ARCH}/j2sdk-image (omit the 'control'
> segment on IcedTea7).
>
> The easiest way to try a pain-free build is to try it on Fedora where
> it should just ./configure and make.
>
> >
> > Thanks
> >
> > Michael
> >
> >
>
> Thanks,
> --
> Andrew :-)
>
> Support Free Java!
> Contribute to GNU Classpath and the OpenJDK
> http://www.gnu.org/software/classpath
> http://openjdk.java.net
>
> PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
> Fingerprint: F8EF F1EA 401E 2E60 15FA  7927 142C 2591 94EF D9D8
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20090116/464ea5f9/attachment.html 


More information about the distro-pkg-dev mailing list