|  | ================================= | 
|  | How To Release LLVM To The Public | 
|  | ================================= | 
|  |  | 
|  | Introduction | 
|  | ============ | 
|  |  | 
|  | This document contains information about successfully releasing LLVM --- | 
|  | including sub-projects: e.g., ``clang`` and ``compiler-rt`` --- to the public. | 
|  | It is the Release Manager's responsibility to ensure that a high quality build | 
|  | of LLVM is released. | 
|  |  | 
|  | If you're looking for the document on how to test the release candidates and | 
|  | create the binary packages, please refer to the :doc:`ReleaseProcess` instead. | 
|  |  | 
|  | .. _timeline: | 
|  |  | 
|  | Release Timeline | 
|  | ================ | 
|  |  | 
|  | LLVM is released on a time based schedule --- with major releases roughly | 
|  | every 6 months.  In between major releases there may be dot releases. | 
|  | The release manager will determine if and when to make a dot release based | 
|  | on feedback from the community.  Typically, dot releases should be made if | 
|  | there are large number of bug-fixes in the stable branch or a critical bug | 
|  | has been discovered that affects a large number of users. | 
|  |  | 
|  | Unless otherwise stated, dot releases will follow the same procedure as | 
|  | major releases. | 
|  |  | 
|  | The release process is roughly as follows: | 
|  |  | 
|  | * Set code freeze and branch creation date for 6 months after last code freeze | 
|  | date.  Announce release schedule to the LLVM community and update the website. | 
|  |  | 
|  | * Create release branch and begin release process. | 
|  |  | 
|  | * Send out release candidate sources for first round of testing.  Testing lasts | 
|  | 7-10 days.  During the first round of testing, any regressions found should be | 
|  | fixed.  Patches are merged from mainline into the release branch.  Also, all | 
|  | features need to be completed during this time.  Any features not completed at | 
|  | the end of the first round of testing will be removed or disabled for the | 
|  | release. | 
|  |  | 
|  | * Generate and send out the second release candidate sources.  Only *critical* | 
|  | bugs found during this testing phase will be fixed.  Any bugs introduced by | 
|  | merged patches will be fixed.  If so a third round of testing is needed. | 
|  |  | 
|  | * The release notes are updated. | 
|  |  | 
|  | * Finally, release! | 
|  |  | 
|  | The release process will be accelerated for dot releases.  If the first round | 
|  | of testing finds no critical bugs and no regressions since the last major release, | 
|  | then additional rounds of testing will not be required. | 
|  |  | 
|  | Release Process | 
|  | =============== | 
|  |  | 
|  | .. contents:: | 
|  | :local: | 
|  |  | 
|  | Release Administrative Tasks | 
|  | ---------------------------- | 
|  |  | 
|  | This section describes a few administrative tasks that need to be done for the | 
|  | release process to begin.  Specifically, it involves: | 
|  |  | 
|  | * Creating the release branch, | 
|  |  | 
|  | * Setting version numbers, and | 
|  |  | 
|  | * Tagging release candidates for the release team to begin testing. | 
|  |  | 
|  | Create Release Branch | 
|  | ^^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Branch the Subversion trunk using the following procedure: | 
|  |  | 
|  | #. Remind developers that the release branching is imminent and to refrain from | 
|  | committing patches that might break the build.  E.g., new features, large | 
|  | patches for works in progress, an overhaul of the type system, an exciting | 
|  | new TableGen feature, etc. | 
|  |  | 
|  | #. Verify that the current Subversion trunk is in decent shape by | 
|  | examining nightly tester and buildbot results. | 
|  |  | 
|  | #. Create the release branch for ``llvm``, ``clang``, and other sub-projects, | 
|  | from the last known good revision.  The branch's name is | 
|  | ``release_XY``, where ``X`` is the major and ``Y`` the minor release | 
|  | numbers.  Use ``utils/release/tag.sh`` to tag the release. | 
|  |  | 
|  | #. Advise developers that they may now check their patches into the Subversion | 
|  | tree again. | 
|  |  | 
|  | #. The Release Manager should switch to the release branch, because all changes | 
|  | to the release will now be done in the branch.  The easiest way to do this is | 
|  | to grab a working copy using the following commands: | 
|  |  | 
|  | :: | 
|  |  | 
|  | $ svn co https://llvm.org/svn/llvm-project/llvm/branches/release_XY llvm-X.Y | 
|  |  | 
|  | $ svn co https://llvm.org/svn/llvm-project/cfe/branches/release_XY clang-X.Y | 
|  |  | 
|  | $ svn co https://llvm.org/svn/llvm-project/test-suite/branches/release_XY test-suite-X.Y | 
|  |  | 
|  | Update LLVM Version | 
|  | ^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | After creating the LLVM release branch, update the release branches' | 
|  | ``autoconf`` and ``configure.ac`` versions from '``X.Ysvn``' to '``X.Y``'. | 
|  | Update it on mainline as well to be the next version ('``X.Y+1svn``'). | 
|  | Regenerate the configure scripts for both ``llvm`` and the ``test-suite``. | 
|  |  | 
|  | In addition, the version numbers of all the Bugzilla components must be updated | 
|  | for the next release. | 
|  |  | 
|  | Tagging the LLVM Release Candidates | 
|  | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Tag release candidates using the tag.sh script in utils/release. | 
|  |  | 
|  | :: | 
|  |  | 
|  | $ ./tag.sh -release X.Y.Z -rc $RC | 
|  |  | 
|  | The Release Manager may supply pre-packaged source tarballs for users.  This can | 
|  | be done with the export.sh script in utils/release. | 
|  |  | 
|  | :: | 
|  |  | 
|  | $ ./export.sh -release X.Y.Z -rc $RC | 
|  |  | 
|  | This will generate source tarballs for each LLVM project being validated, which | 
|  | can be uploaded to the website for further testing. | 
|  |  | 
|  | Build Clang Binary Distribution | 
|  | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Creating the ``clang`` binary distribution requires following the instructions | 
|  | :doc:`here <ReleaseProcess>`. | 
|  |  | 
|  | That process will perform both Release+Asserts and Release builds but only | 
|  | pack the Release build for upload. You should use the Release+Asserts sysroot, | 
|  | normally under ``final/Phase3/Release+Asserts/llvmCore-3.8.1-RCn.install/``, | 
|  | for test-suite and run-time benchmarks, to make sure nothing serious has | 
|  | passed through the net. For compile-time benchmarks, use the Release version. | 
|  |  | 
|  | The minimum required version of the tools you'll need are :doc:`here <GettingStarted>` | 
|  |  | 
|  | Release Qualification Criteria | 
|  | ------------------------------ | 
|  |  | 
|  | A release is qualified when it has no regressions from the previous release (or | 
|  | baseline).  Regressions are related to correctness first and performance second. | 
|  | (We may tolerate some minor performance regressions if they are deemed | 
|  | necessary for the general quality of the compiler.) | 
|  |  | 
|  | More specifically, Clang/LLVM is qualified when it has a clean test with all | 
|  | supported sub-projects included (``make check-all``), per target, and it has no | 
|  | regressions with the ``test-suite`` in relation to the previous release. | 
|  |  | 
|  | Regressions are new failures in the set of tests that are used to qualify | 
|  | each product and only include things on the list.  Every release will have | 
|  | some bugs in it.  It is the reality of developing a complex piece of | 
|  | software.  We need a very concrete and definitive release criteria that | 
|  | ensures we have monotonically improving quality on some metric.  The metric we | 
|  | use is described below.  This doesn't mean that we don't care about other | 
|  | criteria, but these are the criteria which we found to be most important and | 
|  | which must be satisfied before a release can go out. | 
|  |  | 
|  | Official Testing | 
|  | ---------------- | 
|  |  | 
|  | A few developers in the community have dedicated time to validate the release | 
|  | candidates and volunteered to be the official release testers for each | 
|  | architecture. | 
|  |  | 
|  | These will be the ones testing, generating and uploading the official binaries | 
|  | to the server, and will be the minimum tests *necessary* for the release to | 
|  | proceed. | 
|  |  | 
|  | This will obviously not cover all OSs and distributions, so additional community | 
|  | validation is important. However, if community input is not reached before the | 
|  | release is out, all bugs reported will have to go on the next stable release. | 
|  |  | 
|  | The official release managers are: | 
|  |  | 
|  | * Major releases (X.0): Hans Wennborg | 
|  | * Stable releases (X.n): Tom Stellard | 
|  |  | 
|  | The official release testers are volunteered from the community and have | 
|  | consistently validated and released binaries for their targets/OSs. To contact | 
|  | them, you should email the ``release-testers@lists.llvm.org`` mailing list. | 
|  |  | 
|  | The official testers list is in the file ``RELEASE_TESTERS.TXT``, in the ``LLVM`` | 
|  | repository. | 
|  |  | 
|  | Community Testing | 
|  | ----------------- | 
|  |  | 
|  | Once all testing has been completed and appropriate bugs filed, the release | 
|  | candidate tarballs are put on the website and the LLVM community is notified. | 
|  |  | 
|  | We ask that all LLVM developers test the release in any the following ways: | 
|  |  | 
|  | #. Download ``llvm-X.Y``, ``llvm-test-X.Y``, and the appropriate ``clang`` | 
|  | binary.  Build LLVM.  Run ``make check`` and the full LLVM test suite (``make | 
|  | TEST=nightly report``). | 
|  |  | 
|  | #. Download ``llvm-X.Y``, ``llvm-test-X.Y``, and the ``clang`` sources.  Compile | 
|  | everything.  Run ``make check`` and the full LLVM test suite (``make | 
|  | TEST=nightly report``). | 
|  |  | 
|  | #. Download ``llvm-X.Y``, ``llvm-test-X.Y``, and the appropriate ``clang`` | 
|  | binary. Build whole programs with it (ex. Chromium, Firefox, Apache) for | 
|  | your platform. | 
|  |  | 
|  | #. Download ``llvm-X.Y``, ``llvm-test-X.Y``, and the appropriate ``clang`` | 
|  | binary. Build *your* programs with it and check for conformance and | 
|  | performance regressions. | 
|  |  | 
|  | #. Run the :doc:`release process <ReleaseProcess>`, if your platform is | 
|  | *different* than that which is officially supported, and report back errors | 
|  | only if they were not reported by the official release tester for that | 
|  | architecture. | 
|  |  | 
|  | We also ask that the OS distribution release managers test their packages with | 
|  | the first candidate of every release, and report any *new* errors in Bugzilla. | 
|  | If the bug can be reproduced with an unpatched upstream version of the release | 
|  | candidate (as opposed to the distribution's own build), the priority should be | 
|  | release blocker. | 
|  |  | 
|  | During the first round of testing, all regressions must be fixed before the | 
|  | second release candidate is tagged. | 
|  |  | 
|  | In the subsequent stages, the testing is only to ensure that bug | 
|  | fixes previously merged in have not created new major problems. *This is not | 
|  | the time to solve additional and unrelated bugs!* If no patches are merged in, | 
|  | the release is determined to be ready and the release manager may move onto the | 
|  | next stage. | 
|  |  | 
|  | Reporting Regressions | 
|  | --------------------- | 
|  |  | 
|  | Every regression that is found during the tests (as per the criteria above), | 
|  | should be filled in a bug in Bugzilla with the priority *release blocker* and | 
|  | blocking a specific release. | 
|  |  | 
|  | To help manage all the bugs reported and which ones are blockers or not, a new | 
|  | "[meta]" bug should be created and all regressions *blocking* that Meta. Once | 
|  | all blockers are done, the Meta can be closed. | 
|  |  | 
|  | If a bug can't be reproduced, or stops being a blocker, it should be removed | 
|  | from the Meta and its priority decreased to *normal*. Debugging can continue, | 
|  | but on trunk. | 
|  |  | 
|  | Merge Requests | 
|  | -------------- | 
|  |  | 
|  | You can use any of the following methods to request that a revision from trunk | 
|  | be merged into a release branch: | 
|  |  | 
|  | #. Use the ``utils/release/merge-request.sh`` script which will automatically | 
|  | file a bug_ requesting that the patch be merged. e.g. To request revision | 
|  | 12345 be merged into the branch for the 5.0.1 release: | 
|  | ``llvm.src/utils/release/merge-request.sh -stable-version 5.0 -r 12345 -user bugzilla@example.com`` | 
|  |  | 
|  | #. Manually file a bug_ with the subject: "Merge r12345 into the X.Y branch", | 
|  | enter the commit(s) that you want merged in the "Fixed by Commit(s)" and mark | 
|  | it as a blocker of the current release bug.  Release bugs are given aliases | 
|  | in the form of release-x.y.z, so to mark a bug as a blocker for the 5.0.1 | 
|  | release, just enter release-5.0.1 in the "Blocks" field. | 
|  |  | 
|  | #. Reply to the commit email on llvm-commits for the revision to merge and cc | 
|  | the release manager. | 
|  |  | 
|  | .. _bug: https://bugs.llvm.org/ | 
|  |  | 
|  | Release Patch Rules | 
|  | ------------------- | 
|  |  | 
|  | Below are the rules regarding patching the release branch: | 
|  |  | 
|  | #. Patches applied to the release branch may only be applied by the release | 
|  | manager, the official release testers or the code owners with approval from | 
|  | the release manager. | 
|  |  | 
|  | #. During the first round of testing, patches that fix regressions or that are | 
|  | small and relatively risk free (verified by the appropriate code owner) are | 
|  | applied to the branch.  Code owners are asked to be very conservative in | 
|  | approving patches for the branch.  We reserve the right to reject any patch | 
|  | that does not fix a regression as previously defined. | 
|  |  | 
|  | #. During the remaining rounds of testing, only patches that fix critical | 
|  | regressions may be applied. | 
|  |  | 
|  | #. For dot releases all patches must maintain both API and ABI compatibility with | 
|  | the previous major release.  Only bug-fixes will be accepted. | 
|  |  | 
|  | Merging Patches | 
|  | ^^^^^^^^^^^^^^^ | 
|  |  | 
|  | The ``utils/release/merge.sh`` script can be used to merge individual revisions | 
|  | into any one of the llvm projects. To merge revision ``$N`` into project | 
|  | ``$PROJ``, do: | 
|  |  | 
|  | #. ``svn co https://llvm.org/svn/llvm-project/$PROJ/branches/release_XX | 
|  | $PROJ.src`` | 
|  |  | 
|  | #. ``$PROJ.src/utils/release/merge.sh --proj $PROJ --rev $N`` | 
|  |  | 
|  | #. Run regression tests. | 
|  |  | 
|  | #. ``cd $PROJ.src``. Run the ``svn commit`` command printed out by ``merge.sh`` | 
|  | in step 2. | 
|  |  | 
|  | Release Final Tasks | 
|  | ------------------- | 
|  |  | 
|  | The final stages of the release process involves tagging the "final" release | 
|  | branch, updating documentation that refers to the release, and updating the | 
|  | demo page. | 
|  |  | 
|  | Update Documentation | 
|  | ^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Review the documentation and ensure that it is up to date.  The "Release Notes" | 
|  | must be updated to reflect new features, bug fixes, new known issues, and | 
|  | changes in the list of supported platforms.  The "Getting Started Guide" should | 
|  | be updated to reflect the new release version number tag available from | 
|  | Subversion and changes in basic system requirements.  Merge both changes from | 
|  | mainline into the release branch. | 
|  |  | 
|  | .. _tag: | 
|  |  | 
|  | Tag the LLVM Final Release | 
|  | ^^^^^^^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Tag the final release sources using the tag.sh script in utils/release. | 
|  |  | 
|  | :: | 
|  |  | 
|  | $ ./tag.sh -release X.Y.Z -final | 
|  |  | 
|  | Update the LLVM Demo Page | 
|  | ------------------------- | 
|  |  | 
|  | The LLVM demo page must be updated to use the new release.  This consists of | 
|  | using the new ``clang`` binary and building LLVM. | 
|  |  | 
|  | Update the LLVM Website | 
|  | ^^^^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | The website must be updated before the release announcement is sent out.  Here | 
|  | is what to do: | 
|  |  | 
|  | #. Check out the ``www`` module from Subversion. | 
|  |  | 
|  | #. Create a new sub-directory ``X.Y`` in the releases directory. | 
|  |  | 
|  | #. Commit the ``llvm``, ``test-suite``, ``clang`` source and binaries in this | 
|  | new directory. | 
|  |  | 
|  | #. Copy and commit the ``llvm/docs`` and ``LICENSE.txt`` files into this new | 
|  | directory.  The docs should be built with ``BUILD_FOR_WEBSITE=1``. | 
|  |  | 
|  | #. Commit the ``index.html`` to the ``release/X.Y`` directory to redirect (use | 
|  | from previous release). | 
|  |  | 
|  | #. Update the ``releases/download.html`` file with the new release. | 
|  |  | 
|  | #. Update the ``releases/index.html`` with the new release and link to release | 
|  | documentation. | 
|  |  | 
|  | #. Finally, update the main page (``index.html`` and sidebar) to point to the | 
|  | new release and release announcement.  Make sure this all gets committed back | 
|  | into Subversion. | 
|  |  | 
|  | Announce the Release | 
|  | ^^^^^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | Send an email to the list announcing the release, pointing people to all the | 
|  | relevant documentation, download pages and bugs fixed. | 
|  |  |