mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-04 01:51:31 +00:00
Support vector bitcasts in the AsmPrinter. PR11495.
llvm-svn: 146001
This commit is contained in:
parent
d610f464bf
commit
9e8d557cd1
@ -1642,6 +1642,28 @@ static void EmitGlobalConstantVector(const ConstantVector *CV,
|
||||
AP.OutStreamer.EmitZeros(Padding, AddrSpace);
|
||||
}
|
||||
|
||||
static void LowerVectorConstant(const Constant *CV, unsigned AddrSpace,
|
||||
AsmPrinter &AP) {
|
||||
// Look through bitcasts
|
||||
if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV))
|
||||
if (CE->getOpcode() == Instruction::BitCast)
|
||||
CV = CE->getOperand(0);
|
||||
|
||||
if (const ConstantVector *V = dyn_cast<ConstantVector>(CV))
|
||||
return EmitGlobalConstantVector(V, AddrSpace, AP);
|
||||
|
||||
// If we get here, we're stuck; report the problem to the user.
|
||||
// FIXME: Are there any other useful tricks for vectors?
|
||||
{
|
||||
std::string S;
|
||||
raw_string_ostream OS(S);
|
||||
OS << "Unsupported vector expression in static initializer: ";
|
||||
WriteAsOperand(OS, CV, /*PrintType=*/false,
|
||||
!AP.MF ? 0 : AP.MF->getFunction()->getParent());
|
||||
report_fatal_error(OS.str());
|
||||
}
|
||||
}
|
||||
|
||||
static void EmitGlobalConstantStruct(const ConstantStruct *CS,
|
||||
unsigned AddrSpace, AsmPrinter &AP) {
|
||||
// Print the fields in successive locations. Pad to align if needed!
|
||||
@ -1796,8 +1818,8 @@ static void EmitGlobalConstantImpl(const Constant *CV, unsigned AddrSpace,
|
||||
return;
|
||||
}
|
||||
|
||||
if (const ConstantVector *V = dyn_cast<ConstantVector>(CV))
|
||||
return EmitGlobalConstantVector(V, AddrSpace, AP);
|
||||
if (CV->getType()->isVectorTy())
|
||||
return LowerVectorConstant(CV, AddrSpace, AP);
|
||||
|
||||
// Otherwise, it must be a ConstantExpr. Lower it to an MCExpr, then emit it
|
||||
// thread the streamer with EmitValue.
|
||||
|
5
test/CodeGen/X86/2011-12-06-BitcastVectorGlobal.ll
Normal file
5
test/CodeGen/X86/2011-12-06-BitcastVectorGlobal.ll
Normal file
@ -0,0 +1,5 @@
|
||||
; RUN: llc < %s -march=x86-64 | FileCheck %s
|
||||
; PR11495
|
||||
|
||||
; CHECK: 1311768467463790320
|
||||
@v = global <2 x float> bitcast (<1 x i64> <i64 1311768467463790320> to <2 x float>), align 8
|
Loading…
Reference in New Issue
Block a user