1 //===-- ARM64TargetInfo.cpp - ARM64 Target Implementation -----------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #include "llvm/ADT/Triple.h"
11 #include "llvm/Support/TargetRegistry.h"
15 Target TheARM64leTarget;
16 Target TheARM64beTarget;
17 Target TheAArch64leTarget;
18 Target TheAArch64beTarget;
19 } // end namespace llvm
21 extern "C" void LLVMInitializeARM64TargetInfo() {
22 RegisterTarget<Triple::arm64, /*HasJIT=*/true> X(TheARM64leTarget, "arm64",
23 "ARM64 (little endian)");
24 RegisterTarget<Triple::arm64_be, /*HasJIT=*/true> Y(TheARM64beTarget, "arm64_be",
25 "ARM64 (big endian)");
27 RegisterTarget<Triple::aarch64, /*HasJIT=*/true> Z(
28 TheAArch64leTarget, "aarch64", "ARM64 (little endian)");
29 RegisterTarget<Triple::aarch64_be, /*HasJIT=*/true> W(
30 TheAArch64beTarget, "aarch64_be", "ARM64 (big endian)");