LLVM API Documentation

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
ARMSelectionDAGInfo.h
Go to the documentation of this file.
1 //===-- ARMSelectionDAGInfo.h - ARM SelectionDAG Info -----------*- 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 //
10 // This file defines the ARM subclass for TargetSelectionDAGInfo.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef ARMSELECTIONDAGINFO_H
15 #define ARMSELECTIONDAGINFO_H
16 
19 
20 namespace llvm {
21 
22 namespace ARM_AM {
23  static inline ShiftOpc getShiftOpcForNode(unsigned Opcode) {
24  switch (Opcode) {
25  default: return ARM_AM::no_shift;
26  case ISD::SHL: return ARM_AM::lsl;
27  case ISD::SRL: return ARM_AM::lsr;
28  case ISD::SRA: return ARM_AM::asr;
29  case ISD::ROTR: return ARM_AM::ror;
30  //case ISD::ROTL: // Only if imm -> turn into ROTR.
31  // Can't handle RRX here, because it would require folding a flag into
32  // the addressing mode. :( This causes us to miss certain things.
33  //case ARMISD::RRX: return ARM_AM::rrx;
34  }
35  }
36 } // end namespace ARM_AM
37 
39  /// Subtarget - Keep a pointer to the ARMSubtarget around so that we can
40  /// make the right decision when generating code for different targets.
41  const ARMSubtarget *Subtarget;
42 
43 public:
44  explicit ARMSelectionDAGInfo(const TargetMachine &TM);
46 
47  virtual
49  SDValue Chain,
50  SDValue Dst, SDValue Src,
51  SDValue Size, unsigned Align,
52  bool isVolatile, bool AlwaysInline,
53  MachinePointerInfo DstPtrInfo,
54  MachinePointerInfo SrcPtrInfo) const;
55 
56  // Adjust parameters for memset, see RTABI section 4.3.4
57  virtual
59  SDValue Chain,
60  SDValue Op1, SDValue Op2,
61  SDValue Op3, unsigned Align,
62  bool isVolatile,
63  MachinePointerInfo DstPtrInfo) const;
64 };
65 
66 }
67 
68 #endif
static ShiftOpc getShiftOpcForNode(unsigned Opcode)
ARMSelectionDAGInfo(const TargetMachine &TM)
static cl::opt< AlignMode > Align(cl::desc("Load/store alignment support"), cl::Hidden, cl::init(DefaultAlign), cl::values(clEnumValN(DefaultAlign,"arm-default-align","Generate unaligned accesses only on hardware/OS ""combinations that are known to support them"), clEnumValN(StrictAlign,"arm-strict-align","Disallow all unaligned memory accesses"), clEnumValN(NoStrictAlign,"arm-no-strict-align","Allow unaligned memory accesses"), clEnumValEnd))
virtual SDValue EmitTargetCodeForMemset(SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, unsigned Align, bool isVolatile, MachinePointerInfo DstPtrInfo) const
virtual SDValue EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, unsigned Align, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const