(56 intermediate revisions by 2 users not shown) | |||
Line 17: | Line 17: | ||
== Current status == | == Current status == | ||
* Targeted release: [[Releases/ | * Targeted release: [[Releases/22 | Fedora 22 ]] | ||
* Last updated: | * Last updated: 2015-04-03 | ||
<!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | <!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | ||
Bugzilla states meaning as usual: | Bugzilla states meaning as usual: | ||
Line 27: | Line 27: | ||
CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development | CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development | ||
--> | --> | ||
* Tracker bug: | * Tracker bug: [https://bugzilla.redhat.com/show_bug.cgi?id=1086273 #1086273] | ||
== Detailed Description == | == Detailed Description == | ||
* | * This involves updating ghc from 7.6.3 to 7.8.4, and updating/rebuilding all Fedora Haskell packages. [packages built] | ||
* The initial work will be done locally offline to make sure that it is possible to build all our packages with ghc-7.8 and the latest updated libraries. | * The initial work will be done locally offline to make sure that it is possible to build all our packages with ghc-7.8 and the latest updated libraries. [done] | ||
* | * A Koji side tag will then be used to build all the packages before the Side Tag Builds Deadline. [done] | ||
* Once | * Once the packages have been tested, the builds will be moved into f22. [done] | ||
== Benefit to Fedora == | == Benefit to Fedora == | ||
GHC 7.8 is major new version of the major Haskell compiler with many new features and enhancements. | GHC 7.8 is major new version of the major Haskell compiler with many new features and enhancements. | ||
See the release notes link below for more details on the changes. | See the upstream release notes link below for more details on the changes. | ||
For example the new runtime I/O manager scales significantly better for larger workloads compared to the previous one: it should scale linearly up to approximately 32 cores ([http://www.reddit.com/r/haskell/comments/18d81l/ghc_head_new_parallel_io_manager_merged/ reference]). | For example the new runtime I/O manager scales significantly better for larger workloads compared to the previous one: it should scale linearly up to approximately 32 cores ([http://www.reddit.com/r/haskell/comments/18d81l/ghc_head_new_parallel_io_manager_merged/ reference]). | ||
Line 46: | Line 46: | ||
* Proposal owners: | * Proposal owners: | ||
** locally test rebuilding and updating of all packages | ** locally test rebuilding and updating of all packages | ||
** update macros to subpackage static libraries | ** (optional) update macros to subpackage static libraries | ||
** push changes to Koji | ** push changes to Koji | ||
** testing | ** testing | ||
* Other developers: If you own a package which contains some Haskell code built with ghc you will need to rebuild you package to make sure it still rebuilds with ghc-7.8. Feel free to contact the Haskell SIG if we need assistance with fixing any build breakage, and we will try to help out. <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | * Other developers: | ||
** If you own a package which contains some Haskell code built with ghc you will need to rebuild you package to make sure it still rebuilds with ghc-7.8. Feel free to contact the Haskell SIG if we need assistance with fixing any build breakage, and we will try to help out. | |||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | |||
<!-- What work do other developers have to accomplish to complete the feature in time for release? Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?--> | <!-- What work do other developers have to accomplish to complete the feature in time for release? Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?--> | ||
* Release engineering: | * Release engineering: f22-ghc koji side tag [[https://fedorahosted.org/rel-eng/ticket/6085 ticket]] | ||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | |||
<!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuid required? If a rel-eng ticket exists, add a link here. --> | <!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuid required? If a rel-eng ticket exists, add a link here. --> | ||
* Policies and guidelines: | * Policies and guidelines: | ||
** There may be some lesser changes to the Haskell Packaging Guidelines needed - they could be done after this Change. | |||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | |||
<!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. --> | <!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. --> | ||
Line 63: | Line 68: | ||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
Upgrading will be tested and should Just Work. | * Upgrading will be tested and should Just Work. | ||
* Local user code may need some minor changes to build with ghc-7.8. | |||
== How To Test == | == How To Test == | ||
Line 80: | Line 86: | ||
--> | --> | ||
# yum install ghc cabal-install cabal-rpm pandoc xmonad git-annex hledger | |||
# Check these packages install, run correctly, and can build Haskell and Hackage packages. | |||
== User Experience == | == User Experience == | ||
<!-- If this change proposal is noticeable by its target audience, how will their experiences change as a result? Describe what they will see or notice. --> | <!-- If this change proposal is noticeable by its target audience, how will their experiences change as a result? Describe what they will see or notice. --> | ||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
Fedora users using GHC to programming or develop in Haskell will benefit from the new features and performance enhancements of the latest version of the ghc compiler. | |||
Additionally various package upgrades will also improve the experience for users of Haskell packages. | Additionally various package upgrades will also improve the experience for users of Haskell packages. | ||
Line 95: | Line 98: | ||
<!-- What other packages (RPMs) depend on this package? Are there changes outside the developers' control on which completion of this change depends? In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate? Other upstream projects like the kernel (if this is not a kernel change)? --> | <!-- What other packages (RPMs) depend on this package? Are there changes outside the developers' control on which completion of this change depends? In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate? Other upstream projects like the kernel (if this is not a kernel change)? --> | ||
GHC 7.8. | * GHC 7.8.3 was released 2014-07-11 | ||
* GHC 7.8.4 bugfix released 2014-12-23 | |||
There are a few packages outside the Haskell SIG that use ghc for some part of their build. | There are a few packages outside the Haskell SIG that use ghc for some part of their build. | ||
Assistance can be provided if needed to build them with latest ghc. | Assistance can be provided if needed to build them with latest ghc. | ||
== Contingency Plan == | == Contingency Plan == | ||
<!-- If you cannot complete your feature by the final development freeze, what is the backup plan? This might be as simple as "Revert the shipped configuration". Or it might not (e.g. rebuilding a number of dependent packages). If you feature is not completed in time we want to assure others that other parts of Fedora will not be in jeopardy. --> | <!-- If you cannot complete your feature by the final development freeze, what is the backup plan? This might be as simple as "Revert the shipped configuration". Or it might not (e.g. rebuilding a number of dependent packages). If you feature is not completed in time we want to assure others that other parts of Fedora will not be in jeopardy. --> | ||
* Contingency mechanism: | * Contingency mechanism: if it is not possible to complete the building and testing in f22-build in time for the Mass Rebuild then ghc will be reverted back to current 7.6.3 and packages rebuilt as necessary. (Proposal Owners) <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
<!-- When is the last time the contingency mechanism can be put in place? This will typically be the beta freeze. --> | <!-- When is the last time the contingency mechanism can be put in place? This will typically be the beta freeze. --> | ||
* Contingency deadline: Beta Freeze <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | * Contingency deadline: Beta Freeze <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
<!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? --> | <!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? --> | ||
* Blocks release: | * Blocks release: Yes <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
* Blocks product: N/A <-- Applicable for Changes that blocks specific product release/Fedora.next --> | * Blocks product: N/A <!-- Applicable for Changes that blocks specific product release/Fedora.next --> | ||
== Documentation == | == Documentation == | ||
<!-- Is there upstream documentation on this change, or notes you have written yourself? Link to that material here so other interested developers can get involved. --> | <!-- Is there upstream documentation on this change, or notes you have written yourself? Link to that material here so other interested developers can get involved. --> | ||
* Release notes for [https://downloads.haskell.org/~ghc/7.8.4/docs/html/users_guide/release-7-8-1.html 7.8.1] | |||
* Bug fix releases: [https://downloads.haskell.org/~ghc/7.8.4/docs/html/users_guide/release-7-8-3.html 7.8.3] and [https://downloads.haskell.org/~ghc/7.8.4/docs/html/users_guide/release-7-8-4.html 7.8.4] | |||
== Release Notes == | == Release Notes == | ||
Line 126: | Line 125: | ||
--> | --> | ||
[[Category: | [[Category:ChangeAcceptedF22]] | ||
<!-- When your change proposal page is completed and ready for review and announcement --> | <!-- When your change proposal page is completed and ready for review and announcement --> | ||
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler --> | <!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler --> |
Latest revision as of 09:27, 3 April 2015
GHC 7.8
Summary
Update the GHC Haskell compiler to the major new 7.8 release, and update/rebuild all Haskell packages against it.
Owner
- Name: Jens Petersen, Ricky Elrod, Haskell_SIG
- Email: petersen@redhat.com, relrod@redhat.com, haskell@lists.fedoraproject.org
- Release notes owner:
Current status
Detailed Description
- This involves updating ghc from 7.6.3 to 7.8.4, and updating/rebuilding all Fedora Haskell packages. [packages built]
- The initial work will be done locally offline to make sure that it is possible to build all our packages with ghc-7.8 and the latest updated libraries. [done]
- A Koji side tag will then be used to build all the packages before the Side Tag Builds Deadline. [done]
- Once the packages have been tested, the builds will be moved into f22. [done]
Benefit to Fedora
GHC 7.8 is major new version of the major Haskell compiler with many new features and enhancements. See the upstream release notes link below for more details on the changes.
For example the new runtime I/O manager scales significantly better for larger workloads compared to the previous one: it should scale linearly up to approximately 32 cores (reference).
Scope
- Proposal owners:
- locally test rebuilding and updating of all packages
- (optional) update macros to subpackage static libraries
- push changes to Koji
- testing
- Other developers:
- If you own a package which contains some Haskell code built with ghc you will need to rebuild you package to make sure it still rebuilds with ghc-7.8. Feel free to contact the Haskell SIG if we need assistance with fixing any build breakage, and we will try to help out.
- Release engineering: f22-ghc koji side tag [ticket]
- Policies and guidelines:
- There may be some lesser changes to the Haskell Packaging Guidelines needed - they could be done after this Change.
Upgrade/compatibility impact
- Upgrading will be tested and should Just Work.
- Local user code may need some minor changes to build with ghc-7.8.
How To Test
- yum install ghc cabal-install cabal-rpm pandoc xmonad git-annex hledger
- Check these packages install, run correctly, and can build Haskell and Hackage packages.
User Experience
Fedora users using GHC to programming or develop in Haskell will benefit from the new features and performance enhancements of the latest version of the ghc compiler. Additionally various package upgrades will also improve the experience for users of Haskell packages.
Dependencies
- GHC 7.8.3 was released 2014-07-11
- GHC 7.8.4 bugfix released 2014-12-23
There are a few packages outside the Haskell SIG that use ghc for some part of their build. Assistance can be provided if needed to build them with latest ghc.
Contingency Plan
- Contingency mechanism: if it is not possible to complete the building and testing in f22-build in time for the Mass Rebuild then ghc will be reverted back to current 7.6.3 and packages rebuilt as necessary. (Proposal Owners)
- Contingency deadline: Beta Freeze
- Blocks release: Yes
- Blocks product: N/A