Coverage Report

Created: 2017-11-23 03:11

/Users/buildslave/jenkins/workspace/clang-stage2-coverage-R/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
14.3M
#define ISL_FL_SET(l, f)    ((l) |= (f))
107
140M
#define ISL_FL_CLR(l, f)    ((l) &= ~(f))
108
57.1M
#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
8.97M
#define ISL_F_SET(p, f)     ISL_FL_SET((p)->flags, f)
112
139M
#define ISL_F_CLR(p, f)     ISL_FL_CLR((p)->flags, f)
113
55.0M
#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
39.7M
#define isl_alloc(ctx,type,size)  ((type *)isl_malloc_or_die(ctx, size))
120
8.28M
#define isl_calloc(ctx,type,size) ((type *)isl_calloc_or_die(ctx,\
121
8.28M
                    1, size))
122
1.25M
#define isl_realloc(ctx,ptr,type,size)  ((type *)isl_realloc_or_die(ctx,\
123
1.25M
                    ptr, size))
124
19.6M
#define isl_alloc_type(ctx,type)  isl_alloc(ctx,type,sizeof(type))
125
6.61M
#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
18.9M
#define isl_alloc_array(ctx,type,n) isl_alloc(ctx,type,(n)*sizeof(type))
128
6.04M
#define isl_calloc_array(ctx,type,n)  ((type *)isl_calloc_or_die(ctx,\
129
6.04M
                  n, sizeof(type)))
130
#define isl_realloc_array(ctx,ptr,type,n) \
131
1.23M
            isl_realloc(ctx,ptr,type,(n)*sizeof(type))
132
133
#define isl_die(ctx,errno,msg,code)         \
134
48
  do {               \
135
48
    isl_handle_error(ctx, errno, msg, __FILE__, __LINE__);  \
136
48
    code;             \
137
48
  } while (
00
)
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
198M
  do {               \
144
178M
    if (test)           \
145
178M
      break;           \
146
178M
    
isl_die0
(ctx, errno, "Assertion \"" #test "\" failed", code); \
147
0
  } while (0)
148
#define isl_assert(ctx,test,code)         \
149
178M
  isl_assert4(ctx,test,code,isl_error_unknown)
150
151
25.1M
#define isl_min(a,b)      ((a < b) ? 
(a)0
: (b))
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
35.9k
st *isl_ctx_peek_ ## prefix(isl_ctx *ctx)       \
179
35.9k
{                 \
180
35.9k
  return (st *)isl_ctx_peek_options(ctx, &(args));    \
181
35.9k
}
182
183
#define ISL_CTX_GET_INT_DEF(prefix,st,args,field)     \
184
30.8k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
30.8k
{                 \
186
30.8k
  st *options;              \
187
30.8k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
30.8k
  if (!options)             \
189
30.8k
    
isl_die0
(ctx, isl_error_invalid,        \
190
30.8k
      "isl_ctx does not reference " #prefix,    \
191
30.8k
      return -1);         \
192
30.8k
  return options->field;           \
193
30.8k
}
Unexecuted instantiation: isl_options_get_bound
isl_options_get_on_error
Line
Count
Source
184
1.16k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.16k
{                 \
186
1.16k
  st *options;              \
187
1.16k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.16k
  if (!options)             \
189
1.16k
    
isl_die0
(ctx, isl_error_invalid,        \
190
1.16k
      "isl_ctx does not reference " #prefix,    \
191
1.16k
      return -1);         \
192
1.16k
  return options->field;           \
193
1.16k
}
Unexecuted instantiation: isl_options_get_pip_symmetry
isl_options_get_coalesce_bounded_wrapping
Line
Count
Source
184
3.66k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
3.66k
{                 \
186
3.66k
  st *options;              \
187
3.66k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
3.66k
  if (!options)             \
189
3.66k
    
isl_die0
(ctx, isl_error_invalid,        \
190
3.66k
      "isl_ctx does not reference " #prefix,    \
191
3.66k
      return -1);         \
192
3.66k
  return options->field;           \
193
3.66k
}
Unexecuted instantiation: isl_options_get_gbr_only_first
isl_options_get_schedule_max_coefficient
Line
Count
Source
184
1.07k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.07k
{                 \
186
1.07k
  st *options;              \
187
1.07k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.07k
  if (!options)             \
189
1.07k
    
isl_die0
(ctx, isl_error_invalid,        \
190
1.07k
      "isl_ctx does not reference " #prefix,    \
191
1.07k
      return -1);         \
192
1.07k
  return options->field;           \
193
1.07k
}
isl_options_get_schedule_max_constant_term
Line
Count
Source
184
814
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
814
{                 \
186
814
  st *options;              \
187
814
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
814
  if (!options)             \
189
814
    
isl_die0
(ctx, isl_error_invalid,        \
190
814
      "isl_ctx does not reference " #prefix,    \
191
814
      return -1);         \
192
814
  return options->field;           \
193
814
}
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
18
    
isl_die0
(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
20
    
isl_die0
(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.55k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
1.55k
{                 \
186
1.55k
  st *options;              \
187
1.55k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
1.55k
  if (!options)             \
189
1.55k
    
isl_die0
(ctx, isl_error_invalid,        \
190
1.55k
      "isl_ctx does not reference " #prefix,    \
191
1.55k
      return -1);         \
192
1.55k
  return options->field;           \
193
1.55k
}
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
10
    
isl_die0
(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
41
    
isl_die0
(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
16
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
16
{                 \
186
16
  st *options;              \
187
16
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
16
  if (!options)             \
189
16
    
isl_die0
(ctx, isl_error_invalid,        \
190
16
      "isl_ctx does not reference " #prefix,    \
191
16
      return -1);         \
192
16
  return options->field;           \
193
16
}
Unexecuted instantiation: isl_options_get_schedule_algorithm
isl_options_get_schedule_carry_self_first
Line
Count
Source
184
14
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
14
{                 \
186
14
  st *options;              \
187
14
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
14
  if (!options)             \
189
14
    
isl_die0
(ctx, isl_error_invalid,        \
190
14
      "isl_ctx does not reference " #prefix,    \
191
14
      return -1);         \
192
14
  return options->field;           \
193
14
}
isl_options_get_schedule_serialize_sccs
Line
Count
Source
184
165
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
165
{                 \
186
165
  st *options;              \
187
165
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
165
  if (!options)             \
189
165
    
isl_die0
(ctx, isl_error_invalid,        \
190
165
      "isl_ctx does not reference " #prefix,    \
191
165
      return -1);         \
192
165
  return options->field;           \
193
165
}
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
151
    
isl_die0
(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
77
    
isl_die0
(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
698
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
698
{                 \
186
698
  st *options;              \
187
698
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
698
  if (!options)             \
189
698
    
isl_die0
(ctx, isl_error_invalid,        \
190
698
      "isl_ctx does not reference " #prefix,    \
191
698
      return -1);         \
192
698
  return options->field;           \
193
698
}
isl_options_get_ast_build_prefer_pdiv
Line
Count
Source
184
8.61k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
8.61k
{                 \
186
8.61k
  st *options;              \
187
8.61k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
8.61k
  if (!options)             \
189
8.61k
    
isl_die0
(ctx, isl_error_invalid,        \
190
8.61k
      "isl_ctx does not reference " #prefix,    \
191
8.61k
      return -1);         \
192
8.61k
  return options->field;           \
193
8.61k
}
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
55
    
isl_die0
(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
3.85k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
3.85k
{                 \
186
3.85k
  st *options;              \
187
3.85k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
3.85k
  if (!options)             \
189
3.85k
    
isl_die0
(ctx, isl_error_invalid,        \
190
3.85k
      "isl_ctx does not reference " #prefix,    \
191
3.85k
      return -1);         \
192
3.85k
  return options->field;           \
193
3.85k
}
isl_options_get_ast_build_group_coscheduled
Line
Count
Source
184
98
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
98
{                 \
186
98
  st *options;              \
187
98
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
98
  if (!options)             \
189
98
    
isl_die0
(ctx, isl_error_invalid,        \
190
98
      "isl_ctx does not reference " #prefix,    \
191
98
      return -1);         \
192
98
  return options->field;           \
193
98
}
isl_options_get_ast_always_print_block
Line
Count
Source
184
336
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
336
{                 \
186
336
  st *options;              \
187
336
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
336
  if (!options)             \
189
336
    
isl_die0
(ctx, isl_error_invalid,        \
190
336
      "isl_ctx does not reference " #prefix,    \
191
336
      return -1);         \
192
336
  return options->field;           \
193
336
}
Unexecuted instantiation: isl_options_get_ast_print_macro_once
isl_options_get_ast_build_separation_bounds
Line
Count
Source
184
24
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
24
{                 \
186
24
  st *options;              \
187
24
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
24
  if (!options)             \
189
24
    
isl_die0
(ctx, isl_error_invalid,        \
190
24
      "isl_ctx does not reference " #prefix,    \
191
24
      return -1);         \
192
24
  return options->field;           \
193
24
}
isl_options_get_ast_build_scale_strides
Line
Count
Source
184
3.85k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
3.85k
{                 \
186
3.85k
  st *options;              \
187
3.85k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
3.85k
  if (!options)             \
189
3.85k
    
isl_die0
(ctx, isl_error_invalid,        \
190
3.85k
      "isl_ctx does not reference " #prefix,    \
191
3.85k
      return -1);         \
192
3.85k
  return options->field;           \
193
3.85k
}
isl_options_get_ast_build_allow_else
Line
Count
Source
184
4.34k
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
4.34k
{                 \
186
4.34k
  st *options;              \
187
4.34k
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
4.34k
  if (!options)             \
189
4.34k
    
isl_die0
(ctx, isl_error_invalid,        \
190
4.34k
      "isl_ctx does not reference " #prefix,    \
191
4.34k
      return -1);         \
192
4.34k
  return options->field;           \
193
4.34k
}
isl_options_get_ast_build_allow_or
Line
Count
Source
184
195
int prefix ## _get_ ## field(isl_ctx *ctx)        \
185
195
{                 \
186
195
  st *options;              \
187
195
  options = isl_ctx_peek_ ## prefix(ctx);       \
188
195
  if (!options)             \
189
195
    
isl_die0
(ctx, isl_error_invalid,        \
190
195
      "isl_ctx does not reference " #prefix,    \
191
195
      return -1);         \
192
195
  return options->field;           \
193
195
}
194
195
#define ISL_CTX_SET_INT_DEF(prefix,st,args,field)     \
196
4.67k
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
4.67k
{                 \
198
4.67k
  st *options;              \
199
4.67k
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
4.67k
  if (!options)             \
201
4.67k
    
isl_die0
(ctx, isl_error_invalid,        \
202
4.67k
      "isl_ctx does not reference " #prefix,    \
203
4.67k
      return isl_stat_error);       \
204
4.67k
  options->field = val;           \
205
4.67k
  return isl_stat_ok;           \
206
4.67k
}
Unexecuted instantiation: isl_options_set_bound
isl_options_set_on_error
Line
Count
Source
196
3.50k
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
3.50k
{                 \
198
3.50k
  st *options;              \
199
3.50k
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
3.50k
  if (!options)             \
201
3.50k
    
isl_die0
(ctx, isl_error_invalid,        \
202
3.50k
      "isl_ctx does not reference " #prefix,    \
203
3.50k
      return isl_stat_error);       \
204
3.50k
  options->field = val;           \
205
3.50k
  return isl_stat_ok;           \
206
3.50k
}
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
2
    
isl_die0
(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
45
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
45
{                 \
198
45
  st *options;              \
199
45
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
45
  if (!options)             \
201
45
    
isl_die0
(ctx, isl_error_invalid,        \
202
45
      "isl_ctx does not reference " #prefix,    \
203
45
      return isl_stat_error);       \
204
45
  options->field = val;           \
205
45
  return isl_stat_ok;           \
206
45
}
isl_options_set_schedule_max_constant_term
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
41
    
isl_die0
(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
}
isl_options_set_schedule_maximize_band_depth
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
39
    
isl_die0
(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_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
4
    
isl_die0
(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
8
    
isl_die0
(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
4
    
isl_die0
(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
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
43
    
isl_die0
(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
}
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
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
39
    
isl_die0
(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_tile_scale_tile_loops
Line
Count
Source
196
44
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
44
{                 \
198
44
  st *options;              \
199
44
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
44
  if (!options)             \
201
44
    
isl_die0
(ctx, isl_error_invalid,        \
202
44
      "isl_ctx does not reference " #prefix,    \
203
44
      return isl_stat_error);       \
204
44
  options->field = val;           \
205
44
  return isl_stat_ok;           \
206
44
}
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
5
    
isl_die0
(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
443
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
443
{                 \
198
443
  st *options;              \
199
443
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
443
  if (!options)             \
201
443
    
isl_die0
(ctx, isl_error_invalid,        \
202
443
      "isl_ctx does not reference " #prefix,    \
203
443
      return isl_stat_error);       \
204
443
  options->field = val;           \
205
443
  return isl_stat_ok;           \
206
443
}
Unexecuted instantiation: isl_options_set_ast_build_prefer_pdiv
isl_options_set_ast_build_detect_min_max
Line
Count
Source
196
445
isl_stat prefix ## _set_ ## field(isl_ctx *ctx, int val)    \
197
445
{                 \
198
445
  st *options;              \
199
445
  options = isl_ctx_peek_ ## prefix(ctx);       \
200
445
  if (!options)             \
201
445
    
isl_die0
(ctx, isl_error_invalid,        \
202
445
      "isl_ctx does not reference " #prefix,    \
203
445
      return isl_stat_error);       \
204
445
  options->field = val;           \
205
445
  return isl_stat_ok;           \
206
445
}
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
3
    
isl_die0
(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
390
const char *prefix ## _get_ ## field(isl_ctx *ctx)      \
210
390
{                 \
211
390
  st *options;              \
212
390
  options = isl_ctx_peek_ ## prefix(ctx);       \
213
390
  if (!options)             \
214
390
    
isl_die0
(ctx, isl_error_invalid,        \
215
390
      "isl_ctx does not reference " #prefix,    \
216
390
      return NULL);         \
217
390
  return options->field;           \
218
390
}
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 (!val)             \
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