mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
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:
parent
b93a23a532
commit
43f44aa160
@ -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;
|
||||||
}
|
}
|
||||||
|
16
test/CodeGen/X86/x86-64-jumps.ll
Normal file
16
test/CodeGen/X86/x86-64-jumps.ll
Normal 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
|
||||||
|
}
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user