reference, declaration → definition definition → references, declarations, derived classes, virtual overrides reference to multiple definitions → definitions unreferenced |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | //===--- unittests/DebugInfo/DWARF/DwarfUtils.cpp ---------------*- 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 "DwarfUtils.h" #include "llvm/ADT/Triple.h" #include "llvm/Config/llvm-config.h" #include "llvm/Support/Host.h" #include "llvm/Support/TargetRegistry.h" #include "llvm/Support/TargetSelect.h" using namespace llvm; static void initLLVMIfNeeded() { static bool gInitialized = false; if (!gInitialized) { gInitialized = true; InitializeAllTargets(); InitializeAllTargetMCs(); InitializeAllAsmPrinters(); InitializeAllAsmParsers(); } } Triple llvm::dwarf::utils::getNormalizedDefaultTargetTriple() { Triple T(Triple::normalize(sys::getDefaultTargetTriple())); return T; } Triple llvm::dwarf::utils::getDefaultTargetTripleForAddrSize(uint8_t AddrSize) { Triple T = getNormalizedDefaultTargetTriple(); assert((AddrSize == 4 || AddrSize == 8) && "Only 32-bit/64-bit address size variants are supported"); // If a 32-bit/64-bit address size was specified, try to convert the triple // if it is for the wrong variant. if (AddrSize == 8 && T.isArch32Bit()) return T.get64BitArchVariant(); if (AddrSize == 4 && T.isArch64Bit()) return T.get32BitArchVariant(); return T; } bool llvm::dwarf::utils::isConfigurationSupported(Triple &T) { initLLVMIfNeeded(); std::string Err; return TargetRegistry::lookupTarget(T.getTriple(), Err); } |