xref: /aosp_15_r20/external/llvm/lib/Target/AArch64/TargetInfo/AArch64TargetInfo.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker //===-- AArch64TargetInfo.cpp - AArch64 Target Implementation -----------------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker //                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker 
10*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/Triple.h"
11*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/TargetRegistry.h"
12*9880d681SAndroid Build Coastguard Worker using namespace llvm;
13*9880d681SAndroid Build Coastguard Worker 
14*9880d681SAndroid Build Coastguard Worker namespace llvm {
15*9880d681SAndroid Build Coastguard Worker Target TheAArch64leTarget;
16*9880d681SAndroid Build Coastguard Worker Target TheAArch64beTarget;
17*9880d681SAndroid Build Coastguard Worker Target TheARM64Target;
18*9880d681SAndroid Build Coastguard Worker } // end namespace llvm
19*9880d681SAndroid Build Coastguard Worker 
LLVMInitializeAArch64TargetInfo()20*9880d681SAndroid Build Coastguard Worker extern "C" void LLVMInitializeAArch64TargetInfo() {
21*9880d681SAndroid Build Coastguard Worker   // Now register the "arm64" name for use with "-march". We don't want it to
22*9880d681SAndroid Build Coastguard Worker   // take possession of the Triple::aarch64 tag though.
23*9880d681SAndroid Build Coastguard Worker   TargetRegistry::RegisterTarget(TheARM64Target, "arm64",
24*9880d681SAndroid Build Coastguard Worker                                  "ARM64 (little endian)",
25*9880d681SAndroid Build Coastguard Worker                                  [](Triple::ArchType) { return false; }, true);
26*9880d681SAndroid Build Coastguard Worker 
27*9880d681SAndroid Build Coastguard Worker   RegisterTarget<Triple::aarch64, /*HasJIT=*/true> Z(
28*9880d681SAndroid Build Coastguard Worker       TheAArch64leTarget, "aarch64", "AArch64 (little endian)");
29*9880d681SAndroid Build Coastguard Worker   RegisterTarget<Triple::aarch64_be, /*HasJIT=*/true> W(
30*9880d681SAndroid Build Coastguard Worker       TheAArch64beTarget, "aarch64_be", "AArch64 (big endian)");
31*9880d681SAndroid Build Coastguard Worker 
32*9880d681SAndroid Build Coastguard Worker }
33