diff options
| author | Juergen Ributzka <juergen@apple.com> | 2014-09-19 22:23:46 +0000 | 
|---|---|---|
| committer | Juergen Ributzka <juergen@apple.com> | 2014-09-19 22:23:46 +0000 | 
| commit | 92e8978e4031cda35d282013919a81bdc3b2d79d (patch) | |
| tree | 405b869cdd1fcfe69badd528401e663e0b2db23a /llvm/lib | |
| parent | 684981e4548733c9c28633c93a4cb418ea66e06a (diff) | |
| download | bcm5719-llvm-92e8978e4031cda35d282013919a81bdc3b2d79d.tar.gz bcm5719-llvm-92e8978e4031cda35d282013919a81bdc3b2d79d.zip | |
[FastIsel][AArch64] Fix a think-o in address computation.
When looking through sign/zero-extensions the code would always assume there is
such an extension instruction and use the wrong operand for the address.
There was also a minor issue in the handling of 'AND' instructions. I
accidentially used a 'cast' instead of a 'dyn_cast'.
llvm-svn: 218161
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/AArch64/AArch64FastISel.cpp | 47 | 
1 files changed, 27 insertions, 20 deletions
| diff --git a/llvm/lib/Target/AArch64/AArch64FastISel.cpp b/llvm/lib/Target/AArch64/AArch64FastISel.cpp index 1ba5ba5de70..f09f6003289 100644 --- a/llvm/lib/Target/AArch64/AArch64FastISel.cpp +++ b/llvm/lib/Target/AArch64/AArch64FastISel.cpp @@ -561,7 +561,7 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)      break;    } -  case Instruction::Shl: +  case Instruction::Shl: {      if (Addr.getOffsetReg())        break; @@ -584,19 +584,24 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)        Addr.setShift(Val);        Addr.setExtendType(AArch64_AM::LSL); -      if (const auto *I = dyn_cast<Instruction>(U->getOperand(0))) +      const Value *Src = U->getOperand(0); +      if (const auto *I = dyn_cast<Instruction>(Src))          if (FuncInfo.MBBMap[I->getParent()] == FuncInfo.MBB) -          U = I; +          Src = I; -      if (const auto *ZE = dyn_cast<ZExtInst>(U)) -        if (ZE->getOperand(0)->getType()->isIntegerTy(32)) +      if (const auto *ZE = dyn_cast<ZExtInst>(Src)) { +        if (ZE->getOperand(0)->getType()->isIntegerTy(32)) {            Addr.setExtendType(AArch64_AM::UXTW); - -      if (const auto *SE = dyn_cast<SExtInst>(U)) -        if (SE->getOperand(0)->getType()->isIntegerTy(32)) +          Src = ZE->getOperand(0); +        } +      } else if (const auto *SE = dyn_cast<SExtInst>(Src)) { +        if (SE->getOperand(0)->getType()->isIntegerTy(32)) {            Addr.setExtendType(AArch64_AM::SXTW); +          Src = SE->getOperand(0); +        } +      } -      if (const auto *AI = dyn_cast<BinaryOperator>(U)) +      if (const auto *AI = dyn_cast<BinaryOperator>(Src))          if (AI->getOpcode() == Instruction::And) {            const Value *LHS = AI->getOperand(0);            const Value *RHS = AI->getOperand(1); @@ -605,7 +610,7 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)              if (C->getValue() == 0xffffffff)                std::swap(LHS, RHS); -          if (const auto *C = cast<ConstantInt>(RHS)) +          if (const auto *C = dyn_cast<ConstantInt>(RHS))              if (C->getValue() == 0xffffffff) {                Addr.setExtendType(AArch64_AM::UXTW);                unsigned Reg = getRegForValue(LHS); @@ -619,13 +624,14 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)              }          } -      unsigned Reg = getRegForValue(U->getOperand(0)); +      unsigned Reg = getRegForValue(Src);        if (!Reg)          return false;        Addr.setOffsetReg(Reg);        return true;      }      break; +  }    case Instruction::Mul: {      if (Addr.getOffsetReg())        break; @@ -661,23 +667,24 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)      Addr.setShift(Val);      Addr.setExtendType(AArch64_AM::LSL); -    if (const auto *I = dyn_cast<Instruction>(LHS)) +    const Value *Src = LHS; +    if (const auto *I = dyn_cast<Instruction>(Src))        if (FuncInfo.MBBMap[I->getParent()] == FuncInfo.MBB) -        U = I; +        Src = I; -    if (const auto *ZE = dyn_cast<ZExtInst>(U)) +    if (const auto *ZE = dyn_cast<ZExtInst>(Src)) {        if (ZE->getOperand(0)->getType()->isIntegerTy(32)) {          Addr.setExtendType(AArch64_AM::UXTW); -        LHS = U->getOperand(0); +        Src = ZE->getOperand(0);        } - -    if (const auto *SE = dyn_cast<SExtInst>(U)) +    } else if (const auto *SE = dyn_cast<SExtInst>(Src)) {        if (SE->getOperand(0)->getType()->isIntegerTy(32)) {          Addr.setExtendType(AArch64_AM::SXTW); -        LHS = U->getOperand(0); +        Src = SE->getOperand(0);        } +    } -    unsigned Reg = getRegForValue(LHS); +    unsigned Reg = getRegForValue(Src);      if (!Reg)        return false;      Addr.setOffsetReg(Reg); @@ -697,7 +704,7 @@ bool AArch64FastISel::computeAddress(const Value *Obj, Address &Addr, Type *Ty)        if (C->getValue() == 0xffffffff)          std::swap(LHS, RHS); -    if (const auto *C = cast<ConstantInt>(RHS)) +    if (const auto *C = dyn_cast<ConstantInt>(RHS))        if (C->getValue() == 0xffffffff) {          Addr.setShift(0);          Addr.setExtendType(AArch64_AM::LSL); | 

