From d371486c0a09e15bd4cf5fdf0fc6e995b5b26f70 Mon Sep 17 00:00:00 2001 From: Manish Goregaokar Date: Sat, 28 Dec 2024 14:38:15 -0800 Subject: [PATCH 1/4] Add explicit policy about updating the linked LLVM version --- documents/process/rust_versions.md | 96 ++++++++++++++++++++++++++++++ 1 file changed, 96 insertions(+) diff --git a/documents/process/rust_versions.md b/documents/process/rust_versions.md index 975fb85f8fe..266b9eb0ca0 100644 --- a/documents/process/rust_versions.md +++ b/documents/process/rust_versions.md @@ -26,3 +26,99 @@ When the nightly cronjob CI fails, ICU4X developers must fix it and ensure it do [stability-policy]: https://rust-lang.github.io/rfcs/1122-language-semver.html + + +### Pinned Rust nightly policy + +ICU4X pins a Rust Nightly in CI for multiple purposes: + + - `diplomat-coverage/src/main.rs`: Running the diplomat-coverage task, which uses unstable Rustdoc JSON output, requiring synchronization between the Rust version and the `rustdoc_types` dependency. + - `PINNED_CI_NIGHTLY`: Running various FFI CI jobs that need _some_ Rust nightly to use build-std or other nightly features, without becoming beholden to arbitrary + - `LLVM_COMPATIBLE_NIGHTLY`: Usage of `-Clinker-plugin-lto` in size-optimized tests where Rust and Clang need to be using compatible LLVM versions. + + + ICU4X also runs its entire CI against the latest nightly once a day, reporting errors to Slack. These errors help us catch upstream breakages early, but ICU4X does not have any particular SLO against these being fixed. We guarantee we build on the latest stable as detailed in the first section of this page. + + The first two nightlies here can be updated whenever necessary to whatever nightly works. It not necessary to keep the nightly versions the same, though it is ideal to try. + + + We have a stricter policy around updating `LLVM_COMPATIBLE_NIGHTLY`. We recommend usage of ICU4X with `-Clinker-plugin-lto` for size-constrained clients who have the option available, so `LLVM_COMPATIBLE_NIGHTLY` must be updated to nightlies that work with "widely available LLVM" versions. This may further constrain our MSRV policy above in case `LLVM_COMPATIBLE_NIGHTLY` cannot be pinned to something that works with an otherwise-allowed MSRV. + +An `LLVM_COMPATIBLE_NIGHTLY` is said to "work with" an LLVM version when the size test benchmarks (makefiles in `tutorials/c-tiny/`) run without erroring due to mismatched LLVM metadata. Note that Rust uses LLVM trunk, so it may happen that a Rust nightly is not compatible with _any_ released LLVM version. Some experimentation is often required to find a nightly/LLVM pair that works. + + +"widely available LLVM" here means that: + + - It MUST be available via apt on all currently-supported Ubuntu LTS + - It MUST be available via apt on Debian `testing` + - It MUST be available via `brew` + - It MUST be available on the GitHub Actions runners with `ubuntu-latest` + - It SHOULD be available on the latest XCode + - It SHOULD be available on ICU4X developer machines using nonstandard package management (more on this below) + + + +More information on each of these bullet points, and how to verify them without needing that OS. below. Commands are for installing LLVM 18, for illustrative purposes.. + + +#### Ubuntu + +Policy: Must be available on the oldest still-supported Ubuntu LTS. + +Command: `apt install llvm-18` on Ubuntu LTS. + +Verification: Package should be available on [oldest still-supported Ubuntu LTS][ubuntu-release]. Visit the page https://launchpad.net/ubuntu/+source/llvm-toolchain-18 (with the number replaced with the desired LLVM version), and scroll down to see if the oldest active Ubuntu LTS is there. [Currently][ubuntu-release], that is 20.04 Focal Fossa, starting April 2025 it will be Jammy Jellyfish (until April 2027). + + + [ubuntu-release]: https://ubuntu.com/about/release-cycle + +#### Debian + +Policy: Must be available on Debian testing. + +Command: `apt install llvm-18` on Debian testing. + + +Verification: Visit the page https://packages.debian.org/search?keywords=llvm-18&searchon=names&suite=testing§ion=all (with the number 18 replaced by the desired LLVM version) and ensure the package is listed under "Exact matches". + +Note: "Debian stable" is typically _very_ old and is not what most Debian-based systems use. E.g. Debian stable is currently on Rust 1.63, which is more than two years old. Stable is intended to be extremely stable without even performing backwards-compatible upgrades. + + +#### XCode + +Policy: Should be available on the latest XCode, but policy can be overridden by TC approval in cases where there is a strong case for a new feature. + +Command: none + + +Verification: Look at the bottom of [XCode's Wikipedia page][xcode-wiki] and check that the latest released XCode has an LLVM version equal to or greater than the one being used. + + [xcode-wiki]: https://en.wikipedia.org/wiki/Xcode#Xcode_15.0_-_(since_visionOS_support)_2 + +#### Brew + +Policy: Must be available via brew. + +Command: `brew install llvm@18` on OSX. + +Verification: Visit https://formulae.brew.sh/formula/llvm#default and ensure the `llvm@N` package is listed, for version N. + +#### GitHub Actions + +Policy: Must be available on GitHub actions `ubuntu-latest` (i.e. ICU4X CI should be able to just `apt install` the LLVM) + +Command `apt install llvm-18` on ICU4X CI. + +Verification: `ubuntu-latest` is always older than the oldest still-supported Ubuntu LTS, so this does not need to be verified separately. There are potential edge cases where GitHub's package repository mirrors are lagging behind where this policy basically means that we should wait a few days for things to smooth out. + +#### ICU4X developer machines + +ICU4X developers may request additional criteria for their machines in case their machines use nonstandard package management, for example employer-managed machinees. These criteria will be listed below, and adding new criteria should require TC approval. + +Policy: Should be available on ICU4X developer machines based on criteria below. Overriding this policy requires approval from affected developers. + +Verification: Affected ICU4X developers are in charge of testing this: if developer A wishes to perform an LLVM upgrade to a version satisfying all of the above policies, they may do so without checking if it works on developer B's machine, but developer B is allowed to block or revert the PR if they have issues. + +The current criteria are: + + - "Available on GLinux" (Used by Googler ICU4X developers): GLinux packages are based on Debian `testing` so this should almost always be true based on previous criteria, but there may be occasional cases where things lag behind for a week or two, in which case the Rust upgrade should be delayed til fixed. From a7cbd35cf1e30d9c9a2f989fca2f286802c039b3 Mon Sep 17 00:00:00 2001 From: Manish Goregaokar Date: Thu, 2 Jan 2025 11:55:52 -0800 Subject: [PATCH 2/4] fedora --- documents/process/rust_versions.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/documents/process/rust_versions.md b/documents/process/rust_versions.md index 266b9eb0ca0..21ed0219daa 100644 --- a/documents/process/rust_versions.md +++ b/documents/process/rust_versions.md @@ -52,6 +52,7 @@ An `LLVM_COMPATIBLE_NIGHTLY` is said to "work with" an LLVM version when the siz - It MUST be available via apt on all currently-supported Ubuntu LTS - It MUST be available via apt on Debian `testing` - It MUST be available via `brew` + - It MUST be available on Fedora via `yum` - It MUST be available on the GitHub Actions runners with `ubuntu-latest` - It SHOULD be available on the latest XCode - It SHOULD be available on ICU4X developer machines using nonstandard package management (more on this below) @@ -83,6 +84,13 @@ Verification: Visit the page https://packages.debian.org/search?keywords=llvm-1 Note: "Debian stable" is typically _very_ old and is not what most Debian-based systems use. E.g. Debian stable is currently on Rust 1.63, which is more than two years old. Stable is intended to be extremely stable without even performing backwards-compatible upgrades. +#### Fedora + +Policy: Must be available on latest stable Fedora + +Command: `yum install llvm18` + +Verification: Visit the page https://packages.fedoraproject.org/pkgs/llvm18/llvm18/ (with the number 18 replaced with desired LLVM version), and ensure that in the "Releases overview" table, there is an entry in the "Stable" column for "Fedora N" where N is a number. You can double check that N is the latest stable by visiting [this page](https://fedoraproject.org/). #### XCode From 031640252bef934dc2d21cd0a2183b1cd57fc911 Mon Sep 17 00:00:00 2001 From: Manish Goregaokar Date: Thu, 2 Jan 2025 15:06:05 -0800 Subject: [PATCH 3/4] Add RHEL policy --- documents/process/rust_versions.md | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/documents/process/rust_versions.md b/documents/process/rust_versions.md index 21ed0219daa..4be87c51c81 100644 --- a/documents/process/rust_versions.md +++ b/documents/process/rust_versions.md @@ -56,6 +56,7 @@ An `LLVM_COMPATIBLE_NIGHTLY` is said to "work with" an LLVM version when the siz - It MUST be available on the GitHub Actions runners with `ubuntu-latest` - It SHOULD be available on the latest XCode - It SHOULD be available on ICU4X developer machines using nonstandard package management (more on this below) + - It SHOULD be available on RHEL and latest Rocky Linux via `yum` @@ -111,6 +112,14 @@ Command: `brew install llvm@18` on OSX. Verification: Visit https://formulae.brew.sh/formula/llvm#default and ensure the `llvm@N` package is listed, for version N. +#### RHEL / Rocky Linux + +Policy: Should be available via `yum`, but policy can be overridden by TC approval in cases where there is a strong case for a new feature. + +Command: `yum module install llvm-toolset` or `dnf install llvm-toolset` (RHEL 9) + +Verification: Latest Rocky Linux (currently Rocky Linux 9) and RHEL should be listed on [this page](https://pkgs.org/search/?q=llvm-toolset) with an LLVM version that is equal to or greater than the desired LLVM version. It's okay if the exact LLVM version is not listed, `yum module install` allows installing older versions via explicit command. + #### GitHub Actions Policy: Must be available on GitHub actions `ubuntu-latest` (i.e. ICU4X CI should be able to just `apt install` the LLVM) From d83d8c8330ed6f629192223d94789527139f0e5c Mon Sep 17 00:00:00 2001 From: Manish Goregaokar Date: Sun, 5 Jan 2025 11:54:52 -0800 Subject: [PATCH 4/4] explain SHOULD --- documents/process/rust_versions.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/documents/process/rust_versions.md b/documents/process/rust_versions.md index 4be87c51c81..2e9410eb2af 100644 --- a/documents/process/rust_versions.md +++ b/documents/process/rust_versions.md @@ -58,9 +58,9 @@ An `LLVM_COMPATIBLE_NIGHTLY` is said to "work with" an LLVM version when the siz - It SHOULD be available on ICU4X developer machines using nonstandard package management (more on this below) - It SHOULD be available on RHEL and latest Rocky Linux via `yum` +Here, SHOULD requirements can be overridden by TC approval, where the developer must make a per-use case argument as to why the upgrade is beneficial to the project. - -More information on each of these bullet points, and how to verify them without needing that OS. below. Commands are for installing LLVM 18, for illustrative purposes.. +More information on each of these bullet points, and how to verify them without needing that OS. below. Commands are for installing LLVM 18, for illustrative purposes. #### Ubuntu