improve x86 codegen support for blockaddress. We now compile

the testcase into:

_test1:                                                     ## @test1
## BB#0:                                                    ## %entry
	leaq	L_test1_bb6(%rip), %rax
	jmpq	*%rax
L_test1_bb:                                                 ## Address Taken
LBB1_1:                                                     ## %bb
	movb	$1, %al
	ret
L_test1_bb6:                                                ## Address Taken
LBB1_2:                                                     ## %bb6
	movb	$2, %al
	ret

Note, it is very very strange that BlockAddressSDNode doesn't carry 
around TargetFlags.  Dan, please fix this.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85703 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2009-11-01 03:25:03 +00:00
parent b93a23a532
commit 43f44aa160
2 changed files with 30 additions and 6 deletions

View File

@ -71,6 +71,7 @@ namespace {
SDValue Segment; SDValue Segment;
GlobalValue *GV; GlobalValue *GV;
Constant *CP; Constant *CP;
BlockAddress *BlockAddr;
const char *ES; const char *ES;
int JT; int JT;
unsigned Align; // CP alignment. unsigned Align; // CP alignment.
@ -78,12 +79,12 @@ namespace {
X86ISelAddressMode() X86ISelAddressMode()
: BaseType(RegBase), Scale(1), IndexReg(), Disp(0), : BaseType(RegBase), Scale(1), IndexReg(), Disp(0),
Segment(), GV(0), CP(0), ES(0), JT(-1), Align(0), Segment(), GV(0), CP(0), BlockAddr(0), ES(0), JT(-1), Align(0),
SymbolFlags(X86II::MO_NO_FLAG) { SymbolFlags(X86II::MO_NO_FLAG) {
} }
bool hasSymbolicDisplacement() const { bool hasSymbolicDisplacement() const {
return GV != 0 || CP != 0 || ES != 0 || JT != -1; return GV != 0 || CP != 0 || ES != 0 || JT != -1 || BlockAddr != 0;
} }
bool hasBaseOrIndexReg() const { bool hasBaseOrIndexReg() const {
@ -241,6 +242,9 @@ namespace {
Disp = CurDAG->getTargetExternalSymbol(AM.ES, MVT::i32, AM.SymbolFlags); Disp = CurDAG->getTargetExternalSymbol(AM.ES, MVT::i32, AM.SymbolFlags);
else if (AM.JT != -1) else if (AM.JT != -1)
Disp = CurDAG->getTargetJumpTable(AM.JT, MVT::i32, AM.SymbolFlags); Disp = CurDAG->getTargetJumpTable(AM.JT, MVT::i32, AM.SymbolFlags);
else if (AM.BlockAddr)
Disp = CurDAG->getBlockAddress(AM.BlockAddr, DebugLoc()/*MVT::i32*/,
true /*AM.SymbolFlags*/);
else else
Disp = CurDAG->getTargetConstant(AM.Disp, MVT::i32); Disp = CurDAG->getTargetConstant(AM.Disp, MVT::i32);
@ -760,10 +764,12 @@ bool X86DAGToDAGISel::MatchWrapper(SDValue N, X86ISelAddressMode &AM) {
} else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(N0)) { } else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(N0)) {
AM.ES = S->getSymbol(); AM.ES = S->getSymbol();
AM.SymbolFlags = S->getTargetFlags(); AM.SymbolFlags = S->getTargetFlags();
} else { } else if (JumpTableSDNode *J = dyn_cast<JumpTableSDNode>(N0)) {
JumpTableSDNode *J = cast<JumpTableSDNode>(N0);
AM.JT = J->getIndex(); AM.JT = J->getIndex();
AM.SymbolFlags = J->getTargetFlags(); AM.SymbolFlags = J->getTargetFlags();
} else {
AM.BlockAddr = cast<BlockAddressSDNode>(N0)->getBlockAddress();
//AM.SymbolFlags = cast<BlockAddressSDNode>(N0)->getTargetFlags();
} }
if (N.getOpcode() == X86ISD::WrapperRIP) if (N.getOpcode() == X86ISD::WrapperRIP)
@ -789,10 +795,12 @@ bool X86DAGToDAGISel::MatchWrapper(SDValue N, X86ISelAddressMode &AM) {
} else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(N0)) { } else if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(N0)) {
AM.ES = S->getSymbol(); AM.ES = S->getSymbol();
AM.SymbolFlags = S->getTargetFlags(); AM.SymbolFlags = S->getTargetFlags();
} else { } else if (JumpTableSDNode *J = dyn_cast<JumpTableSDNode>(N0)) {
JumpTableSDNode *J = cast<JumpTableSDNode>(N0);
AM.JT = J->getIndex(); AM.JT = J->getIndex();
AM.SymbolFlags = J->getTargetFlags(); AM.SymbolFlags = J->getTargetFlags();
} else {
AM.BlockAddr = cast<BlockAddressSDNode>(N0)->getBlockAddress();
//AM.SymbolFlags = cast<BlockAddressSDNode>(N0)->getTargetFlags();
} }
return false; return false;
} }

View File

@ -0,0 +1,16 @@
; RUN: llc < %s
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
target triple = "x86_64-apple-darwin10.0"
define i8 @test1() nounwind ssp {
entry:
%0 = select i1 undef, i8* blockaddress(@test1, %bb), i8* blockaddress(@test1, %bb6) ; <i8*> [#uses=1]
indirectbr i8* %0, [label %bb, label %bb6]
bb: ; preds = %entry
ret i8 1
bb6: ; preds = %entry
ret i8 2
}