blob: c01043dddeadca9575e3bb0f11419fe6f67cc656 [file] [log] [blame]
Diana Picus22274932016-11-11 08:27:37 +00001//===- ARMInstructionSelector.cpp ----------------------------*- C++ -*-==//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9/// \file
10/// This file implements the targeting of the InstructionSelector class for ARM.
11/// \todo This should be generated by TableGen.
12//===----------------------------------------------------------------------===//
13
14#include "ARMInstructionSelector.h"
15#include "ARMRegisterBankInfo.h"
16#include "ARMSubtarget.h"
17#include "ARMTargetMachine.h"
Diana Picus812caee2016-12-16 12:54:46 +000018#include "llvm/CodeGen/MachineRegisterInfo.h"
Diana Picus22274932016-11-11 08:27:37 +000019#include "llvm/Support/Debug.h"
20
21#define DEBUG_TYPE "arm-isel"
22
23using namespace llvm;
24
25#ifndef LLVM_BUILD_GLOBAL_ISEL
26#error "You shouldn't build this"
27#endif
28
Diana Picus895c6aa2016-11-15 16:42:10 +000029ARMInstructionSelector::ARMInstructionSelector(const ARMSubtarget &STI,
Diana Picus22274932016-11-11 08:27:37 +000030 const ARMRegisterBankInfo &RBI)
Diana Picus895c6aa2016-11-15 16:42:10 +000031 : InstructionSelector(), TII(*STI.getInstrInfo()),
Diana Picus812caee2016-12-16 12:54:46 +000032 TRI(*STI.getRegisterInfo()), RBI(RBI) {}
Diana Picus22274932016-11-11 08:27:37 +000033
Diana Picus812caee2016-12-16 12:54:46 +000034static bool selectCopy(MachineInstr &I, const TargetInstrInfo &TII,
35 MachineRegisterInfo &MRI, const TargetRegisterInfo &TRI,
36 const RegisterBankInfo &RBI) {
37 unsigned DstReg = I.getOperand(0).getReg();
38 if (TargetRegisterInfo::isPhysicalRegister(DstReg))
39 return true;
40
41 const RegisterBank *RegBank = RBI.getRegBank(DstReg, MRI, TRI);
Benjamin Kramer24bf8682016-12-16 13:13:03 +000042 (void)RegBank;
Diana Picus812caee2016-12-16 12:54:46 +000043 assert(RegBank && "Can't get reg bank for virtual register");
44
Benjamin Kramer24bf8682016-12-16 13:13:03 +000045 assert(MRI.getType(DstReg).getSizeInBits() ==
46 RBI.getSizeInBits(I.getOperand(1).getReg(), MRI, TRI) &&
47 "Copy with different width?!");
Diana Picus812caee2016-12-16 12:54:46 +000048
49 assert(RegBank->getID() == ARM::GPRRegBankID && "Unsupported reg bank");
50 const TargetRegisterClass *RC = &ARM::GPRRegClass;
51
52 // No need to constrain SrcReg. It will get constrained when
53 // we hit another of its uses or its defs.
54 // Copies do not have constraints.
55 if (!RBI.constrainGenericRegister(DstReg, *RC, MRI)) {
56 DEBUG(dbgs() << "Failed to constrain " << TII.getName(I.getOpcode())
57 << " operand\n");
58 return false;
59 }
60 return true;
61}
62
63bool ARMInstructionSelector::select(MachineInstr &I) const {
64 assert(I.getParent() && "Instruction should be in a basic block!");
65 assert(I.getParent()->getParent() && "Instruction should be in a function!");
66
67 auto &MBB = *I.getParent();
68 auto &MF = *MBB.getParent();
69 auto &MRI = MF.getRegInfo();
70
71 if (!isPreISelGenericOpcode(I.getOpcode())) {
72 if (I.isCopy())
73 return selectCopy(I, TII, MRI, TRI, RBI);
74
75 return true;
76 }
77
Diana Picus519807f2016-12-19 11:26:31 +000078 MachineInstrBuilder MIB{MF, I};
79
80 using namespace TargetOpcode;
81 switch (I.getOpcode()) {
82 case G_ADD:
Diana Picus812caee2016-12-16 12:54:46 +000083 I.setDesc(TII.get(ARM::ADDrr));
Diana Picus519807f2016-12-19 11:26:31 +000084 AddDefaultCC(AddDefaultPred(MIB));
85 break;
86 case G_FRAME_INDEX:
87 // Add 0 to the given frame index and hope it will eventually be folded into
88 // the user(s).
89 I.setDesc(TII.get(ARM::ADDri));
90 AddDefaultCC(AddDefaultPred(MIB.addImm(0)));
91 break;
92 case G_LOAD:
93 I.setDesc(TII.get(ARM::LDRi12));
94 AddDefaultPred(MIB.addImm(0));
95 break;
96 default:
97 return false;
Diana Picus812caee2016-12-16 12:54:46 +000098 }
99
Diana Picus519807f2016-12-19 11:26:31 +0000100 return constrainSelectedInstRegOperands(I, TII, TRI, RBI);
Diana Picus22274932016-11-11 08:27:37 +0000101}