Roll llvm-project from 6007ad79afef to 323911de2770 (25 revisions)

https://chromium.googlesource.com/external/github.com/llvm/llvm-project.git/+log/6007ad79afef..323911de2770

2024-09-11 chiahungduan@google.com Reapply "[scudo] Fix the logic of MaxAllowedFragmentedPages" (#108130) (#108134)
2024-09-11 tbaeder@redhat.com [clang][bytecode] Fix lookup of source locations in implicit ctors (#107992)
2024-09-11 aheejin@gmail.com [WebAssembly] Add assembly support for final EH proposal (#107917)
2024-09-11 kazu@google.com [LTO] Remove unused includes (NFC) (#108110)
2024-09-11 バレンタイン クレメン [flang][cuda] Avoid extra load in c_f_pointer lowering with c_devptr (#108090)
2024-09-11 56981066+Sterling-Augustine@users.noreply.github.com [SandboxIR] Implement ScalableVectorType (#108124)
2024-09-11 pklausler@nvidia.com [flang] Fix cycle of build dependencies (#108132)
2024-09-11 chiahungduan@google.com Revert "[scudo] Fix the logic of MaxAllowedFragmentedPages" (#108130)
2024-09-11 syq@debian.org SelectionDAG: Remove unneeded getSelectCC in expandFMINIMUMNUM_FMAXIMUMNUM (#107416)
2024-09-11 preames@rivosinc.com [RISCV] Add reductions to list of roots in tryToReduceVL (#107595)
2024-09-11 pklausler@nvidia.com [flang] Make flang module hidden dependency explicit to correct build… (#108129)
2024-09-11 luke@igalia.com [RISCV] Rematerialize vmv.s.x and vfmv.s.f (#108012)
2024-09-11 luke@igalia.com [RISCV] Rematerialize vfmv.v.f (#108007)
2024-09-11 syq@debian.org MIPSr6: Add llvm.is.fpclasss intrinsic support (#107857)
2024-09-11 jim@andestech.com [RISCV] Add testcase for -mcmodel= (#107816)
2024-09-11 luke@igalia.com [RISCV] Rematerialize vmv.v.x (#107993)
2024-09-11 patidarsahil2001@gmail.com [ORC][Runtime] Add `dlupdate` for MachO (#97441)
2024-09-11 chiahungduan@google.com [scudo] Fix the logic of MaxAllowedFragmentedPages (#107927)
2024-09-11 aeubanks@google.com [compiler-rt] Hardcode uptr/sptr typedefs on Linux Arm (#108105)
2024-09-10 craig.topper@sifive.com [LegalizeTypes] Avoid creating an unused node in ExpandIntRes_ADDSUB. NFC
2024-09-10 tejohnson@google.com [MemProf] Convert CallContextInfo to a struct (NFC) (#108086)
2024-09-10 rnk@google.com [docs] Add a section on AI-generated content to the developer policy (#91014)
2024-09-10 fmayer@google.com Revert "[sanitizer] Add CHECKs to validate calculated TLS range" (#108112)
2024-09-10 56981066+Sterling-Augustine@users.noreply.github.com [SandboxIR] Implement FixedVectorType (#107930)
2024-09-10 vporpodas@google.com [SandboxIR] Implement BlockAddress (#107940)

If this roll has caused a breakage, revert this CL and stop the roller
using the controls here:
https://autoroll.skia.org/r/llvm-project-emscripten-releases
Please CC dschuff@google.com,wasm-waterfall@grotations.appspotmail.com on the revert to ensure that a human
is aware of the problem.

To report a problem with the AutoRoller itself, please file a bug:
https://issues.skia.org/issues/new?component=1389291&template=1850622

Documentation for the AutoRoller is here:
https://skia.googlesource.com/buildbot/+doc/main/autoroll/README.md

Tbr: wasm-waterfall@grotations.appspotmail.com
Change-Id: Ia5ba0901542f0e3977e6e00d0656243c00d4dfc7
Reviewed-on: https://chromium-review.googlesource.com/c/emscripten-releases/+/5852635
Bot-Commit: chromium-autoroll <chromium-autoroll@skia-public.iam.gserviceaccount.com>
Commit-Queue: chromium-autoroll <chromium-autoroll@skia-public.iam.gserviceaccount.com>
1 file changed
tree: 3b97fcb4dc42a5cb8af0c30c2707755464f6007a
  1. src/
  2. third_party/
  3. tools/
  4. .gitignore
  5. bots.json
  6. codereview.settings
  7. DEPS
  8. DEPS.tagged-release
  9. PRESUBMIT.py
  10. README.md
README.md

Emscripten Releases

This is meta-repository which brings together all the repositories needed to produce an emscripten release. The revisions used in each release are tracked in a DEPS file (See depot_tools for more information). This file contains a history of revisions that have been built and tested together and represent a known good state.

Each release is automatically built and uploaded to to Google Cloud Storage and can be used standalone or with emsdk.

The build status for the automated builds can be seen here

Updating DEPS entries

Install depot_tools and then check out: gclient config https://chromium.googlesource.com/emscripten-releases (Do this only once)

Update working trees:

  • git pull
  • gclient sync

Update a DEPS entry:

  • cd emscripten-releases
  • git checkout -b <branch>
  • roll-dep emscripten-releases/llvm-project
  • git cl upload

The argument to roll-dep must match one of the keys in the ‘deps’ dictionary in the DEPS file. See roll-dep -h for more options.

༼ ༎ຶ ෴ ༎ຶ༽ Build and test scripts in src/

This directory was forked from the WebAssembly waterfall repo That repo was retired because it was only used by emscripten-releases.

How do I run it?

  1. Get the sources
  2. Install depot_tools. Follow the instructions
  3. Install pkg-config if you don't have it installed already, e.g. # apt install pkg-config
  4. Run build.py python src/build.py

Build.py has 3 types of actions:

  • downloading/updating sources for tools and engines (sync)
  • building those sources (build)
  • running tests against them (test).

Each of these types has multiple steps (e.g. a build step for each component). If you run build.py with no arguments, it will run all the sync, build, and test steps. If you make a change and only want to run a subset of steps, you can apply filters from the command line, via exclusions (to prevent specified steps from running) or inclusions (to run only the specified steps). Sync, build, and test exclusions are specified separately. For example:

  1. Do not sync any sources, build everything except LLVM, and run all tests: $ src/build.py --no-sync --build-exclude=llvm
  2. Sync only binaryen, build LLVM and Binaryen, run everything other than the emscripten testsuites: $ src/build.py --sync-include=binaryen --build-include=llvm,binaryen --test-exclude=emtest,emtest-asm

The script should throw an error if you specify nonexistent steps or if you specify both includes and excludes for the same type of action.

When run, the script creates a directory src/work inside the waterfall‘s git checkout. All modifications are made inside this directory (checking and out and building the sources, as well as the test builds and execution results). You can also use the git checkouts (e.g. src/work/llvm) with your own branches; the sync steps will check out the latest revision from the script’s remote repositories but will not overwrite or destroy any local work.