llvm-project/llvm/lib/TargetParser/AVRTargetParser.cpp
Ruoyu Qiu d005cb2953
[llvm-objdump][AVR] Detect AVR architecture from ELF flags for disassembling (#174731)
This PR updates llvm-objdump to detect the specific AVR architecture
from the ELF header flags when no specific CPU is provided.

Fixes: #146451

---------

Signed-off-by: RuoyuQiu <cabbaken@outlook.com>
Signed-off-by: Ruoyu Qiu <cabbaken@outlook.com>
Co-authored-by: qiuruoyu <qiuruoyu@hygon.cn>
2026-02-06 08:58:12 +08:00

51 lines
1.9 KiB
C++

//===-- AVRTargetParser - Parser for AVR target features ------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
///
/// \file
/// This file implements a target parser to recognise AVR hardware features.
///
//===----------------------------------------------------------------------===//
#include "llvm/TargetParser/AVRTargetParser.h"
#include "llvm/BinaryFormat/ELF.h"
#include "llvm/Support/Errc.h"
using namespace llvm;
Expected<std::string>
AVR::getFeatureSetFromEFlag(const object::ELFObjectFileBase *Elf) {
static const DenseMap<unsigned, StringRef> EFlagToFeatureSet = {
{ELF::EF_AVR_ARCH_AVR1, "avr1"},
{ELF::EF_AVR_ARCH_AVR2, "avr2"},
{ELF::EF_AVR_ARCH_AVR25, "avr25"},
{ELF::EF_AVR_ARCH_AVR3, "avr3"},
{ELF::EF_AVR_ARCH_AVR31, "avr31"},
{ELF::EF_AVR_ARCH_AVR35, "avr35"},
{ELF::EF_AVR_ARCH_AVR4, "avr4"},
{ELF::EF_AVR_ARCH_AVR5, "avr5"},
{ELF::EF_AVR_ARCH_AVR51, "avr51"},
{ELF::EF_AVR_ARCH_AVR6, "avr6"},
{ELF::EF_AVR_ARCH_AVRTINY, "avrtiny"},
{ELF::EF_AVR_ARCH_XMEGA1, "xmega1"},
{ELF::EF_AVR_ARCH_XMEGA2, "xmega2"},
{ELF::EF_AVR_ARCH_XMEGA3, "xmega3"},
{ELF::EF_AVR_ARCH_XMEGA4, "xmega4"},
{ELF::EF_AVR_ARCH_XMEGA5, "xmega"},
{ELF::EF_AVR_ARCH_XMEGA6, "xmega"},
{ELF::EF_AVR_ARCH_XMEGA7, "xmega"},
};
unsigned EFlag = Elf->getPlatformFlags() & ELF::EF_AVR_ARCH_MASK;
auto It = EFlagToFeatureSet.find(EFlag);
if (It != EFlagToFeatureSet.end())
return It->second.str();
return createStringError(errc::invalid_argument,
"unrecognised AVR version, 0x" +
Twine::utohexstr(EFlag));
}