Files
clang-p2996/llvm/lib/Target/SPIRV/TargetInfo/SPIRVTargetInfo.cpp
Nathan Gauër 56396b25f1 [SPIRV-V] Add SPIR-V logical triple to llc
This commits adds the minimal required bits to build a logical SPIR-V
compute shader using LLC.
- Skip OpenCL-only capabilities & extensions for Logical SPIR-V.
- Generate required metadata for entrypoints from HLSL frontend.
- Fix execution mode to GLCompute in logical.

The main issue is the lack of "vulkan" bit in the triple.
This might need to be added as a vendor?
Because as-is, SPIRV32/64 assumes OpenCL, and then, SPIRV assumes
Vulkan. This is ok-ish today, but not correct.

Differential Revision: https://reviews.llvm.org/D156424
2023-09-11 10:31:50 +02:00

35 lines
1.2 KiB
C++

//===-- SPIRVTargetInfo.cpp - SPIR-V Target Implementation ----*- C++ -*---===//
//
// 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 "TargetInfo/SPIRVTargetInfo.h"
#include "llvm/MC/TargetRegistry.h"
using namespace llvm;
Target &llvm::getTheSPIRV32Target() {
static Target TheSPIRV32Target;
return TheSPIRV32Target;
}
Target &llvm::getTheSPIRV64Target() {
static Target TheSPIRV64Target;
return TheSPIRV64Target;
}
Target &llvm::getTheSPIRVLogicalTarget() {
static Target TheSPIRVLogicalTarget;
return TheSPIRVLogicalTarget;
}
extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeSPIRVTargetInfo() {
RegisterTarget<Triple::spirv32> X(getTheSPIRV32Target(), "spirv32",
"SPIR-V 32-bit", "SPIRV");
RegisterTarget<Triple::spirv64> Y(getTheSPIRV64Target(), "spirv64",
"SPIR-V 64-bit", "SPIRV");
RegisterTarget<Triple::spirv> Z(getTheSPIRVLogicalTarget(), "spirv",
"SPIR-V Logical", "SPIRV");
}