IcedTea

From Wikipedia, the free encyclopedia
Jump to: navigation, search
Not to be confused with Iced tea.
IcedTea for OpenJDK 7
Developer(s) Red Hat & GNU Classpath
Stable release 2.5.3 / October 14, 2014 (2014-10-14)
Written in C, C++ and Java
Operating system GNU/Linux, *BSD, Mac OS X, Windows[1], Solaris
Platform IA-32, x86-64, ARM, AArch64, sparc, sparc64, ppc, ppc64, ppc64le, s390, s390x
Type Java Virtual Machine and Java Library
License GNU GPL+linking exception
Website http://icedtea.classpath.org
IcedTea for OpenJDK 6
Developer(s) Red Hat & GNU Classpath
Stable release 1.13.5 / October 14, 2014 (2014-10-14)
Written in C, C++ and Java
Operating system GNU/Linux, *BSD, Mac OS X, Windows[2], Solaris
Platform IA-32, x86-64, ARM, sparc, sparc64, ppc, ppc64, s390, s390x
Type Java Virtual Machine and Java Library
License GPL+linking exception
Website http://icedtea.classpath.org
IcedTea-Web
Developer(s) Red Hat & GNU Classpath
Stable release 1.5.0 / April 7, 2014 (2014-04-07)
Written in C++ and Java
Operating system GNU/Linux, *BSD, Mac OS X, Windows, Solaris
Type Java Web Start support and Java web plugin for applets
License GPL+linking exception
Website http://icedtea.classpath.org/wiki/IcedTea-Web
IcedTea-Sound
Developer(s) Red Hat & GNU Classpath
Stable release 1.0.1 / July 18, 2014 (2014-07-18)
Written in C and Java
Operating system GNU/Linux, *BSD, Mac OS X, Windows, Solaris
Type Sound support
License GPL+linking exception
Website http://icedtea.classpath.org/wiki/IcedTea-Sound

IcedTea is a build and integration project for OpenJDK launched by Red Hat in June 2007.[1] IcedTea-Web is a free software implementation of Java Web Start and the Java web browser plugin. IcedTea-Sound is a collection of plugins for the Java sound subsystem, including the PulseAudio provider which used to be included with IcedTea. The FSF recommends all Java programmers use IcedTea as their development environment.[2]

Historically, the initial goal of the IcedTea project was to make the OpenJDK software, which Sun Microsystems released as Free software in 2007, usable without requiring any proprietary software and hence make it possible to add OpenJDK to Fedora and other Linux distributions that insist on Free software. This was met, and a version of IcedTea based on OpenJDK was packaged with Fedora 8 in November 2007. April 2008 saw the first release[3] of a new variant, IcedTea6 which is based on Sun's build drops of OpenJDK6, a fork of the OpenJDK with the goal of being compatible with the existing JDK6. This was released in Ubuntu and Fedora in May 2008. The IcedTea package in these distributions has been renamed to OpenJDK using the OpenJDK trademark notice. In June 2008, the Fedora build passed Sun's rigorous TCK testing[4] on x86 and x86-64. IcedTea 2, the first version based on OpenJDK 7, was released in October 2011.[5]

History[edit]

This project was created following Sun’s release under open source licenses of its HotSpot Virtual Machine and Java compiler in November 2006, and most of the source code of the class library in May 2007. However, parts of the class library, such as font rendering, colour management and sound support, were only provided as proprietary binary plugins. This was because the source code for these plugins was copyrighted to third parties, rather than Sun Microsystems.[6][7] The released parts were published under the terms of the GNU General Public License, a free software license.

Due to these missing components, it was not possible to build OpenJDK only with free software components. Sun aimed to negotiate with the license holders to allow this code to be released under a free software license, or failing that, to replace these proprietary elements with alternative implementations. With the plugins replaced, the class library would then be completely free. Sun has continued to use the proprietary code in their certified binary releases.[8]

Following the announcement, the IcedTea project was started and was formally announced on June 7, 2007,[9] with a build repository provided by the GNU Classpath team. The team could not call their software product "OpenJDK" because this is a trademark which was owned by Sun Microsystems. They instead decided to use the temporary name "IcedTea".[10]

On November 5, 2007, Red Hat signed both the Sun Contributor Agreement and the OpenJDK Community TCK License. The press release suggested that this would benefit the IcedTea project.[11] Simon Phipps suggested the possibility of IcedTea being hosted on openjdk.java.net,[12] and Mark Reinhold noted that signing the copyright assignment could allow Red Hat to contribute parts of IcedTea to Sun for inclusion in the mainstream JDK.[13][14]

Since then, a number of patches from IcedTea have made their way into OpenJDK.[15][16]

On June 2008, it was announced that IcedTea6 (as the packaged version of OpenJDK on Fedora 9) has passed the Technology Compatibility Kit tests and can claim to be a fully compatible Java 6 implementation.[17] The project continues to track both OpenJDK 6 and OpenJDK 7 development in separate repositories, and contribute patches back upstream[18] where possible; the current state of each IcedTea patch is maintained on the IcedTea wiki.

Aims[edit]

The IcedTea project started with two aims:

  1. to make it possible for the GNU Compiler for Java to compile the OpenJDK code. Originally only the existing proprietary Sun JDK could compile the OpenJDK software. Free distributions like Fedora can't depend on proprietary tools in order to build packages, so the IcedTea project had to make it possible to compile the code using free software. When this was done, the resulting IcedTea version of OpenJDK could be used to compile itself, thus escaping the need to use non-Free software for future compiling.[9][19]
  2. to provide free equivalents of the binary plugins that existed in OpenJDK because Sun was unable to release all the source code. As of March 2008, this is no longer necessary for IcedTea6, as the OpenJDK 6 build drops can be built with no binary plugins. With the release of b10,[20] which replaces the proprietary sound support with that from the Gervill project, a full implementation of Java 1.6 can be built without binary plugins. The only remaining binary plug is for SNMP support, which is an optional provider for the JMX architecture and not part of the specification. As of b53 in April 2009,[21] the same is true for OpenJDK 7. Outside the core of OpenJDK, binary plugins are still required for utilizing Java Web Start applets that run using the browser plugin (distinct from the core plugins discussed earlier); as of 2013, the only [3] source code available that accomplishes this goal is the IcedTea-Web project.

Other benefits[edit]

IcedTea also provides a more familiar build system by providing a wrapper around the OpenJDK makefiles using the GNU autotools. This removes the need to remember a large number of environment variables for configuring the build. (The current IcedTea builds set roughly forty such variables for the underlying OpenJDK build.) It has also provided a place for early work on features which will eventually appear in the main OpenJDK builds such as Gervill[22] and for work on ports to other platforms.

IcedTea-Web[edit]

IcedTea NPR plugin (based on IcedTea6) listed in Debian Iceweasel 6.0.2 (Knoppix 6.7.1)

IcedTea provides a free-software Java Web browser plugin. It was the first to work in 64-bit browsers under 64-bit Linux, a feature Sun's proprietary JRE later addressed.[23] This makes it suitable to enable support for Java applets in 64-bit Mozilla Firefox, among others. IcedTea also provides a free Java Network Launching Protocol implementation. Sun has promised to release their plugin and Web Start implementation as part of OpenJDK, but so far have not done so,[24] despite pressure from the community.[25] Development on the IcedTea plugin continues, with the latest version of the next-generation plugin supporting Google's Chromium[26] in addition to Firefox. Since 2011, development takes place in the separate IcedTea-Web project.[27] As of April 2013, Oracle has kept the codebase of the Java plugin fully proprietary [4], in contrast to the remainder of OpenJDK.

Progress and availability[edit]

From June 2007, IcedTea was able to build itself and pass a significant portion of Mauve, the GNU Classpath test suite.[28] In May 2008, support was added to IcedTea for running the Sun jtreg regression tests.[29] Availability on several Windows editions still remains unstable and unofficial.

IcedTea has become popular among package maintainers for the following Linux distributions. Currently (as of April 2012):

  • IcedTea is the default JVM in Ark Linux[30] and Arch Linux.[31]
  • It can be built and run under Debian.[32] Packages entered unstable on 12 July 2008.
  • IcedTea[7] was available in Fedora 8 and IcedTea6 appeared in Fedora 9 through to 17 as java-1.6.0-openjdk.[33] A java-1.7.0-openjdk package using the IcedTea 2.x OpenJDK forest, but not its build system, first appeared in Fedora 16.[34]
  • Binary and source packages for IcedTea6 and IcedTea 2.x are available in Gentoo's official repository. Installing a Java application by default pulls in IcedTea6 instead of sun-jdk because it can be installed without extra work from the user, as users have to manually agree to Oracle's EULA to download the sun-jdk.
  • IcedTea is available in Ubuntu 7.10 (Gutsy Gibbon), from the "universe" repository,[35] and IcedTea6 in 8.04 (Hardy Heron).[36] Starting with Ubuntu 11.04 only IcedTea is available.

Architecture[edit]

OpenJDK contained approximately (on release in May 2007) 4% encumbered code,[10] which was only packaged as binary plugins. These were required to build and use the JDK. OpenJDK 6 was released with only 1% encumbered code, and the encumbered sound support has also since been replaced. IcedTea6 is based on this release. IcedTea still provides its own web browser plugin and Web Start support, as Sun's implementation remains proprietary.

IcedTea can compile OpenJDK using GNU Classpath-based solutions such as GCJ and optionally bootstraps itself using the HotSpot Java Virtual Machine and the javac Java compiler it just built.[37]

Platform support[edit]

Ports of HotSpot (OpenJDK's Virtual Machine) are difficult, because the code contains much assembly language, in addition to the C++ core.[38] The IcedTea project has developed a generic port of the HotSpot interpreter called zero-assembler Hotspot (or zero),[39] with almost no assembly code.[40][41] This port is intended to allow the interpreter part of HotSpot to be very easily adapted to any Linux processor architecture.[42] The code of zero-assembler Hotspot was used for all the non-x86 ports of HotSpot (PPC, IA-64, S390 and ARM) from version 1.6 of IcedTea7.[43][44][45]

The IcedTea project has also developed a platform-independent just-in-time compiler called Shark for HotSpot, using LLVM, to complement Zero.[41][46] This was included in upstream OpenJDK in August 2010.[47] A JIT for ARM32 was first included in 1.6.0[48] and 2.1.1.[49] A native port to AArch64 from Red Hat[50] appeared in 2.4.6[51] and a native PPC64 port from SAP/IBM[52] will be included in 2.5.0.[53]

See also[edit]

References[edit]

  1. ^ Fitzsimmons, Thomas (2007-06-08). "Credits". Retrieved 2007-06-08. 
  2. ^ http://www.gnu.org/philosophy/java-trap.html
  3. ^ Angel, Lillian (2008-04-04). "IcedTea6 1.1 Released". Retrieved 2008-07-12. 
  4. ^ Sharples, Rich (2008-06-19). "Java is finally Free and Open". Retrieved 2008-06-19. 
  5. ^ Hughes, Andrew John (2011-10-19). "IcedTea 2.0 Released!". Retrieved 2012-01-31. 
  6. ^ "Open JDK is here!". Sun Microsystems. 2007-05-08. Retrieved 2007-05-09. 
  7. ^ See also Java Class Library Licensing
  8. ^ "Sun's OpenJDK FAQ". Now Sun is open sourcing most of the remaining components of the JDK, with the exception of a few encumbered components that we hope, with the community's help, can be re-implemented so that 100 % of the OpenJDK code commons is available as free software... Sun will continue to use that code in commercial releases until it's replaced by fully-functional open-source alternatives 
  9. ^ a b Haley, Andrew (2007-06-07). "Experimental Build Repository at icedtea.classpath.org". Retrieved 2007-06-09. 
  10. ^ a b Fitzsimmons, Thomas (2007-05-18). "Plans for OpenJDK". Retrieved 2007-05-22. 
  11. ^ "Red Hat and Sun Collaborate to Advance Open Source Java Technology". Red Hat. 2007-11-05. Retrieved 2007-11-06. 
  12. ^ Phipps, Simon (November 5, 2007). "Red Hat Joins OpenJDK". Retrieved 2007-11-14. 
  13. ^ Reinhold, Mark (2007-11-05). "Welcome, Red Hat!". Retrieved 2007-11-14. 
  14. ^ Haley, Andrew (May 16, 2008). "Open source project: OpenJDK". 
  15. ^ "Bug ID 6523403: OSS CMM: Need to provide lcms library with PYCC and LINEAR_RGB OS ICC profiles". Retrieved 2008-07-12. 
  16. ^ "Bug ID 6604044 java crashes talking to second X screen". Retrieved 2008-07-12. 
  17. ^ Sharples, Rich (2008-06-19). "Java is finally Free and Open". 
  18. ^ Haley, Andrew (2009-04-01). "New project: getting rid of IcedTea local patches". Retrieved 2009-09-05. 
  19. ^ Wielaard, Mark (2007-06-07). "Experimental Build Repository at icedtea.classpath.org". Retrieved 2007-06-09. 
  20. ^ Wielaard, Mark (2007-05-30). "OpenJDK6 b10 source posted". Retrieved 2008-07-12. 
  21. ^ "Changes in OpenJDK7 b53". 2009-04-02. Retrieved 2009-09-05. 
  22. ^ Gervill, a generic synthesizer for Java
  23. ^ Java SE 6 Update 12 Release Notes. Java.sun.com. Retrieved on 2013-07-18.
  24. ^ Darcy, Joe (2009-06-08). "OpenJDK and the new plugin". Retrieved 2009-09-05. 
  25. ^ Hughes, Andrew John (2009-08-21). "Opensource plugin&webstart - when?". Retrieved 2009-09-05. 
  26. ^ Bhole, Deepak (2009-08-26). "IcedTea Java plugin with Chromium and Firefox 3.6A1". Retrieved 2009-09-05. 
  27. ^ Bhole, Deepak (2011-02-02). "First release of IcedTea-Web!". Retrieved 2011-04-04. 
  28. ^ Kung, Francis (2007-06-12). "Mauve test run results". Retrieved 2007-06-12. 
  29. ^ Wielaard, Mark. "jtreg testing integrated". Retrieved 2008-07-12. 
  30. ^ "Ark Linux packages". Ark Linux. Retrieved 2008-02-23. 
  31. ^ "JRE and JDK Moved to Community". Arch Linux. Retrieved 2009-07-30. 
  32. ^ "Debian Building Instructions". IcedTea Wiki. Retrieved 2008-05-21. 
  33. ^ "java-1.6.0-openjdk.git". Retrieved 2014-03-28. 
  34. ^ "java-1.7.0-openjdk.git". Retrieved 2014-03-28. 
  35. ^ "Ubuntu -- Details of icedtea-java7-jre in gutsy". Ubuntu Packages. Retrieved 2007-10-26. 
  36. ^ "Ubuntu -- Details of package openjdk-6-jre in hardy". Ubuntu Packages. Retrieved 2008-07-12. 
  37. ^ Wielaard, Mark (2007-06-07). "IcedTea". Retrieved 2007-06-09. 
  38. ^ Benson, Gary (2007-11-06). "Gary's guide to porting IcedTea". Retrieved 2008-01-26. 
  39. ^ "Zero-Assembler Project". Retrieved 2008-08-22. 
  40. ^ "ZeroSharkFaq". icedtea.classpath.org. Retrieved 2009-05-30. 
  41. ^ a b Benson, Gary (2008-05-28). "28 May 2008". Red Hat. Retrieved 2008-05-30. Shark is a platform-independent JIT for HotSpot, to complement the zero-assembler interpreter we’ve been using 
  42. ^ Benson, Gary (2009-05-21). "Zero and Shark: a Zero-Assembly Port of OpenJDK". java.net. Retrieved 2009-05-30. We started an experimental port of OpenJDK without assembly language, using free software libraries to bridge the gaps. This experiment evolved to become the zero-assembly port of OpenJDK — Zero — and its just-in-time compiler Shark. 
  43. ^ Benson, Gary (2008-02-01). "1st February 2008". Retrieved 2008-02-03. 
  44. ^ Haley, Andrew (2008-01-31). "Making zero-assembler the default on ppc". Retrieved 2008-02-03. 
  45. ^ Angel, Lillian (2008-02-13). "IcedTea 1.6 Released with Zero-assembler and JNLP support!". Red Hat. Retrieved 2008-02-13. 
  46. ^ Benson, Gary (2008-03-31). "31 March 2008". Red Hat. Retrieved 2008-05-30. 
  47. ^ "6976186: integrate Shark HotSpot changes". hg.openjdk.java.net. Retrieved 2014-03-28. 
  48. ^ Haley, Andrew (2009-09-09). "IcedTea6 1.6 Released!". Retrieved 2014-03-28. 
  49. ^ Hughes, Andrew (2012-06-13). "[SECURITY] IcedTea 2.1.1 & 2.2.1 Released!". Retrieved 2014-03-28. 
  50. ^ "AArch64 Port Project". Retrieved 2014-03-28. 
  51. ^ Hughes, Andrew (2014-03-28). "IcedTea 2.3.14 & 2.4.6: Considered ARMful Released!". Retrieved 2014-03-28. 
  52. ^ "OpenJDK PowerPC/AIX Port". Retrieved 2014-03-28. 
  53. ^ Hughes, Andrew (2014-01-23). "PPC Port Available in IcedTea 2.x HEAD". Retrieved 2014-03-28. 

External links[edit]