
Following #137070, this PR adds an initial set of Intel `OffloadArch` values with corresponding predicates that will be used in SYCL offloading. More Intel architectures will be added in a future PR.
37 lines
1.5 KiB
C++
37 lines
1.5 KiB
C++
//===- 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));
|
|
}
|