Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 1 | //===-- TargetInfo/AMDGPUTargetInfo.cpp - TargetInfo for AMDGPU -----------===// |
| 2 | // |
Chandler Carruth | 2946cd7 | 2019-01-19 08:50:56 +0000 | [diff] [blame] | 3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| 4 | // See https://llvm.org/LICENSE.txt for license information. |
| 5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 6 | // |
| 7 | //===----------------------------------------------------------------------===// |
| 8 | // |
| 9 | /// \file |
| 10 | // |
| 11 | //===----------------------------------------------------------------------===// |
| 12 | |
Richard Trieu | 8ce2ee9 | 2019-05-14 21:54:37 +0000 | [diff] [blame] | 13 | #include "TargetInfo/AMDGPUTargetInfo.h" |
Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 14 | #include "llvm/Support/TargetRegistry.h" |
| 15 | |
| 16 | using namespace llvm; |
| 17 | |
Adrian Prantl | 5f8f34e4 | 2018-05-01 15:54:18 +0000 | [diff] [blame] | 18 | /// The target which supports all AMD GPUs. This will eventually |
Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 19 | /// be deprecated and there will be a R600 target and a GCN target. |
Mehdi Amini | f42454b | 2016-10-09 23:00:34 +0000 | [diff] [blame] | 20 | Target &llvm::getTheAMDGPUTarget() { |
| 21 | static Target TheAMDGPUTarget; |
| 22 | return TheAMDGPUTarget; |
| 23 | } |
Adrian Prantl | 5f8f34e4 | 2018-05-01 15:54:18 +0000 | [diff] [blame] | 24 | /// The target for GCN GPUs |
Mehdi Amini | f42454b | 2016-10-09 23:00:34 +0000 | [diff] [blame] | 25 | Target &llvm::getTheGCNTarget() { |
| 26 | static Target TheGCNTarget; |
| 27 | return TheGCNTarget; |
| 28 | } |
Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 29 | |
Adrian Prantl | 5f8f34e4 | 2018-05-01 15:54:18 +0000 | [diff] [blame] | 30 | /// Extern function to initialize the targets for the AMDGPU backend |
Tom Stellard | 4b0b261 | 2019-06-11 03:21:13 +0000 | [diff] [blame] | 31 | extern "C" void LLVMInitializeAMDGPUTargetInfo() { |
Mehdi Amini | f42454b | 2016-10-09 23:00:34 +0000 | [diff] [blame] | 32 | RegisterTarget<Triple::r600, false> R600(getTheAMDGPUTarget(), "r600", |
Daniel Sanders | 725584e | 2017-11-15 23:55:44 +0000 | [diff] [blame] | 33 | "AMD GPUs HD2XXX-HD6XXX", "AMDGPU"); |
Mehdi Amini | f42454b | 2016-10-09 23:00:34 +0000 | [diff] [blame] | 34 | RegisterTarget<Triple::amdgcn, false> GCN(getTheGCNTarget(), "amdgcn", |
Daniel Sanders | 725584e | 2017-11-15 23:55:44 +0000 | [diff] [blame] | 35 | "AMD GCN GPUs", "AMDGPU"); |
Tom Stellard | 45bb48e | 2015-06-13 03:28:10 +0000 | [diff] [blame] | 36 | } |