2 * Copyright 2011 Leiden University. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above
12 * copyright notice, this list of conditions and the following
13 * disclaimer in the documentation and/or other materials provided
14 * with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY LEIDEN UNIVERSITY ''AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL LEIDEN UNIVERSITY OR
20 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
21 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
22 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
23 * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 * The views and conclusions contained in the software and documentation
29 * are those of the authors and should not be interpreted as
30 * representing official policies, either expressed or implied, of
36 #include "clang_compatibility.h"
39 using namespace clang
;
41 /* Create an isl_id that refers to the variable declarator "decl".
43 __isl_give isl_id
*pet_id_from_decl(isl_ctx
*ctx
, ValueDecl
*decl
)
45 return isl_id_alloc(ctx
, decl
->getName().str().c_str(), decl
);
48 /* Create an isl_id that refers to the variable declarator "decl", but
51 __isl_give isl_id
*pet_id_from_name_and_decl(isl_ctx
*ctx
, const char *name
,
54 return isl_id_alloc(ctx
, name
, decl
);
57 /* Create an isl_id with name specified by "name_template" and "n" and
58 * associated type "qt".
60 static __isl_give isl_id
*pet_id_from_type(isl_ctx
*ctx
,
61 const char *name_template
, int n
, QualType qt
)
64 const Type
*type
= qt
.getTypePtr();
66 snprintf(name
, sizeof(name
), name_template
, n
);
67 return isl_id_alloc(ctx
, name
, const_cast<Type
*>(type
));
70 /* Create an isl_id with name "__pet_arg_<n>" and associated type "qt".
72 __isl_give isl_id
*pet_id_arg_from_type(isl_ctx
*ctx
, int n
, QualType qt
)
74 return pet_id_from_type(ctx
, "__pet_arg_%d", n
, qt
);
77 /* Create an isl_id with name "__pet_ret_<n>" and associated type "qt".
79 __isl_give isl_id
*pet_id_ret_from_type(isl_ctx
*ctx
, int n
, QualType qt
)
81 return pet_id_from_type(ctx
, "__pet_ret_%d", n
, qt
);
84 /* Compare the prefix of "s" to "prefix" up to the length of "prefix".
86 static int prefixcmp(const char *s
, const char *prefix
)
88 return strncmp(s
, prefix
, strlen(prefix
));
91 /* Is "id" an identifier created by pet_id_arg_from_type or
92 * pet_id_ret_from_type?
94 static int pet_id_is_arg_or_ret(__isl_keep isl_id
*id
)
100 name
= isl_id_get_name(id
);
103 return !prefixcmp(name
, "__pet_arg") || !prefixcmp(name
, "__pet_ret");
106 /* Extract the ValueDecl that was associated to "id"
107 * in pet_id_from_decl.
109 * If "id" was create by pet_id_arg_from_type or pet_id_ret_from_type,
110 * then there is no ValueDecl associated to it, so return NULL instead.
112 ValueDecl
*pet_id_get_decl(__isl_keep isl_id
*id
)
114 if (pet_id_is_arg_or_ret(id
))
117 return (ValueDecl
*) isl_id_get_user(id
);
120 /* Construct a pet_expr representing an index expression for an access
121 * to the variable represented by "id".
123 __isl_give pet_expr
*pet_id_create_index_expr(__isl_take isl_id
*id
)
130 space
= isl_space_alloc(isl_id_get_ctx(id
), 0, 0, 0);
131 space
= isl_space_set_tuple_id(space
, isl_dim_out
, id
);
133 return pet_expr_from_index(isl_multi_pw_aff_zero(space
));
136 /* Is "T" the type of a variable length array with static size?
138 static bool is_vla_with_static_size(QualType T
)
140 const VariableArrayType
*vlatype
;
142 if (!T
->isVariableArrayType())
144 vlatype
= cast
<VariableArrayType
>(T
);
145 return vlatype
->getSizeModifier() == ArraySizeModifier::Static
;
148 /* Return the type of the variable represented by "id" as an array.
150 * In particular, if the declaration associated to "id" is a parameter
151 * declaration that is a variable length array with a static size, then
152 * return the original type (i.e., the variable length array).
153 * Otherwise, return the type of decl.
155 * If "id" was created by pet_id_arg_from_type or pet_id_ret_from_type,
156 * then it has a type associated to it, so return that type instead.
158 QualType
pet_id_get_array_type(__isl_keep isl_id
*id
)
164 if (pet_id_is_arg_or_ret(id
)) {
166 type
= (const Type
*) isl_id_get_user(id
);
167 return QualType(type
, 0);
170 decl
= pet_id_get_decl(id
);
172 parm
= dyn_cast
<ParmVarDecl
>(decl
);
174 return decl
->getType();
176 T
= parm
->getOriginalType();
177 if (!is_vla_with_static_size(T
))
178 return decl
->getType();