diff options
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/AArch64/AArch64InstructionSelector.cpp | 10 | 
1 files changed, 10 insertions, 0 deletions
| diff --git a/llvm/lib/Target/AArch64/AArch64InstructionSelector.cpp b/llvm/lib/Target/AArch64/AArch64InstructionSelector.cpp index efb2dbc64a9..addf60a102d 100644 --- a/llvm/lib/Target/AArch64/AArch64InstructionSelector.cpp +++ b/llvm/lib/Target/AArch64/AArch64InstructionSelector.cpp @@ -229,6 +229,16 @@ bool AArch64InstructionSelector::select(MachineInstr &I) const {      return true;    } +  case TargetOpcode::G_CONSTANT: { +    if (Ty.getSizeInBits() <= 32) +      I.setDesc(TII.get(AArch64::MOVi32imm)); +    else if (Ty.getSizeInBits() <= 64) +      I.setDesc(TII.get(AArch64::MOVi64imm)); +    else +      return false; +    return constrainSelectedInstRegOperands(I, TII, TRI, RBI); +  } +    case TargetOpcode::G_FRAME_INDEX: {      // allocas and G_FRAME_INDEX are only supported in addrspace(0).      if (Ty != LLT::pointer(0, 64)) { | 

