aboutsummaryrefslogtreecommitdiff
path: root/clang/tools/offload-arch/AMDGPUArchByHIP.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'clang/tools/offload-arch/AMDGPUArchByHIP.cpp')
-rw-r--r--clang/tools/offload-arch/AMDGPUArchByHIP.cpp14
1 files changed, 10 insertions, 4 deletions
diff --git a/clang/tools/offload-arch/AMDGPUArchByHIP.cpp b/clang/tools/offload-arch/AMDGPUArchByHIP.cpp
index 11cff4f..ff39a85 100644
--- a/clang/tools/offload-arch/AMDGPUArchByHIP.cpp
+++ b/clang/tools/offload-arch/AMDGPUArchByHIP.cpp
@@ -98,8 +98,16 @@ static std::vector<std::string> getSearchPaths() {
// Custom comparison function for dll name
static bool compareVersions(StringRef A, StringRef B) {
auto ParseVersion = [](StringRef S) -> VersionTuple {
- size_t Pos = S.find_last_of('_');
- StringRef VerStr = (Pos == StringRef::npos) ? S : S.substr(Pos + 1);
+ StringRef Filename = sys::path::filename(S);
+ size_t Pos = Filename.find_last_of('_');
+ if (Pos == StringRef::npos)
+ return VersionTuple();
+
+ StringRef VerStr = Filename.substr(Pos + 1);
+ size_t DotPos = VerStr.find('.');
+ if (DotPos != StringRef::npos)
+ VerStr = VerStr.substr(0, DotPos);
+
VersionTuple Vt;
(void)Vt.tryParse(VerStr);
return Vt;
@@ -135,8 +143,6 @@ static std::pair<std::string, bool> findNewestHIPDLL() {
Filename.ends_with(HipDLLSuffix))
DLLNames.push_back(sys::path::convert_to_slash(DirIt->path()));
}
- if (!DLLNames.empty())
- break;
}
if (DLLNames.empty())