Coverage Report

Created: 2017-08-18 19:41

/Users/buildslave/jenkins/sharedspace/clang-stage2-coverage-R@2/llvm/tools/polly/lib/External/isl/include/isl/ctx.h
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * Copyright 2008-2009 Katholieke Universiteit Leuven
3
 *
4
 * Use of this software is governed by the MIT license
5
 *
6
 * Written by Sven Verdoolaege, K.U.Leuven, Departement
7
 * Computerwetenschappen, Celestijnenlaan 200A, B-3001 Leuven, Belgium
8
 */
9
10
#ifndef ISL_CTX_H
11
#define ISL_CTX_H
12
13
#include <stdio.h>
14
#include <stdlib.h>
15
16
#include <isl/arg.h>
17
18
#ifndef __isl_give
19
#define __isl_give
20
#endif
21
#ifndef __isl_take
22
#define __isl_take
23
#endif
24
#ifndef __isl_keep
25
#define __isl_keep
26
#endif
27
#ifndef __isl_null
28
#define __isl_null
29
#endif
30
#ifndef __isl_export
31
#define __isl_export
32
#endif
33
#ifndef __isl_overload
34
#define __isl_overload
35
#endif
36
#ifndef __isl_constructor
37
#define __isl_constructor
38
#endif
39
#ifndef __isl_subclass
40
#define __isl_subclass(super)
41
#endif
42
43
#if defined(__cplusplus)
44
extern "C" {
45
#endif
46
47
/* Nearly all isa functions require a struct isl_ctx allocated using
48
 * isl_ctx_alloc.  This ctx contains (or will contain) options that
49
 * control the behavior of the library and some caches.
50
 *
51
 * An object allocated within a given ctx should never be used inside
52
 * another ctx.  Functions for moving objects from one ctx to another
53
 * will be added as the need arises.
54
 *
55
 * A given context should only be used inside a single thread.
56
 * A global context for synchronization between different threads
57
 * as well as functions for moving a context to a different thread
58
 * will be added as the need arises.
59
 *
60
 * If anything goes wrong (out of memory, failed assertion), then
61
 * the library will currently simply abort.  This will be made
62
 * configurable in the future.
63
 * Users of the library should expect functions that return
64
 * a pointer to a structure, to return NULL, indicating failure.
65
 * Any function accepting a pointer to a structure will treat
66
 * a NULL argument as a failure, resulting in the function freeing
67
 * the remaining structures (if any) and returning NULL itself
68
 * (in case of pointer return type).
69
 * The only exception is the isl_ctx argument, which should never be NULL.
70
 */
71
struct isl_stats {
72
  long  gbr_solved_lps;
73
};
74
enum isl_error {
75
  isl_error_none = 0,
76
  isl_error_abort,
77
  isl_error_alloc,
78
  isl_error_unknown,
79
  isl_error_internal,
80
  isl_error_invalid,
81
  isl_error_quota,
82
  isl_error_unsupported
83
};
84
typedef enum {
85
  isl_stat_error = -1,
86
  isl_stat_ok = 0
87
} isl_stat;
88
typedef enum {
89
  isl_bool_error = -1,
90
  isl_bool_false = 0,
91
  isl_bool_true = 1
92
} isl_bool;
93
isl_bool isl_bool_not(isl_bool b);
94
struct isl_ctx;
95
typedef struct isl_ctx isl_ctx;
96
97
/* Some helper macros */
98
99
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1)
100
#define ISL_DEPRECATED  __attribute__((__deprecated__))
101
#else
102
#define ISL_DEPRECATED
103
#endif
104
105
#define ISL_FL_INIT(l, f)   (l) = (f)               /* Specific flags location. */
106
7.79M
#define ISL_FL_SET(l, f)    ((l) |= (f))
107
114M
#define ISL_FL_CLR(l, f)    ((l) &= ~(f))
108
45.7M
#define ISL_FL_ISSET(l, f)  (!!((l) & (f)))
109
110
#define ISL_F_INIT(p, f)    ISL_FL_INIT((p)->flags, f)  /* Structure element flags. */
111
7.78M
#define ISL_F_SET(p, f)     ISL_FL_SET((p)->flags, f)
112
115M
#define ISL_F_CLR(p, f)     ISL_FL_CLR((p)->flags, f)
113
45.5M
#define ISL_F_ISSET(p, f)   ISL_FL_ISSET((p)->flags, f)
114
115
void *isl_malloc_or_die(isl_ctx *ctx, size_t size);
116
void *isl_calloc_or_die(isl_ctx *ctx, size_t nmemb, size_t size);
117
void *isl_realloc_or_die(isl_ctx *ctx, void *ptr, size_t size);
118
119
31.6M
#define isl_alloc(ctx,type,size)  ((type *)isl_malloc_or_die(ctx, size))
120
6.95M
#define isl_calloc(ctx,type,size) ((type *)isl_calloc_or_die(ctx,\
121
6.95M
                    1, size))
122
978k
#define isl_realloc(ctx,ptr,type,size)  ((type *)isl_realloc_or_die(ctx,\
123
978k
                    ptr, size))
124
15.5M
#define isl_alloc_type(ctx,type)  isl_alloc(ctx,type,sizeof(type))
125
5.52M
#define isl_calloc_type(ctx,type) isl_calloc(ctx,type,sizeof(type))
126
#define isl_realloc_type(ctx,ptr,type)  isl_realloc(ctx,ptr,type,sizeof(type))
127
15.1M
#define isl_alloc_array(ctx,type,n) isl_alloc(ctx,type,(n)*sizeof(type))
128
4.99M
#define isl_calloc_array(ctx,type,n)  ((type *)isl_calloc_or_die(ctx,\
129
4.99M
                  n, sizeof(type)))
130
#define isl_realloc_array(ctx,ptr,type,n) \
131
967k
            isl_realloc(ctx,ptr,type,(n)*sizeof(type))
132
133
#define isl_die(ctx,errno,msg,code)         \
134
5.91k
  
do 5.91k
{               \49
135
49
    isl_handle_error(ctx, errno, msg, __FILE__, __LINE__);  \
136
49
    code;             \
137
5.91k
  } while (0)
138
139
void isl_handle_error(isl_ctx *ctx, enum isl_error error, const char *msg,
140
  const char *file, int line);
141
142
#define isl_assert4(ctx,test,code,errno)        \
143
145M
  
do 145M
{               \145M
144
145M
    if (test)           \
145
145M
      break;           \
146
0
    
isl_die0
(ctx, errno, "Assertion \"" #test "\" failed", code); \0
147
145M
  } while (0)
148
#define isl_assert(ctx,test,code)         \
149
145M
  isl_assert4(ctx,test,code,isl_error_unknown)
150
151
21.9M
#define isl_min(a,b)      
((a < b) ? 21.9M
(a)0
:
(b)21.9M
)
152
153
/* struct isl_ctx functions */
154
155
struct isl_options *isl_ctx_options(isl_ctx *ctx);
156
157
isl_ctx *isl_ctx_alloc_with_options(struct isl_args *args,
158
  __isl_take void *opt);
159
isl_ctx *isl_ctx_alloc(void);
160
void *isl_ctx_peek_options(isl_ctx *ctx, struct isl_args *args);
161
int isl_ctx_parse_options(isl_ctx *ctx, int argc, char **argv, unsigned flags);
162
void isl_ctx_ref(struct isl_ctx *ctx);
163
void isl_ctx_deref(struct isl_ctx *ctx);
164
void isl_ctx_free(isl_ctx *ctx);
165
166
void isl_ctx_abort(isl_ctx *ctx);
167
void isl_ctx_resume(isl_ctx *ctx);
168
int isl_ctx_aborted(isl_ctx *ctx);
169
170
void isl_ctx_set_max_operations(isl_ctx *ctx, unsigned long max_operations);
171
unsigned long isl_ctx_get_max_operations(isl_ctx *ctx);
172
void isl_ctx_reset_operations(isl_ctx *ctx);
173
174
#define ISL_ARG_CTX_DECL(prefix,st,args)        \
175
st *isl_ctx_peek_ ## prefix(isl_ctx *ctx);
176
177
#define ISL_ARG_CTX_DEF(prefix,st,args)         \
178
28.9k
st *isl_ctx_peek_ ## prefix(isl_ctx *ctx)       \
179
28.9k
{                 \
180
28.9k
  return (st *)isl_ctx_peek_options(ctx, &(args));    \
181
28.9k
}
182
183
#define ISL_CTX_GET_INT_DEF(prefix,st,args,field)     \
184
24.3k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
24.3k
{                 \
186
24.3k
  st *options;              \
187
24.3k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
24.3k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
24.3k
      "isl_ctx does not reference " #prefix,    \
191
24.3k
      return -1);         \
192
24.3k
  return options->field;           \
193
24.3k
}
Unexecuted instantiation: isl_options_get_bound
isl_options_get_on_error
Line
Count
Source
184
1.01k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.01k
{                 \
186
1.01k
  st *options;              \
187
1.01k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.01k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
1.01k
      "isl_ctx does not reference " #prefix,    \
191
1.01k
      return -1);         \
192
1.01k
  return options->field;           \
193
1.01k
}
Unexecuted instantiation: isl_options_get_pip_symmetry
isl_options_get_coalesce_bounded_wrapping
Line
Count
Source
184
1.88k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.88k
{                 \
186
1.88k
  st *options;              \
187
1.88k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.88k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
1.88k
      "isl_ctx does not reference " #prefix,    \
191
1.88k
      return -1);         \
192
1.88k
  return options->field;           \
193
1.88k
}
Unexecuted instantiation: isl_options_get_gbr_only_first
isl_options_get_schedule_max_coefficient
Line
Count
Source
184
1.04k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.04k
{                 \
186
1.04k
  st *options;              \
187
1.04k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.04k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
1.04k
      "isl_ctx does not reference " #prefix,    \
191
1.04k
      return -1);         \
192
1.04k
  return options->field;           \
193
1.04k
}
isl_options_get_schedule_max_constant_term
Line
Count
Source
184
798
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
798
{                 \
186
798
  st *options;              \
187
798
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
798
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
798
      "isl_ctx does not reference " #prefix,    \
191
798
      return -1);         \
192
798
  return options->field;           \
193
798
}
isl_options_get_schedule_maximize_band_depth
Line
Count
Source
184
18
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
18
{                 \
186
18
  st *options;              \
187
18
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
18
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
18
      "isl_ctx does not reference " #prefix,    \
191
18
      return -1);         \
192
18
  return options->field;           \
193
18
}
isl_options_get_schedule_maximize_coincidence
Line
Count
Source
184
20
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
20
{                 \
186
20
  st *options;              \
187
20
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
20
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
20
      "isl_ctx does not reference " #prefix,    \
191
20
      return -1);         \
192
20
  return options->field;           \
193
20
}
Unexecuted instantiation: isl_options_get_schedule_split_scaled
isl_options_get_schedule_treat_coalescing
Line
Count
Source
184
1.52k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.52k
{                 \
186
1.52k
  st *options;              \
187
1.52k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.52k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
1.52k
      "isl_ctx does not reference " #prefix,    \
191
1.52k
      return -1);         \
192
1.52k
  return options->field;           \
193
1.52k
}
isl_options_get_schedule_separate_components
Line
Count
Source
184
10
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
10
{                 \
186
10
  st *options;              \
187
10
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
10
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
10
      "isl_ctx does not reference " #prefix,    \
191
10
      return -1);         \
192
10
  return options->field;           \
193
10
}
isl_options_get_schedule_whole_component
Line
Count
Source
184
41
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
41
{                 \
186
41
  st *options;              \
187
41
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
41
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
41
      "isl_ctx does not reference " #prefix,    \
191
41
      return -1);         \
192
41
  return options->field;           \
193
41
}
isl_options_get_schedule_outer_coincidence
Line
Count
Source
184
15
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
15
{                 \
186
15
  st *options;              \
187
15
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
15
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
15
      "isl_ctx does not reference " #prefix,    \
191
15
      return -1);         \
192
15
  return options->field;           \
193
15
}
Unexecuted instantiation: isl_options_get_schedule_algorithm
isl_options_get_schedule_carry_self_first
Line
Count
Source
184
13
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
13
{                 \
186
13
  st *options;              \
187
13
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
13
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
13
      "isl_ctx does not reference " #prefix,    \
191
13
      return -1);         \
192
13
  return options->field;           \
193
13
}
isl_options_get_schedule_serialize_sccs
Line
Count
Source
184
162
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
162
{                 \
186
162
  st *options;              \
187
162
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
162
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
162
      "isl_ctx does not reference " #prefix,    \
191
162
      return -1);         \
192
162
  return options->field;           \
193
162
}
isl_options_get_tile_scale_tile_loops
Line
Count
Source
184
151
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
151
{                 \
186
151
  st *options;              \
187
151
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
151
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
151
      "isl_ctx does not reference " #prefix,    \
191
151
      return -1);         \
192
151
  return options->field;           \
193
151
}
isl_options_get_tile_shift_point_loops
Line
Count
Source
184
77
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
77
{                 \
186
77
  st *options;              \
187
77
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
77
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
77
      "isl_ctx does not reference " #prefix,    \
191
77
      return -1);         \
192
77
  return options->field;           \
193
77
}
isl_options_get_ast_build_atomic_upper_bound
Line
Count
Source
184
696
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
696
{                 \
186
696
  st *options;              \
187
696
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
696
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
696
      "isl_ctx does not reference " #prefix,    \
191
696
      return -1);         \
192
696
  return options->field;           \
193
696
}
isl_options_get_ast_build_prefer_pdiv
Line
Count
Source
184
7.07k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
7.07k
{                 \
186
7.07k
  st *options;              \
187
7.07k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
7.07k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
7.07k
      "isl_ctx does not reference " #prefix,    \
191
7.07k
      return -1);         \
192
7.07k
  return options->field;           \
193
7.07k
}
isl_options_get_ast_build_detect_min_max
Line
Count
Source
184
55
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
55
{                 \
186
55
  st *options;              \
187
55
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
55
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
55
      "isl_ctx does not reference " #prefix,    \
191
55
      return -1);         \
192
55
  return options->field;           \
193
55
}
isl_options_get_ast_build_exploit_nested_bounds
Line
Count
Source
184
2.90k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
2.90k
{                 \
186
2.90k
  st *options;              \
187
2.90k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
2.90k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
2.90k
      "isl_ctx does not reference " #prefix,    \
191
2.90k
      return -1);         \
192
2.90k
  return options->field;           \
193
2.90k
}
isl_options_get_ast_build_group_coscheduled
Line
Count
Source
184
91
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
91
{                 \
186
91
  st *options;              \
187
91
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
91
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
91
      "isl_ctx does not reference " #prefix,    \
191
91
      return -1);         \
192
91
  return options->field;           \
193
91
}
isl_options_get_ast_always_print_block
Line
Count
Source
184
342
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
342
{                 \
186
342
  st *options;              \
187
342
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
342
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
342
      "isl_ctx does not reference " #prefix,    \
191
342
      return -1);         \
192
342
  return options->field;           \
193
342
}
Unexecuted instantiation: isl_options_get_ast_print_macro_once
Unexecuted instantiation: isl_options_get_ast_build_separation_bounds
isl_options_get_ast_build_scale_strides
Line
Count
Source
184
2.90k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
2.90k
{                 \
186
2.90k
  st *options;              \
187
2.90k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
2.90k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
2.90k
      "isl_ctx does not reference " #prefix,    \
191
2.90k
      return -1);         \
192
2.90k
  return options->field;           \
193
2.90k
}
isl_options_get_ast_build_allow_else
Line
Count
Source
184
3.37k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
3.37k
{                 \
186
3.37k
  st *options;              \
187
3.37k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
3.37k
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
3.37k
      "isl_ctx does not reference " #prefix,    \
191
3.37k
      return -1);         \
192
3.37k
  return options->field;           \
193
3.37k
}
isl_options_get_ast_build_allow_or
Line
Count
Source
184
131
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
131
{                 \
186
131
  st *options;              \
187
131
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
131
  if (!options)             \
189
0
    isl_die(ctx, isl_error_invalid,        \
190
131
      "isl_ctx does not reference " #prefix,    \
191
131
      return -1);         \
192
131
  return options->field;           \
193
131
}
194
195
#define ISL_CTX_SET_INT_DEF(prefix,st,args,field)     \
196
4.26k
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
4.26k
{                 \
198
4.26k
  st *options;              \
199
4.26k
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
4.26k
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
4.26k
      "isl_ctx does not reference " #prefix,    \
203
4.26k
      return isl_stat_error);       \
204
4.26k
  options->field = val;           \
205
4.26k
  return isl_stat_ok;           \
206
4.26k
}
Unexecuted instantiation: isl_options_set_bound
isl_options_set_on_error
Line
Count
Source
196
3.13k
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
3.13k
{                 \
198
3.13k
  st *options;              \
199
3.13k
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
3.13k
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
3.13k
      "isl_ctx does not reference " #prefix,    \
203
3.13k
      return isl_stat_error);       \
204
3.13k
  options->field = val;           \
205
3.13k
  return isl_stat_ok;           \
206
3.13k
}
Unexecuted instantiation: isl_options_set_pip_symmetry
isl_options_set_coalesce_bounded_wrapping
Line
Count
Source
196
2
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
2
{                 \
198
2
  st *options;              \
199
2
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
2
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
2
      "isl_ctx does not reference " #prefix,    \
203
2
      return isl_stat_error);       \
204
2
  options->field = val;           \
205
2
  return isl_stat_ok;           \
206
2
}
Unexecuted instantiation: isl_options_set_gbr_only_first
isl_options_set_schedule_max_coefficient
Line
Count
Source
196
43
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
43
{                 \
198
43
  st *options;              \
199
43
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
43
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
43
      "isl_ctx does not reference " #prefix,    \
203
43
      return isl_stat_error);       \
204
43
  options->field = val;           \
205
43
  return isl_stat_ok;           \
206
43
}
isl_options_set_schedule_max_constant_term
Line
Count
Source
196
39
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
39
{                 \
198
39
  st *options;              \
199
39
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
39
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
39
      "isl_ctx does not reference " #prefix,    \
203
39
      return isl_stat_error);       \
204
39
  options->field = val;           \
205
39
  return isl_stat_ok;           \
206
39
}
isl_options_set_schedule_maximize_band_depth
Line
Count
Source
196
37
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
37
{                 \
198
37
  st *options;              \
199
37
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
37
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
37
      "isl_ctx does not reference " #prefix,    \
203
37
      return isl_stat_error);       \
204
37
  options->field = val;           \
205
37
  return isl_stat_ok;           \
206
37
}
isl_options_set_schedule_maximize_coincidence
Line
Count
Source
196
4
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
4
{                 \
198
4
  st *options;              \
199
4
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
4
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
4
      "isl_ctx does not reference " #prefix,    \
203
4
      return isl_stat_error);       \
204
4
  options->field = val;           \
205
4
  return isl_stat_ok;           \
206
4
}
Unexecuted instantiation: isl_options_set_schedule_split_scaled
isl_options_set_schedule_treat_coalescing
Line
Count
Source
196
8
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
8
{                 \
198
8
  st *options;              \
199
8
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
8
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
8
      "isl_ctx does not reference " #prefix,    \
203
8
      return isl_stat_error);       \
204
8
  options->field = val;           \
205
8
  return isl_stat_ok;           \
206
8
}
Unexecuted instantiation: isl_options_set_schedule_separate_components
isl_options_set_schedule_whole_component
Line
Count
Source
196
4
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
4
{                 \
198
4
  st *options;              \
199
4
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
4
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
4
      "isl_ctx does not reference " #prefix,    \
203
4
      return isl_stat_error);       \
204
4
  options->field = val;           \
205
4
  return isl_stat_ok;           \
206
4
}
isl_options_set_schedule_outer_coincidence
Line
Count
Source
196
41
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
41
{                 \
198
41
  st *options;              \
199
41
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
41
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
41
      "isl_ctx does not reference " #prefix,    \
203
41
      return isl_stat_error);       \
204
41
  options->field = val;           \
205
41
  return isl_stat_ok;           \
206
41
}
Unexecuted instantiation: isl_options_set_schedule_algorithm
Unexecuted instantiation: isl_options_set_schedule_carry_self_first
isl_options_set_schedule_serialize_sccs
Line
Count
Source
196
37
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
37
{                 \
198
37
  st *options;              \
199
37
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
37
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
37
      "isl_ctx does not reference " #prefix,    \
203
37
      return isl_stat_error);       \
204
37
  options->field = val;           \
205
37
  return isl_stat_ok;           \
206
37
}
isl_options_set_tile_scale_tile_loops
Line
Count
Source
196
42
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
42
{                 \
198
42
  st *options;              \
199
42
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
42
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
42
      "isl_ctx does not reference " #prefix,    \
203
42
      return isl_stat_error);       \
204
42
  options->field = val;           \
205
42
  return isl_stat_ok;           \
206
42
}
isl_options_set_tile_shift_point_loops
Line
Count
Source
196
5
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
5
{                 \
198
5
  st *options;              \
199
5
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
5
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
5
      "isl_ctx does not reference " #prefix,    \
203
5
      return isl_stat_error);       \
204
5
  options->field = val;           \
205
5
  return isl_stat_ok;           \
206
5
}
isl_options_set_ast_build_atomic_upper_bound
Line
Count
Source
196
430
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
430
{                 \
198
430
  st *options;              \
199
430
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
430
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
430
      "isl_ctx does not reference " #prefix,    \
203
430
      return isl_stat_error);       \
204
430
  options->field = val;           \
205
430
  return isl_stat_ok;           \
206
430
}
Unexecuted instantiation: isl_options_set_ast_build_prefer_pdiv
isl_options_set_ast_build_detect_min_max
Line
Count
Source
196
432
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
432
{                 \
198
432
  st *options;              \
199
432
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
432
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
432
      "isl_ctx does not reference " #prefix,    \
203
432
      return isl_stat_error);       \
204
432
  options->field = val;           \
205
432
  return isl_stat_ok;           \
206
432
}
isl_options_set_ast_build_exploit_nested_bounds
Line
Count
Source
196
3
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
3
{                 \
198
3
  st *options;              \
199
3
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
3
  if (!options)             \
201
0
    isl_die(ctx, isl_error_invalid,        \
202
3
      "isl_ctx does not reference " #prefix,    \
203
3
      return isl_stat_error);       \
204
3
  options->field = val;           \
205
3
  return isl_stat_ok;           \
206
3
}
Unexecuted instantiation: isl_options_set_ast_build_group_coscheduled
Unexecuted instantiation: isl_options_set_ast_always_print_block
Unexecuted instantiation: isl_options_set_ast_print_macro_once
Unexecuted instantiation: isl_options_set_ast_build_separation_bounds
Unexecuted instantiation: isl_options_set_ast_build_scale_strides
Unexecuted instantiation: isl_options_set_ast_build_allow_else
Unexecuted instantiation: isl_options_set_ast_build_allow_or
207
208
#define ISL_CTX_GET_STR_DEF(prefix,st,args,field)     \
209
399
const char *prefix ## _get_ ## field(isl_ctx *ctx)      \
210
399
{                 \
211
399
  st *options;              \
212
399
  options = isl_ctx_peek_ ## prefix(ctx);       \
213
399
  if (!options)             \
214
0
    isl_die(ctx, isl_error_invalid,        \
215
399
      "isl_ctx does not reference " #prefix,    \
216
399
      return NULL);         \
217
399
  return options->field;           \
218
399
}
219
220
#define ISL_CTX_SET_STR_DEF(prefix,st,args,field)     \
221
0
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, const char *val)  \
222
0
{                 \
223
0
  st *options;              \
224
0
  options = isl_ctx_peek_ ## prefix(ctx);       \
225
0
  if (!options)             \
226
0
    isl_die(ctx, isl_error_invalid,        \
227
0
      "isl_ctx does not reference " #prefix,    \
228
0
      return isl_stat_error);       \
229
0
  
if (0
!val0
)             \
230
0
    return isl_stat_error;         \
231
0
  free(options->field);           \
232
0
  options->field = strdup(val);         \
233
0
  if (!options->field)           \
234
0
    return isl_stat_error;         \
235
0
  return isl_stat_ok;           \
236
0
}
237
238
#define ISL_CTX_GET_BOOL_DEF(prefix,st,args,field)      \
239
  ISL_CTX_GET_INT_DEF(prefix,st,args,field)
240
241
#define ISL_CTX_SET_BOOL_DEF(prefix,st,args,field)      \
242
  ISL_CTX_SET_INT_DEF(prefix,st,args,field)
243
244
#define ISL_CTX_GET_CHOICE_DEF(prefix,st,args,field)      \
245
  ISL_CTX_GET_INT_DEF(prefix,st,args,field)
246
247
#define ISL_CTX_SET_CHOICE_DEF(prefix,st,args,field)      \
248
  ISL_CTX_SET_INT_DEF(prefix,st,args,field)
249
250
enum isl_error isl_ctx_last_error(isl_ctx *ctx);
251
void isl_ctx_reset_error(isl_ctx *ctx);
252
void isl_ctx_set_error(isl_ctx *ctx, enum isl_error error);
253
254
#if defined(__cplusplus)
255
}
256
#endif
257
258
#endif