add an internal parametric integer linear program solver
[platform/upstream/isl.git] / isl_ctx.c
1 #include "isl_ctx.h"
2 #include "isl_vec.h"
3 #ifdef ISL_POLYLIB
4 #include <polylib/polylibgmp.h>
5 #endif
6
7 struct isl_ctx *isl_ctx_alloc()
8 {
9         struct isl_ctx *ctx = NULL;
10
11         ctx = isl_calloc_type(NULL, struct isl_ctx);
12         if (!ctx)
13                 goto error;
14
15         if (isl_hash_table_init(ctx, &ctx->name_hash, 0))
16                 goto error;
17
18         ctx->stats = isl_calloc_type(ctx, struct isl_stats);
19         if (!ctx->stats)
20                 goto error;
21
22         ctx->ref = 0;
23
24         isl_int_init(ctx->one);
25         isl_int_set_si(ctx->one, 1);
26
27         isl_int_init(ctx->negone);
28         isl_int_set_si(ctx->negone, -1);
29
30         ctx->n_cached = 0;
31
32 #ifdef ISL_POLYLIB
33         ctx->MaxRays = POL_NO_DUAL | POL_INTEGER;
34 #endif
35
36         ctx->lp_solver = ISL_LP_TAB;
37         ctx->ilp_solver = ISL_ILP_GBR;
38         ctx->pip = ISL_PIP_TAB;
39
40         return ctx;
41 error:
42         free(ctx);
43         return NULL;
44 }
45
46 void isl_ctx_ref(struct isl_ctx *ctx)
47 {
48         ctx->ref++;
49 }
50
51 void isl_ctx_deref(struct isl_ctx *ctx)
52 {
53         isl_assert(ctx, ctx->ref > 0, return);
54         ctx->ref--;
55 }
56
57 void isl_ctx_free(struct isl_ctx *ctx)
58 {
59         if (!ctx)
60                 return;
61         isl_assert(ctx, ctx->ref == 0, return);
62         isl_hash_table_clear(&ctx->name_hash);
63         isl_blk_clear_cache(ctx);
64         isl_int_clear(ctx->one);
65         isl_int_clear(ctx->negone);
66         free(ctx->stats);
67         free(ctx);
68 }