From c074b096d5d338659cf24a029c77c4b3e4c1ddb0 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Mon, 28 Apr 2014 12:40:50 +0000 Subject: Produce an error instead of a crash in an expr we cannot represent. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@207414 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/MC/ELFObjectWriter.cpp | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'lib/MC/ELFObjectWriter.cpp') diff --git a/lib/MC/ELFObjectWriter.cpp b/lib/MC/ELFObjectWriter.cpp index e8b34d56f5..12b5f595ca 100644 --- a/lib/MC/ELFObjectWriter.cpp +++ b/lib/MC/ELFObjectWriter.cpp @@ -606,7 +606,12 @@ static const MCSymbol *getBaseSymbol(const MCAsmLayout &Layout, MCValue Value; if (!Expr->EvaluateAsRelocatable(Value, &Layout)) llvm_unreachable("Invalid Expression"); - assert(!Value.getSymB()); + const MCSymbolRefExpr *RefB = Value.getSymB(); + if (RefB) { + Layout.getAssembler().getContext().FatalError( + SMLoc(), Twine("symbol '") + RefB->getSymbol().getName() + + "' could not be evaluated in a subtraction expression"); + } const MCSymbolRefExpr *A = Value.getSymA(); if (!A) return nullptr; -- cgit v1.2.3