| Brian Gaeke | b3deed9 | 2004-04-06 23:21:45 +0000 | [diff] [blame] | 1 | //===-- DelaySlotFiller.cpp - SparcV8 delay slot filler -------------------===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
|  | 5 | // This file was developed by the LLVM research group and is distributed under | 
|  | 6 | // the University of Illinois Open Source License. See LICENSE.TXT for details. | 
|  | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // Simple local delay slot filler for SparcV8 machine code | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 |  | 
|  | 14 | #include "SparcV8.h" | 
| Brian Gaeke | b3deed9 | 2004-04-06 23:21:45 +0000 | [diff] [blame] | 15 | #include "llvm/CodeGen/MachineFunctionPass.h" | 
| Brian Gaeke | b3deed9 | 2004-04-06 23:21:45 +0000 | [diff] [blame] | 16 | #include "llvm/CodeGen/MachineInstrBuilder.h" | 
| Brian Gaeke | b3deed9 | 2004-04-06 23:21:45 +0000 | [diff] [blame] | 17 | #include "Support/Statistic.h" | 
| Brian Gaeke | 589bf05 | 2004-04-06 23:25:07 +0000 | [diff] [blame^] | 18 |  | 
| Brian Gaeke | b3deed9 | 2004-04-06 23:21:45 +0000 | [diff] [blame] | 19 | using namespace llvm; | 
|  | 20 |  | 
|  | 21 | namespace { | 
|  | 22 | Statistic<> FilledSlots ("delayslotfiller", "Num. of delay slots filled"); | 
|  | 23 |  | 
|  | 24 | struct Filler : public MachineFunctionPass { | 
|  | 25 | /// Target machine description which we query for reg. names, data | 
|  | 26 | /// layout, etc. | 
|  | 27 | /// | 
|  | 28 | TargetMachine &TM; | 
|  | 29 |  | 
|  | 30 | Filler (TargetMachine &tm) : TM (tm) { } | 
|  | 31 |  | 
|  | 32 | virtual const char *getPassName () const { | 
|  | 33 | return "SparcV8 Delay Slot Filler"; | 
|  | 34 | } | 
|  | 35 |  | 
|  | 36 | bool runOnMachineBasicBlock (MachineBasicBlock &MBB); | 
|  | 37 | bool runOnMachineFunction (MachineFunction &F) { | 
|  | 38 | bool Changed = false; | 
|  | 39 | for (MachineFunction::iterator FI = F.begin (), FE = F.end (); | 
|  | 40 | FI != FE; ++FI) | 
|  | 41 | Changed |= runOnMachineBasicBlock (*FI); | 
|  | 42 | return Changed; | 
|  | 43 | } | 
|  | 44 |  | 
|  | 45 | }; | 
|  | 46 | } // end of anonymous namespace | 
|  | 47 |  | 
|  | 48 | /// createSparcV8DelaySlotFillerPass - Returns a pass that fills in delay | 
|  | 49 | /// slots in SparcV8 MachineFunctions | 
|  | 50 | /// | 
|  | 51 | FunctionPass *llvm::createSparcV8DelaySlotFillerPass (TargetMachine &tm) { | 
|  | 52 | return new Filler (tm); | 
|  | 53 | } | 
|  | 54 |  | 
|  | 55 | static bool hasDelaySlot (unsigned Opcode) { | 
|  | 56 | switch (Opcode) { | 
|  | 57 | case V8::CALL: | 
|  | 58 | case V8::RETL: | 
|  | 59 | return true; | 
|  | 60 | default: | 
|  | 61 | return false; | 
|  | 62 | } | 
|  | 63 | } | 
|  | 64 |  | 
|  | 65 | /// runOnMachineBasicBlock - Fill in delay slots for the given basic block. | 
|  | 66 | /// | 
|  | 67 | bool Filler::runOnMachineBasicBlock (MachineBasicBlock &MBB) { | 
|  | 68 | for (MachineBasicBlock::iterator I = MBB.begin (); I != MBB.end (); ++I) | 
|  | 69 | if (hasDelaySlot (I->getOpcode ())) { | 
|  | 70 | MachineBasicBlock::iterator J = I; | 
|  | 71 | ++J; | 
|  | 72 | MBB.insert (J, BuildMI (V8::NOP, 0)); | 
|  | 73 | ++FilledSlots; | 
|  | 74 | } | 
|  | 75 | return false; | 
|  | 76 | } |