diff options
| author | Andres Freund | 2018-03-22 18:45:07 +0000 |
|---|---|---|
| committer | Andres Freund | 2018-03-22 18:51:58 +0000 |
| commit | cc415a56d09a8da7c919088036b6097b70f10791 (patch) | |
| tree | b99cb7e66041f8533dc63c4a689cbf3f03956957 /src/backend/jit/jit.c | |
| parent | 7ec0d80c0508eae35ac8e19d041f9ba1276de08e (diff) | |
Basic planner and executor integration for JIT.
This adds simple cost based plan time decision about whether JIT
should be performed. jit_above_cost, jit_optimize_above_cost are
compared with the total cost of a plan, and if the cost is above them
JIT is performed / optimization is performed respectively.
For that PlannedStmt and EState have a jitFlags (es_jit_flags) field
that stores information about what JIT operations should be performed.
EState now also has a new es_jit field, which can store a
JitContext. When there are no errors the context is released in
standard_ExecutorEnd().
It is likely that the default values for jit_[optimize_]above_cost
will need to be adapted further, but in my test these values seem to
work reasonably.
Author: Andres Freund, with feedback by Peter Eisentraut
Discussion: https://postgr.es/m/[email protected]
Diffstat (limited to 'src/backend/jit/jit.c')
| -rw-r--r-- | src/backend/jit/jit.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/src/backend/jit/jit.c b/src/backend/jit/jit.c index c17df1c985e..1d74ec8c91a 100644 --- a/src/backend/jit/jit.c +++ b/src/backend/jit/jit.c @@ -36,6 +36,8 @@ char *jit_provider = "llvmjit"; bool jit_debugging_support = false; bool jit_dump_bitcode = false; bool jit_profiling_support = false; +double jit_above_cost = 100000; +double jit_optimize_above_cost = 500000; static JitProviderCallbacks provider; static bool provider_successfully_loaded = false; |
