| //===- unittests/Basic/OffloadArchTest.cpp - Test OffloadArch -------===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "clang/Basic/OffloadArch.h" |
| #include "gtest/gtest.h" |
| |
| using namespace clang; |
| |
| TEST(OffloadArchTest, basic) { |
| EXPECT_TRUE(IsNVIDIAOffloadArch(OffloadArch::SM_20)); |
| EXPECT_TRUE(IsNVIDIAOffloadArch(OffloadArch::SM_120a)); |
| EXPECT_FALSE(IsNVIDIAOffloadArch(OffloadArch::GFX600)); |
| |
| EXPECT_FALSE(IsAMDOffloadArch(OffloadArch::SM_120a)); |
| EXPECT_TRUE(IsAMDOffloadArch(OffloadArch::GFX600)); |
| EXPECT_TRUE(IsAMDOffloadArch(OffloadArch::GFX1201)); |
| EXPECT_TRUE(IsAMDOffloadArch(OffloadArch::GFX12_GENERIC)); |
| EXPECT_TRUE(IsAMDOffloadArch(OffloadArch::AMDGCNSPIRV)); |
| EXPECT_FALSE(IsAMDOffloadArch(OffloadArch::GRANITERAPIDS)); |
| |
| EXPECT_TRUE(IsIntelOffloadArch(OffloadArch::GRANITERAPIDS)); |
| EXPECT_TRUE(IsIntelCPUOffloadArch(OffloadArch::GRANITERAPIDS)); |
| EXPECT_FALSE(IsIntelGPUOffloadArch(OffloadArch::GRANITERAPIDS)); |
| EXPECT_TRUE(IsIntelOffloadArch(OffloadArch::BMG_G21)); |
| EXPECT_FALSE(IsIntelCPUOffloadArch(OffloadArch::BMG_G21)); |
| EXPECT_TRUE(IsIntelGPUOffloadArch(OffloadArch::BMG_G21)); |
| |
| EXPECT_FALSE(IsNVIDIAOffloadArch(OffloadArch::Generic)); |
| EXPECT_FALSE(IsAMDOffloadArch(OffloadArch::Generic)); |
| EXPECT_FALSE(IsIntelOffloadArch(OffloadArch::Generic)); |
| } |