mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
Merging r213895:
------------------------------------------------------------------------ r213895 | mren | 2014-07-24 14:13:20 -0700 (Thu, 24 Jul 2014) | 2 lines Feedback from Hans on r213815. No functionaility change. ------------------------------------------------------------------------ git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_35@214254 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
39b7fcb4bb
commit
2a9896e434
@ -3477,7 +3477,7 @@ namespace {
|
|||||||
|
|
||||||
/// BuildLookup - Build instructions with Builder to retrieve the value at
|
/// BuildLookup - Build instructions with Builder to retrieve the value at
|
||||||
/// the position given by Index in the lookup table.
|
/// the position given by Index in the lookup table.
|
||||||
Value *BuildLookup(Value *Index, uint64_t TableSize, IRBuilder<> &Builder);
|
Value *BuildLookup(Value *Index, IRBuilder<> &Builder);
|
||||||
|
|
||||||
/// WouldFitInRegister - Return true if a table with TableSize elements of
|
/// WouldFitInRegister - Return true if a table with TableSize elements of
|
||||||
/// type ElementType would fit in a target-legal register.
|
/// type ElementType would fit in a target-legal register.
|
||||||
@ -3598,8 +3598,7 @@ SwitchLookupTable::SwitchLookupTable(Module &M,
|
|||||||
Kind = ArrayKind;
|
Kind = ArrayKind;
|
||||||
}
|
}
|
||||||
|
|
||||||
Value *SwitchLookupTable::BuildLookup(Value *Index, uint64_t TableSize,
|
Value *SwitchLookupTable::BuildLookup(Value *Index, IRBuilder<> &Builder) {
|
||||||
IRBuilder<> &Builder) {
|
|
||||||
switch (Kind) {
|
switch (Kind) {
|
||||||
case SingleValueKind:
|
case SingleValueKind:
|
||||||
return SingleValue;
|
return SingleValue;
|
||||||
@ -3626,8 +3625,10 @@ Value *SwitchLookupTable::BuildLookup(Value *Index, uint64_t TableSize,
|
|||||||
}
|
}
|
||||||
case ArrayKind: {
|
case ArrayKind: {
|
||||||
// Make sure the table index will not overflow when treated as signed.
|
// Make sure the table index will not overflow when treated as signed.
|
||||||
if (IntegerType *IT = dyn_cast<IntegerType>(Index->getType()))
|
IntegerType *IT = cast<IntegerType>(Index->getType());
|
||||||
if (TableSize > (1 << (IT->getBitWidth() - 1)))
|
uint64_t TableSize = Array->getInitializer()->getType()
|
||||||
|
->getArrayNumElements();
|
||||||
|
if (TableSize > (1ULL << (IT->getBitWidth() - 1)))
|
||||||
Index = Builder.CreateZExt(Index,
|
Index = Builder.CreateZExt(Index,
|
||||||
IntegerType::get(IT->getContext(),
|
IntegerType::get(IT->getContext(),
|
||||||
IT->getBitWidth() + 1),
|
IT->getBitWidth() + 1),
|
||||||
@ -3887,7 +3888,7 @@ static bool SwitchToLookupTable(SwitchInst *SI,
|
|||||||
SwitchLookupTable Table(Mod, TableSize, MinCaseVal, ResultLists[PHI],
|
SwitchLookupTable Table(Mod, TableSize, MinCaseVal, ResultLists[PHI],
|
||||||
DV, DL);
|
DV, DL);
|
||||||
|
|
||||||
Value *Result = Table.BuildLookup(TableIndex, TableSize, Builder);
|
Value *Result = Table.BuildLookup(TableIndex, Builder);
|
||||||
|
|
||||||
// If the result is used to return immediately from the function, we want to
|
// If the result is used to return immediately from the function, we want to
|
||||||
// do that right here.
|
// do that right here.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user