1 use crate::spec::{LinkerFlavor, MergeFunctions, PanicStrategy, Target, TargetOptions};
3 pub fn target() -> Target {
5 arch: "nvptx64".into(),
6 data_layout: "e-i64:64-i128:128-v16:16-v32:32-n16:32:64".into(),
7 llvm_target: "nvptx64-nvidia-cuda".into(),
10 options: TargetOptions {
12 vendor: "nvidia".into(),
13 linker_flavor: LinkerFlavor::Ptx,
14 // The linker can be installed from `crates.io`.
15 linker: Some("rust-ptx-linker".into()),
17 // With `ptx-linker` approach, it can be later overridden via link flags.
20 // FIXME: create tests for the atomics.
21 max_atomic_width: Some(64),
23 // Unwinding on CUDA is neither feasible nor useful.
24 panic_strategy: PanicStrategy::Abort,
26 // Needed to use `dylib` and `bin` crate types and the linker.
27 dynamic_linking: true,
29 // Avoid using dylib because it contain metadata not supported
30 // by LLVM NVPTX backend.
33 // Let the `ptx-linker` to handle LLVM lowering into MC / assembly.
36 // Convenient and predicable naming scheme.
37 dll_prefix: "".into(),
38 dll_suffix: ".ptx".into(),
39 exe_suffix: ".ptx".into(),
41 // Disable MergeFunctions LLVM optimisation pass because it can
42 // produce kernel functions that call other kernel functions.
43 // This behavior is not supported by PTX ISA.
44 merge_functions: MergeFunctions::Disabled,
46 // The LLVM backend does not support stack canaries for this target
47 supports_stack_protector: false,