blob: 1614422a365cbca748a64c17bdb31f25b76ff5e1 [file] [log] [blame]
Evan Cheng88645942010-06-18 23:11:35 +00001//===-- Thumb2HazardRecognizer.cpp - Thumb2 postra hazard recognizer ------===//
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
10#include "ARM.h"
11#include "Thumb2HazardRecognizer.h"
12#include "llvm/CodeGen/MachineInstr.h"
13#include "llvm/CodeGen/ScheduleDAG.h"
14using namespace llvm;
15
16ScheduleHazardRecognizer::HazardType
17Thumb2HazardRecognizer::getHazardType(SUnit *SU) {
18 if (ITBlockSize) {
19 MachineInstr *MI = SU->getInstr();
20 if (MI != ITBlockMIs[ITBlockSize-1])
21 return Hazard;
22 }
23
24 return PostRAHazardRecognizer::getHazardType(SU);
25}
26
27void Thumb2HazardRecognizer::Reset() {
28 ITBlockSize = 0;
29 PostRAHazardRecognizer::Reset();
30}
31
32void Thumb2HazardRecognizer::EmitInstruction(SUnit *SU) {
33 MachineInstr *MI = SU->getInstr();
34 unsigned Opcode = MI->getOpcode();
35 if (ITBlockSize) {
36 --ITBlockSize;
37 } else if (Opcode == ARM::t2IT) {
38 unsigned Mask = MI->getOperand(1).getImm();
39 unsigned NumTZ = CountTrailingZeros_32(Mask);
40 assert(NumTZ <= 3 && "Invalid IT mask!");
41 ITBlockSize = 4 - NumTZ;
42 MachineBasicBlock::iterator I = MI;
43 for (unsigned i = 0; i < ITBlockSize; ++i) {
44 ++I;
45 ITBlockMIs[ITBlockSize-1-i] = &*I;
46 }
47 }
48
49 PostRAHazardRecognizer::EmitInstruction(SU);
50}