blob: ec1bf5ca1941d5e0a4547d7cb1a39852196d4a75 [file] [log] [blame]
Dan Gohman53c5e422010-04-16 23:04:22 +00001//===-- 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
17#include "llvm/Target/TargetSelectionDAGInfo.h"
18
19namespace llvm {
20
21class ARMSelectionDAGInfo : public TargetSelectionDAGInfo {
Dan Gohmanff7a5622010-05-11 17:31:57 +000022 /// Subtarget - Keep a pointer to the ARMSubtarget around so that we can
23 /// make the right decision when generating code for different targets.
24 const ARMSubtarget *Subtarget;
25
Dan Gohman53c5e422010-04-16 23:04:22 +000026public:
Dan Gohmanff7a5622010-05-11 17:31:57 +000027 explicit ARMSelectionDAGInfo(const TargetMachine &TM);
Dan Gohman53c5e422010-04-16 23:04:22 +000028 ~ARMSelectionDAGInfo();
Dan Gohmanff7a5622010-05-11 17:31:57 +000029
30 virtual
31 SDValue EmitTargetCodeForMemcpy(SelectionDAG &DAG, DebugLoc dl,
32 SDValue Chain,
33 SDValue Dst, SDValue Src,
34 SDValue Size, unsigned Align,
35 bool isVolatile, bool AlwaysInline,
Chris Lattnere72f2022010-09-21 05:40:29 +000036 MachinePointerInfo DstPtrInfo,
37 MachinePointerInfo SrcPtrInfo) const;
Renato Golin1ec11fb2011-05-22 21:41:23 +000038
39 // Adjust parameters for memset, see RTABI section 4.3.4
40 virtual
41 SDValue EmitTargetCodeForMemset(SelectionDAG &DAG, DebugLoc dl,
42 SDValue Chain,
43 SDValue Op1, SDValue Op2,
44 SDValue Op3, unsigned Align,
45 bool isVolatile,
46 MachinePointerInfo DstPtrInfo) const;
Dan Gohman53c5e422010-04-16 23:04:22 +000047};
48
49}
50
51#endif