aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Driver/Driver.cpp
diff options
context:
space:
mode:
authorFangrui Song <i@maskray.me>2024-06-28 11:06:29 -0700
committerFangrui Song <i@maskray.me>2024-06-28 11:06:29 -0700
commit592abf29f9f7f73e6be28bef4574172125e4ab3f (patch)
treef28478f3ba700b38c8f31ac004308aa34769cfef /clang/lib/Driver/Driver.cpp
parentcf311a1131b9aef3e66b2a20ad49cfc77212754b (diff)
downloadllvm-592abf29f9f7f73e6be28bef4574172125e4ab3f.zip
llvm-592abf29f9f7f73e6be28bef4574172125e4ab3f.tar.gz
llvm-592abf29f9f7f73e6be28bef4574172125e4ab3f.tar.bz2
[Driver] BuildOffloadingActions: Actually stabilize iteration order
In ``` /tmp/StaticDebug/bin/clang -ccc-print-phases -lsomelib -fopenmp=libomp --target=powerpc64-ibm-linux-gnu -fopenmp-targets=x86_64-pc-linux-gnu,powerpc64-ibm-linux-gnu clang/test/Driver/openmp-offload.c clang/test/Driver/openmp-offload.c ``` Both ToolChains have one single empty arch. llvm::sort in LLVM_ENABLE_EXPENSIVE_CHECKS=on builds could swap the two entries. Fixes: 255986e27fcf9f0b36f7a23fbe030fcca1ba0249
Diffstat (limited to 'clang/lib/Driver/Driver.cpp')
-rw-r--r--clang/lib/Driver/Driver.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp
index 8fa8673..6314bc5 100644
--- a/clang/lib/Driver/Driver.cpp
+++ b/clang/lib/Driver/Driver.cpp
@@ -4597,10 +4597,13 @@ Action *Driver::BuildOffloadingActions(Compilation &C,
// Get the product of all bound architectures and toolchains.
SmallVector<std::pair<const ToolChain *, StringRef>> TCAndArchs;
- for (const ToolChain *TC : ToolChains)
- for (StringRef Arch : getOffloadArchs(C, Args, Kind, TC))
+ for (const ToolChain *TC : ToolChains) {
+ llvm::DenseSet<StringRef> Arches = getOffloadArchs(C, Args, Kind, TC);
+ SmallVector<StringRef, 0> Sorted(Arches.begin(), Arches.end());
+ llvm::sort(Sorted);
+ for (StringRef Arch : Sorted)
TCAndArchs.push_back(std::make_pair(TC, Arch));
- llvm::sort(TCAndArchs, llvm::less_second());
+ }
for (unsigned I = 0, E = TCAndArchs.size(); I != E; ++I)
DeviceActions.push_back(C.MakeAction<InputAction>(*InputArg, InputType));