forked from OSchip/llvm-project
[llvm-mc] Add reportWarning() to MCContext
Adding reportWarning() to MCContext, so that it can be used from the Hexagon assembler backend. llvm-svn: 368327
This commit is contained in:
parent
a3c3530958
commit
6dbbd0f343
|
@ -374,7 +374,8 @@ static bool ExecuteAssembler(AssemblerInvocation &Opts,
|
|||
// MCObjectFileInfo needs a MCContext reference in order to initialize itself.
|
||||
std::unique_ptr<MCObjectFileInfo> MOFI(new MCObjectFileInfo());
|
||||
|
||||
MCContext Ctx(MAI.get(), MRI.get(), MOFI.get(), &SrcMgr);
|
||||
MCTargetOptions MCOptions;
|
||||
MCContext Ctx(MAI.get(), MRI.get(), MOFI.get(), &SrcMgr, &MCOptions);
|
||||
|
||||
bool PIC = false;
|
||||
if (Opts.RelocationModel == "static") {
|
||||
|
@ -431,7 +432,6 @@ static bool ExecuteAssembler(AssemblerInvocation &Opts,
|
|||
raw_pwrite_stream *Out = FDOS.get();
|
||||
std::unique_ptr<buffer_ostream> BOS;
|
||||
|
||||
MCTargetOptions MCOptions;
|
||||
MCOptions.ABIName = Opts.TargetABI;
|
||||
|
||||
// FIXME: There is a bit of code duplication with addPassesToEmitFile.
|
||||
|
|
|
@ -22,6 +22,7 @@
|
|||
#include "llvm/MC/MCAsmMacro.h"
|
||||
#include "llvm/MC/MCDwarf.h"
|
||||
#include "llvm/MC/MCSubtargetInfo.h"
|
||||
#include "llvm/MC/MCTargetOptions.h"
|
||||
#include "llvm/MC/SectionKind.h"
|
||||
#include "llvm/Support/Allocator.h"
|
||||
#include "llvm/Support/Compiler.h"
|
||||
|
@ -275,6 +276,8 @@ namespace llvm {
|
|||
/// Do automatic reset in destructor
|
||||
bool AutoReset;
|
||||
|
||||
MCTargetOptions const *TargetOptions;
|
||||
|
||||
bool HadError = false;
|
||||
|
||||
MCSymbol *createSymbolImpl(const StringMapEntry<bool> *Name,
|
||||
|
@ -298,7 +301,9 @@ namespace llvm {
|
|||
public:
|
||||
explicit MCContext(const MCAsmInfo *MAI, const MCRegisterInfo *MRI,
|
||||
const MCObjectFileInfo *MOFI,
|
||||
const SourceMgr *Mgr = nullptr, bool DoAutoReset = true);
|
||||
const SourceMgr *Mgr = nullptr,
|
||||
MCTargetOptions const *TargetOpts = nullptr,
|
||||
bool DoAutoReset = true);
|
||||
MCContext(const MCContext &) = delete;
|
||||
MCContext &operator=(const MCContext &) = delete;
|
||||
~MCContext();
|
||||
|
@ -659,6 +664,7 @@ namespace llvm {
|
|||
|
||||
bool hadError() { return HadError; }
|
||||
void reportError(SMLoc L, const Twine &Msg);
|
||||
void reportWarning(SMLoc L, const Twine &Msg);
|
||||
// Unrecoverable error has occurred. Display the best diagnostic we can
|
||||
// and bail via exit(1). For now, most MC backend errors are unrecoverable.
|
||||
// FIXME: We should really do something about that.
|
||||
|
|
|
@ -194,9 +194,9 @@ void MMIAddrLabelMapCallbackPtr::allUsesReplacedWith(Value *V2) {
|
|||
}
|
||||
|
||||
MachineModuleInfo::MachineModuleInfo(const LLVMTargetMachine *TM)
|
||||
: ImmutablePass(ID), TM(*TM),
|
||||
Context(TM->getMCAsmInfo(), TM->getMCRegisterInfo(),
|
||||
TM->getObjFileLowering(), nullptr, false) {
|
||||
: ImmutablePass(ID), TM(*TM),
|
||||
Context(TM->getMCAsmInfo(), TM->getMCRegisterInfo(),
|
||||
TM->getObjFileLowering(), nullptr, nullptr, false) {
|
||||
initializeMachineModuleInfoPass(*PassRegistry::getPassRegistry());
|
||||
}
|
||||
|
||||
|
|
|
@ -58,11 +58,11 @@ AsSecureLogFileName("as-secure-log-file-name",
|
|||
|
||||
MCContext::MCContext(const MCAsmInfo *mai, const MCRegisterInfo *mri,
|
||||
const MCObjectFileInfo *mofi, const SourceMgr *mgr,
|
||||
bool DoAutoReset)
|
||||
MCTargetOptions const *TargetOpts, bool DoAutoReset)
|
||||
: SrcMgr(mgr), InlineSrcMgr(nullptr), MAI(mai), MRI(mri), MOFI(mofi),
|
||||
Symbols(Allocator), UsedNames(Allocator),
|
||||
CurrentDwarfLoc(0, 0, 0, DWARF2_FLAG_IS_STMT, 0, 0),
|
||||
AutoReset(DoAutoReset) {
|
||||
AutoReset(DoAutoReset), TargetOptions(TargetOpts) {
|
||||
SecureLogFile = AsSecureLogFileName;
|
||||
|
||||
if (SrcMgr && SrcMgr->getNumBuffers())
|
||||
|
@ -691,6 +691,21 @@ void MCContext::reportError(SMLoc Loc, const Twine &Msg) {
|
|||
report_fatal_error(Msg, false);
|
||||
}
|
||||
|
||||
void MCContext::reportWarning(SMLoc Loc, const Twine &Msg) {
|
||||
if (TargetOptions && TargetOptions->MCNoWarn)
|
||||
return;
|
||||
if (TargetOptions && TargetOptions->MCFatalWarnings)
|
||||
reportError(Loc, Msg);
|
||||
else {
|
||||
// If we have a source manager use it. Otherwise, try using the inline
|
||||
// source manager.
|
||||
if (SrcMgr)
|
||||
SrcMgr->PrintMessage(Loc, SourceMgr::DK_Warning, Msg);
|
||||
else if (InlineSrcMgr)
|
||||
InlineSrcMgr->PrintMessage(Loc, SourceMgr::DK_Warning, Msg);
|
||||
}
|
||||
}
|
||||
|
||||
void MCContext::reportFatalError(SMLoc Loc, const Twine &Msg) {
|
||||
reportError(Loc, Msg);
|
||||
|
||||
|
|
|
@ -726,9 +726,6 @@ void HexagonMCChecker::reportNote(SMLoc Loc, llvm::Twine const &Msg) {
|
|||
}
|
||||
|
||||
void HexagonMCChecker::reportWarning(Twine const &Msg) {
|
||||
if (ReportErrors) {
|
||||
auto SM = Context.getSourceManager();
|
||||
if (SM)
|
||||
SM->PrintMessage(MCB.getLoc(), SourceMgr::DK_Warning, Msg);
|
||||
}
|
||||
if (ReportErrors)
|
||||
Context.reportWarning(MCB.getLoc(), Msg);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
# RUN: llvm-mc -arch=hexagon -mhvx --filetype=asm %s -o - 2>&1 | FileCheck %s
|
||||
# RUN: llvm-mc --no-warn -arch=hexagon -mhvx --filetype=obj %s -o - | llvm-objdump -d - | FileCheck --check-prefix=CHECK-NOWARN %s
|
||||
# RUN: not llvm-mc --fatal-warnings -arch=hexagon -mhvx --filetype=asm %s 2>&1 | FileCheck --check-prefix=CHECK-FATAL-WARN %s
|
||||
|
||||
.text
|
||||
.warning
|
||||
|
||||
{
|
||||
v7.tmp = vmem(r28 + #3)
|
||||
v7:6.w = vadd(v17:16.w, v17:16.w)
|
||||
v17:16.uw = vunpack(v8.uh)
|
||||
}
|
||||
|
||||
# CHECK-NOWARN-NOT: warning
|
||||
# CHECK-FATAL-WARN-NOT: warning
|
||||
# CHECK-FATAL-WARN: error
|
||||
# CHECK-FATAL-WARN: error
|
||||
# CHECK: warning:
|
||||
# CHECK: warning:
|
|
@ -279,7 +279,7 @@ static int fillCommandLineSymbols(MCAsmParser &Parser) {
|
|||
static int AssembleInput(const char *ProgName, const Target *TheTarget,
|
||||
SourceMgr &SrcMgr, MCContext &Ctx, MCStreamer &Str,
|
||||
MCAsmInfo &MAI, MCSubtargetInfo &STI,
|
||||
MCInstrInfo &MCII, MCTargetOptions &MCOptions) {
|
||||
MCInstrInfo &MCII, MCTargetOptions const &MCOptions) {
|
||||
std::unique_ptr<MCAsmParser> Parser(
|
||||
createMCAsmParser(SrcMgr, Ctx, Str, MAI));
|
||||
std::unique_ptr<MCTargetAsmParser> TAP(
|
||||
|
@ -316,7 +316,7 @@ int main(int argc, char **argv) {
|
|||
cl::AddExtraVersionPrinter(TargetRegistry::printRegisteredTargetsForVersion);
|
||||
|
||||
cl::ParseCommandLineOptions(argc, argv, "llvm machine code playground\n");
|
||||
MCTargetOptions MCOptions = InitMCTargetOptionsFromFlags();
|
||||
const MCTargetOptions MCOptions = InitMCTargetOptionsFromFlags();
|
||||
setDwarfDebugFlags(argc, argv);
|
||||
|
||||
setDwarfDebugProducer();
|
||||
|
@ -368,7 +368,7 @@ int main(int argc, char **argv) {
|
|||
// FIXME: This is not pretty. MCContext has a ptr to MCObjectFileInfo and
|
||||
// MCObjectFileInfo needs a MCContext reference in order to initialize itself.
|
||||
MCObjectFileInfo MOFI;
|
||||
MCContext Ctx(MAI.get(), MRI.get(), &MOFI, &SrcMgr);
|
||||
MCContext Ctx(MAI.get(), MRI.get(), &MOFI, &SrcMgr, &MCOptions);
|
||||
MOFI.InitMCObjectFileInfo(TheTriple, PIC, Ctx, LargeCodeModel);
|
||||
|
||||
if (SaveTempLabels)
|
||||
|
|
Loading…
Reference in New Issue