Welcome to OpenJDK 8 Updates!

OpenJDK 8 updates are a separate project of OpenJDK. Andrew Haley serves as the Project Lead. The list of Reviewers, Committers, and Authors can be found in the jdk8u entry of the OpenJDK Census.

Maintainers

General Information

As a preamble, the project lead has established general guidelines for working on jdk8u.

OpenJDK 8 updates will be delivered on the same established quarterly cycle used by Oracle i.e. "the Tuesday closest to the 17th day of January, April, July and October."

Development takes place in the jdk8u-dev Mercurial repository and should be the primary place for OpenJDK committers to submit their work.

Code from the development repository is regularly tagged and promoted to the master jdk8u repository, which is used to stabilize and deliver the quarterly releases. Distributors should use this as their primary source for creating OpenJDK builds.

For further process details, you may want to continue reading here.

Contributing

New fixes should first be submitted to the development repository for the current version of OpenJDK, jdk/jdk, first. The vast majority of changes submitted to the OpenJDK 8 project will be backports from later OpenJDK versions. The version of OpenJDK closest to 8u should be used to minimise the differences between the two JDKs e.g. if 11u is still maintained and has the patch, it should be backported from that repository, rather than jdk/jdk. Occasional exceptions are made when an issue only applies to 8. In particular, the build system can be quite different from that in later versions, especially as regards HotSpot.

Everybody is encouraged to submit fixes for OpenJDK 8 updates by dropping a mail to the jdk8u-dev mailing list. Established community members will help new developers without commit access in getting their patch reviewed. Should you not be willing or not be able to drive a fix into OpenJDK 8 updates, you can still suggest changes. But by only doing that, you are at the grace of the community to pick up your suggestion.

The suggested process is as follows:

  1.  Check the bug database for which JDK versions already have the patch applied.
  2. Take a copy of the patch from the repository of the JDK version closest to 8u to minimise changes.
  3. If the patch was developed after the switch to a single repository (during the OpenJDK 10 lifecycle), shuffle the paths using <source jdk>/bin/unshuffle_patch.sh -to9 <original.patch> <9.patch> to get a version that works with the forest of repositories. In some cases, this may mean multiple patches for different repositories.
  4. If the patch was developed after the switch to the modular system (during the OpenJDK 9 lifecycle) and is not a HotSpot fix, shuffle the paths using <jdk9>/common/bin/unshuffle_patch.sh <repo> <9.patch> <8.patch>
  5. Try to apply the patch by using hg import <patch>. If it applies, go to #7. Otherwise, #6.
  6. Fix the patch so it applies. This may require identifying other patches which need to backported first, in which case you start this process again with that fix.
  7. Build the resulting JDK, altering if necessary. Again, this may end up needing dependent backports.
  8. You now should have a working patch. If no changes were necessary other than path shuffling, proceed to step #11. Otherwise, step #9.
  9. Use the webrev tool to create a webrev. Post a mail to jdk8u-dev@openjdk.java.net  with the subject "RFR: <bug ID> <bug description>", asking for a review.Explain the motivation and what technical changes were necessary to make the patch work with 8u. Include a link to the bug and to your webrev uploaded on cr.openjdk.java.net. If you can't upload to cr.openjdk.java.net, ask someone with OpenJDK authorship status or above to do it on your behalf.
  10. Wait for a successful review from an OpenJDK 8u reviewer.
  11. Go to the bug in JIRA and add the label 'jdk8u-fix-request'. Write a comment preceded with "Fix Request [8u]". Explain the motivation for the fix, and either explain that it applies cleanly to 8u with patch shuffling, or link to the successful review thread on the mailing list.  If you don't have bug database access, someone will need to do this on your behalf.
  12. Wait for an 8u maintainer to add jdk8u-fix-yes to the bug.
  13. The change can now be committed & pushed to the appropriate jdk8u-dev repository. If you don't have committer or above status, someone will need to to do so on your behalf. Patches that apply cleanly or only need a few minor changes which don't alter the code (e.g. copyright header fixes, same changes in a different context) should use the original author & reviewers for the commit. If the fix was reviewed, those reviewers should be appended to the end of the list. If substantial code changes were needed to create the 8u fix, authorship should go to the backporter and reviewers should  only list those who reviewed the altered patch.
  14. Pat yourself on the back, having successfully got a patch into OpenJDK 8u.

Fix Approvals

In general, we follow the common rules for the jdk-updates project.

If the backport does not apply to the 8u tree via the automated shuffling described above, it should first be submitted for review.

Push approval for a fix is then requested by setting the jdk8u-fix-request label on the original JBS bug.  The maintainer will either approve this by setting jdk8u-fix-yes or reject it by setting jdk8u-fix-no. Outstanding approvals can be monitored here. If, and only if, the fix is approved, it may be pushed to the appropriate jdk8u-dev repositories. Approved fixes show up in this JBS filter (login required).

During the later stages of a release cycle, the release enters rampdown. The master jdk8u repositories contain the latest version of that release, while the jdk8u-dev repositories are used to start work on the next release. If a change needs to be pushed to a release in rampdown, push approval can still be requested using the jdk8u-critical-request label. As the name of this tag suggests, this process is intended for fixes such as major regressions that must make the release. More minor bugs and new features should go in the next release being developed in jdk8u-dev. The maintainers may approve with jdk8u-critical-yes, defer to jdk8u-dev or reject altogether. Outstanding approvals for critical fixes can be monitored here. If, and only if, the fix gets approved with jdk8u-critical-yes, it may be pushed to the jdk8u repository. Approved critical fixes show up in this JBS filter (login required).

At the end of the month prior to the release month, the jdk8u repository is declared frozen, so embargoed security fixes can be added in private during the final few weeks. On release day, the final version will be pushed to the jdk8u repository and source bundles made available.

Repository Status

jdk8u-dev:  Open for development of 8u262. Pushes after jdk8u-fix-yes approval. Check here for clearance.

jdk8u: Open for weekly maintainer build promotions of 8u262.

Timelines

OpenJDK 8u252

  • Thursday, December 17th 2019: jdk8u-dev forest open (tag: jdk8u252-b00)
  • Wednesday, January 22nd 2020: First build promotion jdk8u-dev→jdk8u (tag: jdk8u252-b01)
  • Wednesday, January 29th 2020: Second build promotion jdk8u-dev→jdk8u (tag: jdk8u252-b02)
  • Wednesday, February 12th 2020: Third build promotion jdk8u-dev→ jdk8u (tag: jdk8u252-b03)
  • Wednesday, February 19th 2020: Fourth build promotion jdk8u-dev→ jdk8u (tag: jdk8u252-b04)
  • Wednesday, February 26th 2020: Fifth build promotion jdk8u-dev→ jdk8u (tag: jdk8u252-b05) & start of Rampdown phase
  • Wednesday, March 11th 2020: First jdk8u build promotion (tag: jdk8u252-b06)
  • Wednesday, March 18th 2020: Second jdk8u build promotion (tag: jdk8u252-b07)
  • Wednesday, March 25th 2020:: Final jdk8u build promotion & tag before code freeze (tag: jdk8u252-b08)
  • Tuesday, April 14th 2020: GA; OpenJDK 8u252 released (tag: jdk8u252-ga, likely to be jdk8u252-b09)

OpenJDK 8u262

  • Tuesday, March 3rd 2020: jdk8u-dev forest open (tag: jdk8u262-b00)
  • Wednesday, April 22nd 2020: First build promotion jdk8u-dev→jdk8u (tag: jdk8u262-b01)
  • Wednesday, April 29th 2020: Second build promotion jdk8u-dev→jdk8u (tag: jdk8u262-b02)
  • Wednesday, May 6th 2020: Third build promotion jdk8u-dev→ jdk8u (tag: jdk8u262-b03)
  • Wednesday, May 13th 2020: Fourth build promotion jdk8u-dev→ jdk8u (tag: jdk8u262-b04)
  • Wednesday, May 20th 2020: Fifth build promotion jdk8u-dev→ jdk8u (tag: jdk8u262-b04)
  • Wednesday, May 27th 2020: Sixth build promotion jdk8u-dev→ jdk8u (tag: jdk8u262-b05) & start of Rampdown phase
  • Wednesday, June 3rd 2020: First jdk8u build promotion (tag: jdk8u262-b06)
  • Wednesday, June 10th 2020: Second jdk8u build promotion (tag: jdk8u262-b07)
  • Wednesday, June 17th 2020: Third jdk8u build promotion (tag: jdk8u262-b08)
  • Wednesday, June 24th 2020:: Final jdk8u build promotion & tag before code freeze (tag: jdk8u262-b10)
  • Tuesday, July 14th 2020: GA; OpenJDK 8u262 released (tag: jdk8u262-ga, likely to be jdk8u262-b11)

Older releases can be found in the archive.

Releases

Latest GA release: 8u252

Latest Generally Available (GA) binary releases of the OpenJDK jdk8u project are available at: https://adoptopenjdk.net/upstream.html?variant=openjdk8&ga=ga

Latest Early Access (EA) binary releases of the OpenJDK jdk8u project are available at: https://adoptopenjdk.net/upstream.html?variant=openjdk8&ga=ea

Most recent and past release details:

JBS Filters

Some filters will only work for users that are logged into JBS.

Standard Fix Requests

[All Requests] [Approved requests] [Approved requests without push] [Unapproved requests]

Critical Fix Requests

[Critical requests] [Approved critical requests] [Approved critical requests without push] [Unapproved critical requests]


Filters for Release 8u252

[Open Downports Oracle -> OpenJDK] [Additional commits in OpenJDK vs Oracle]

Source code

The jdk8u-dev forest for ongoing development can be cloned using this command:  hg clone http://hg.openjdk.java.net/jdk8u/jdk8u-dev;cd jdk8u-dev;sh get_source.sh 

The corresponding master forest jdk8u can be cloned using this command: hg clone http://hg.openjdk.java.net/jdk8u/jdk8u;cd jdk8u;sh get_source.sh

Recent space activity

Space contributors