blob: 908e16ed5e78ee655ed608d59ba59924e7bc7952 [file] [log] [blame]
Chris Lattner00836642007-02-27 05:57:32 +00001//===- TargetCallingConv.td - Target Calling Conventions ---*- tablegen -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Chris Lattner00836642007-02-27 05:57:32 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file defines the target-independent interfaces with which targets
11// describe their calling conventions.
12//
13//===----------------------------------------------------------------------===//
14
15class CCAction;
16class CallingConv;
17
18/// CCPredicateAction - Instances of this class check some predicate, then
19/// delegate to another action if the predicate is true.
20class CCPredicateAction<CCAction A> : CCAction {
21 CCAction SubAction = A;
22}
23
Chris Lattner62247f62007-02-28 05:29:33 +000024/// CCIfType - If the current argument is one of the specified types, apply
Chris Lattner00836642007-02-27 05:57:32 +000025/// Action A.
Chris Lattner62247f62007-02-28 05:29:33 +000026class CCIfType<list<ValueType> vts, CCAction A> : CCPredicateAction<A> {
Chris Lattnerf4580302007-02-27 20:45:02 +000027 list<ValueType> VTs = vts;
Chris Lattner00836642007-02-27 05:57:32 +000028}
29
Chris Lattner62247f62007-02-28 05:29:33 +000030/// CCIf - If the predicate matches, apply A.
31class CCIf<string predicate, CCAction A> : CCPredicateAction<A> {
Chris Lattner00836642007-02-27 05:57:32 +000032 string Predicate = predicate;
33}
34
Evan Cheng6bfa8a12008-01-15 03:34:58 +000035/// CCIfByVal - If the current argument has ByVal parameter attribute, apply
Rafael Espindola1aa7efb2007-07-06 10:57:03 +000036/// Action A.
Duncan Sands276dcbd2008-03-21 09:14:45 +000037class CCIfByVal<CCAction A> : CCIf<"ArgFlags.isByVal()", A> {
Rafael Espindola1aa7efb2007-07-06 10:57:03 +000038}
39
Chris Lattner62247f62007-02-28 05:29:33 +000040/// CCIfCC - Match of the current calling convention is 'CC'.
41class CCIfCC<string CC, CCAction A>
42 : CCIf<!strconcat("State.getCallingConv() == ", CC), A> {}
43
44/// CCIfInReg - If this argument is marked with the 'inreg' attribute, apply
45/// the specified action.
Duncan Sands276dcbd2008-03-21 09:14:45 +000046class CCIfInReg<CCAction A> : CCIf<"ArgFlags.isInReg()", A> {}
Chris Lattner62247f62007-02-28 05:29:33 +000047
Duncan Sands36397f52007-07-27 12:58:54 +000048/// CCIfNest - If this argument is marked with the 'nest' attribute, apply
49/// the specified action.
Duncan Sands276dcbd2008-03-21 09:14:45 +000050class CCIfNest<CCAction A> : CCIf<"ArgFlags.isNest()", A> {}
Duncan Sands36397f52007-07-27 12:58:54 +000051
Chris Lattner52387be2007-06-19 00:13:10 +000052/// CCIfNotVarArg - If the current function is not vararg - apply the action
53class CCIfNotVarArg<CCAction A> : CCIf<"!State.isVarArg()", A> {}
Chris Lattner00836642007-02-27 05:57:32 +000054
55/// CCAssignToReg - This action matches if there is a register in the specified
56/// list that is still available. If so, it assigns the value to the first
57/// available register and succeeds.
58class CCAssignToReg<list<Register> regList> : CCAction {
59 list<Register> RegList = regList;
60}
61
Anton Korobeynikov67073f12008-04-02 05:23:57 +000062/// CCAssignToRegWithShadow - Same as CCAssignToReg, but with list of registers
63/// which became shadowed, when some register is used.
64class CCAssignToRegWithShadow<list<Register> regList,
65 list<Register> shadowList> : CCAction {
66 list<Register> RegList = regList;
67 list<Register> ShadowRegList = shadowList;
68}
69
Chris Lattner00836642007-02-27 05:57:32 +000070/// CCAssignToStack - This action always matches: it assigns the value to a
Duncan Sands87b665d2007-11-14 08:29:13 +000071/// stack slot of the specified size and alignment on the stack. If size is
72/// zero then the ABI size is used; if align is zero then the ABI alignment
73/// is used - these may depend on the target or subtarget.
Chris Lattner00836642007-02-27 05:57:32 +000074class CCAssignToStack<int size, int align> : CCAction {
75 int Size = size;
76 int Align = align;
77}
78
Evan Cheng6bfa8a12008-01-15 03:34:58 +000079/// CCPassByVal - This action always matches: it assigns the value to a stack
80/// slot to implement ByVal aggregate parameter passing. Size and alignment
81/// specify the minimum size and alignment for the stack slot.
82class CCPassByVal<int size, int align> : CCAction {
83 int Size = size;
84 int Align = align;
Rafael Espindola1aa7efb2007-07-06 10:57:03 +000085}
Chris Lattner00836642007-02-27 05:57:32 +000086
87/// CCPromoteToType - If applied, this promotes the specified current value to
88/// the specified type.
89class CCPromoteToType<ValueType destTy> : CCAction {
90 ValueType DestTy = destTy;
91}
92
93/// CCDelegateTo - This action invokes the specified sub-calling-convention. It
94/// is successful if the specified CC matches.
95class CCDelegateTo<CallingConv cc> : CCAction {
96 CallingConv CC = cc;
97}
98
99/// CallingConv - An instance of this is used to define each calling convention
100/// that the target supports.
101class CallingConv<list<CCAction> actions> {
102 list<CCAction> Actions = actions;
103}