annotate libinterp/corefcn/jit-typeinfo.h @ 20654:b65888ec820e draft default tip gccjit

dmalcom gcc jit import
author Stefan Mahr <dac922@gmx.de>
date Fri, 27 Feb 2015 16:59:36 +0100
parents d35201e5ce5d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1 /*
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
2
19731
4197fc428c7d maint: Update copyright notices for 2015.
John W. Eaton <jwe@octave.org>
parents: 18222
diff changeset
3 Copyright (C) 2012-2015 Max Brister
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
4
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
5 This file is part of Octave.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
6
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
7 Octave is free software; you can redistribute it and/or modify it
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
9 Free Software Foundation; either version 3 of the License, or (at your
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
10 option) any later version.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
11
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
12 Octave is distributed in the hope that it will be useful, but WITHOUT
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
15 for more details.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
16
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
18 along with Octave; see the file COPYING. If not, see
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
19 <http://www.gnu.org/licenses/>.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
20
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
21 */
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
22
16768
e2de3c8882be copyright notice fixes
John W. Eaton <jwe@octave.org>
parents: 15893
diff changeset
23 // Author: Max Brister <max@2bass.com>
e2de3c8882be copyright notice fixes
John W. Eaton <jwe@octave.org>
parents: 15893
diff changeset
24
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
25 #if !defined (octave_jit_typeinfo_h)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
26 #define octave_jit_typeinfo_h 1
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
27
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
28 #ifdef HAVE_JIT
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
29
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
30 #include <map>
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
31 #include <vector>
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
32
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
33 #include "Range.h"
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
34 #include "jit-util.h"
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
35
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
36 // Defines the type system used by jit and a singleton class, jit_typeinfo, to
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
37 // manage the types.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
38 //
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
39 // FIXME:
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
40 // Operations are defined and implemented in jit_typeinfo. Eventually they
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
41 // should be moved elsewhere. (just like with octave_typeinfo)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
42
20132
1f9ed81bd173 maint: Fix spelling and grammar mistakes in docs and comments (bug #44878)
Rafael Laboissiere <rafael@laboissiere.net>
parents: 19731
diff changeset
43 // jit_range is compatible with the llvm range structure
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
44 struct
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
45 jit_range
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
46 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
47 jit_range (const Range& from) : base (from.base ()), limit (from.limit ()),
20649
d35201e5ce5d Fix compilation of jit broken by dd6345fd8a97 (bug #46191).
Rik <rik@octave.org>
parents: 20264
diff changeset
48 inc (from.inc ()), nelem (from.numel ())
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
49 { }
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
50
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
51 operator Range () const
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
52 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
53 return Range (base, limit, inc);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
54 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
55
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
56 bool all_elements_are_ints () const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
57
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
58 double base;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
59 double limit;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
60 double inc;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
61 octave_idx_type nelem;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
62 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
63
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
64 std::ostream& operator << (std::ostream& os, const jit_range& rng);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
65
20132
1f9ed81bd173 maint: Fix spelling and grammar mistakes in docs and comments (bug #44878)
Rafael Laboissiere <rafael@laboissiere.net>
parents: 19731
diff changeset
66 // jit_array is compatible with the llvm array/matrix structures
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
67 template <typename T, typename U>
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
68 struct
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
69 jit_array
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
70 {
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
71 jit_array () : array (0) { }
15370
8355fddce815 Use sret and do not use save/restore stack (bug #37308)
Max Brister <max@2bass.com>
parents: 15337
diff changeset
72
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
73 jit_array (T& from) : array (new T (from))
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
74 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
75 update ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
76 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
77
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
78 void update (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
79 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
80 ref_count = array->jit_ref_count ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
81 slice_data = array->jit_slice_data () - 1;
20264
5dfaaaae784f Deprecate Array::capacity() and Sparse::capacity() for numel() and nzmax().
Carnë Draug <carandraug@octave.org>
parents: 20132
diff changeset
82 slice_len = array->numel ();
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
83 dimensions = array->jit_dimensions ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
84 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
85
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
86 void update (T *aarray)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
87 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
88 array = aarray;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
89 update ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
90 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
91
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
92 operator T () const
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
93 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
94 return *array;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
95 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
96
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
97 int *ref_count;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
98
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
99 U *slice_data;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
100 octave_idx_type slice_len;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
101 octave_idx_type *dimensions;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
102
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
103 T *array;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
104 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
105
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
106 typedef jit_array<NDArray, double> jit_matrix;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
107
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
108 std::ostream& operator << (std::ostream& os, const jit_matrix& mat);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
109
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
110 // calling convention
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
111 namespace
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
112 jit_convention
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
113 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
114 enum
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
115 type
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
116 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
117 // internal to jit
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
118 internal,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
119
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
120 // an external C call
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
121 external,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
122
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
123 length
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
124 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
125 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
126
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
127 // Used to keep track of estimated (infered) types during JIT. This is a
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
128 // hierarchical type system which includes both concrete and abstract types.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
129 //
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
130 // The types form a lattice. Currently we only allow for one parent type, but
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
131 // eventually we may allow for multiple predecessors.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
132 class
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
133 jit_type
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
134 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
135 public:
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
136 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
137 typedef llvm::Value *(*convert_fn) (llvm::IRBuilderD&, llvm::Value *);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
138 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
139
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
140 jit_type (const std::string& aname, jit_type *aparent
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
141 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
142 , llvm::Type *allvm_type
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
143 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
144 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
145 , gccjit::type agcc_type
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
146 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
147 , bool askip_paren, int aid);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
148
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
149 // a user readable type name
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
150 const std::string& name (void) const { return mname; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
151
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
152 // a unique id for the type
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
153 int type_id (void) const { return mid; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
154
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
155 // An abstract base type, may be null
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
156 jit_type *parent (void) const { return mparent; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
157
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
158 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
159 // convert to an llvm type
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
160 llvm::Type *to_llvm (void) const { return llvm_type; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
161
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
162 // how this type gets passed as a function argument
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
163 llvm::Type *to_llvm_arg (void) const;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
164 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
165
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
166 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
167 gccjit::type to_gccjit (void) const { return gccjit_type; }
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
168 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
169
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
170 size_t depth (void) const { return mdepth; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
171
15124
0464e3ceb85b Skip functions when resolving end context in JIT
Max Brister <max@2bass.com>
parents: 15102
diff changeset
172 bool skip_paren (void) const { return mskip_paren; }
0464e3ceb85b Skip functions when resolving end context in JIT
Max Brister <max@2bass.com>
parents: 15102
diff changeset
173
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
174 // -------------------- Calling Convention information --------------------
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
175
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
176 // A function declared like: mytype foo (int arg0, int arg1);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
177 // Will be converted to: void foo (mytype *retval, int arg0, int arg1)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
178 // if mytype is sret. The caller is responsible for allocating space for
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
179 // retval. (on the stack)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
180 bool sret (jit_convention::type cc) const { return msret[cc]; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
181
15370
8355fddce815 Use sret and do not use save/restore stack (bug #37308)
Max Brister <max@2bass.com>
parents: 15337
diff changeset
182 void mark_sret (jit_convention::type cc)
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
183 { msret[cc] = true; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
184
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
185 // A function like: void foo (mytype arg0)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
186 // Will be converted to: void foo (mytype *arg0)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
187 // Basically just pass by reference.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
188 bool pointer_arg (jit_convention::type cc) const { return mpointer_arg[cc]; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
189
15370
8355fddce815 Use sret and do not use save/restore stack (bug #37308)
Max Brister <max@2bass.com>
parents: 15337
diff changeset
190 void mark_pointer_arg (jit_convention::type cc)
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
191 { mpointer_arg[cc] = true; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
192
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
193 // Convert into an equivalent form before calling. For example, complex is
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
194 // represented as two values llvm vector, but we need to pass it as a two
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
195 // valued llvm structure to C functions.
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
196 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
197 convert_fn pack (jit_convention::type cc) { return mpack[cc]; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
198
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
199 void set_pack (jit_convention::type cc, convert_fn fn) { mpack[cc] = fn; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
200
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
201 // The inverse operation of pack.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
202 convert_fn unpack (jit_convention::type cc) { return munpack[cc]; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
203
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
204 void set_unpack (jit_convention::type cc, convert_fn fn)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
205 { munpack[cc] = fn; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
206
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
207 // The resulting type after pack is called.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
208 llvm::Type *packed_type (jit_convention::type cc)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
209 { return mpacked_type[cc]; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
210
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
211 void set_packed_type (jit_convention::type cc, llvm::Type *ty)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
212 { mpacked_type[cc] = ty; }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
213 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
214
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
215 private:
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
216 std::string mname;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
217 jit_type *mparent;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
218 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
219 llvm::Type *llvm_type;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
220 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
221 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
222 gccjit::type gccjit_type;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
223 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
224 int mid;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
225 size_t mdepth;
15124
0464e3ceb85b Skip functions when resolving end context in JIT
Max Brister <max@2bass.com>
parents: 15102
diff changeset
226 bool mskip_paren;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
227
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
228 bool msret[jit_convention::length];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
229 bool mpointer_arg[jit_convention::length];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
230
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
231 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
232 convert_fn mpack[jit_convention::length];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
233 convert_fn munpack[jit_convention::length];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
234
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
235 llvm::Type *mpacked_type[jit_convention::length];
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
236 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
237 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
238 // seperate print function to allow easy printing if type is null
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
239 std::ostream& jit_print (std::ostream& os, jit_type *atype);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
240
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
241 class jit_value;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
242
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
243 // An abstraction for calling llvm functions with jit_values. Deals with
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
244 // calling convention details.
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
245 class
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
246 jit_function
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
247 {
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
248 friend std::ostream& operator << (std::ostream& os, const jit_function& fn);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
249 public:
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
250 // create a function in an invalid state
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
251 jit_function ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
252
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
253 jit_function (
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
254 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
255 llvm::Module *amodule,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
256 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
257 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
258 gccjit::context gccjit_ctxt,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
259 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
260 jit_convention::type acall_conv,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
261 std::string aname,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
262 jit_type *aresult,
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
263 const std::vector<jit_type *>& aargs);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
264
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
265 // Use an existing function, but change the argument types. The new argument
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
266 // types must behave the same for the current calling convention.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
267 jit_function (const jit_function& fn, jit_type *aresult,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
268 const std::vector<jit_type *>& aargs);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
269
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
270 jit_function (const jit_function& fn);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
271
15385
8ccb187b24e9 Erase partially created functions on JIT compilation failure (bug #37308)
Max Brister <max@2bass.com>
parents: 15370
diff changeset
272 // erase the interal LLVM function (if it exists). Will become invalid.
8ccb187b24e9 Erase partially created functions on JIT compilation failure (bug #37308)
Max Brister <max@2bass.com>
parents: 15370
diff changeset
273 void erase (void);
8ccb187b24e9 Erase partially created functions on JIT compilation failure (bug #37308)
Max Brister <max@2bass.com>
parents: 15370
diff changeset
274
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
275 #ifdef HAVE_LLVM
15019
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
276 template <typename T>
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
277 void add_mapping (llvm::ExecutionEngine *engine, T fn)
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
278 {
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
279 do_add_mapping (engine, reinterpret_cast<void *> (fn));
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
280 }
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
281
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
282 bool valid (void) const { return llvm_function; }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
283 #else
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
284 bool valid (void) const;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
285 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
286
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
287 std::string name (void) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
288
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
289 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
290 llvm::BasicBlock *new_block (const std::string& aname = "body",
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
291 llvm::BasicBlock *insert_before = 0);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
292
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
293 llvm::Value *call (llvm::IRBuilderD& builder,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
294 const std::vector<jit_value *>& in_args) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
295
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
296 llvm::Value *call (llvm::IRBuilderD& builder,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
297 const std::vector<llvm::Value *>& in_args
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
298 = std::vector<llvm::Value *> ()) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
299
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
300 #define JIT_PARAM_ARGS llvm::IRBuilderD& builder,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
301 #define JIT_PARAMS builder,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
302 #define JIT_CALL(N) JIT_EXPAND (llvm::Value *, call, llvm::Value *, const, N)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
303
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
304 JIT_CALL (1)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
305 JIT_CALL (2)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
306 JIT_CALL (3)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
307 JIT_CALL (4)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
308 JIT_CALL (5)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
309
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
310 #undef JIT_CALL
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
311
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
312 #define JIT_CALL(N) JIT_EXPAND (llvm::Value *, call, jit_value *, const, N)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
313
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
314 JIT_CALL (1);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
315 JIT_CALL (2);
15102
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
316 JIT_CALL (3);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
317
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
318 #undef JIT_CALL
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
319 #undef JIT_PARAMS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
320 #undef JIT_PARAM_ARGS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
321
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
322 llvm::Value *argument (llvm::IRBuilderD& builder, size_t idx) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
323
15370
8355fddce815 Use sret and do not use save/restore stack (bug #37308)
Max Brister <max@2bass.com>
parents: 15337
diff changeset
324 void do_return (llvm::IRBuilderD& builder, llvm::Value *rval = 0,
8355fddce815 Use sret and do not use save/restore stack (bug #37308)
Max Brister <max@2bass.com>
parents: 15337
diff changeset
325 bool verify = true);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
326
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
327 llvm::Function *to_llvm (void) const { return llvm_function; }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
328 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
329
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
330 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
331 gccjit::rvalue call (gccjit::context ctxt,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
332 gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
333 const std::vector<jit_value *>& in_args) const;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
334 gccjit::rvalue call (gccjit::context ctxt,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
335 gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
336 std::vector<gccjit::rvalue>& in_args) const;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
337 gccjit::lvalue argument (size_t idx) const;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
338 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
339
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
340 // If true, then the return value is passed as a pointer in the first argument
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
341 bool sret (void) const { return mresult && mresult->sret (call_conv); }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
342
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
343 bool can_error (void) const { return mcan_error; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
344
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
345 void mark_can_error (void) { mcan_error = true; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
346
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
347 jit_type *result (void) const { return mresult; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
348
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
349 jit_type *argument_type (size_t idx) const
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
350 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
351 assert (idx < args.size ());
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
352 return args[idx];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
353 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
354
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
355 const std::vector<jit_type *>& arguments (void) const { return args; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
356 private:
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
357 #ifdef HAVE_LLVM
15019
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
358 void do_add_mapping (llvm::ExecutionEngine *engine, void *fn);
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
359
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
360 llvm::Module *module;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
361 llvm::Function *llvm_function;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
362 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
363 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
364 public:
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
365 gccjit::function gccjit_function;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
366 private:
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
367 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
368 jit_type *mresult;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
369 std::vector<jit_type *> args;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
370 jit_convention::type call_conv;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
371 bool mcan_error;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
372 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
373
17787
175b392e91fe Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents: 17744
diff changeset
374 std::ostream& operator << (std::ostream& os, const jit_function& fn);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
375
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
376
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
377 // Keeps track of information about how to implement operations (+, -, *, ect)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
378 // and their resulting types.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
379 class
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
380 jit_operation
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
381 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
382 public:
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
383 // type signature vector
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
384 typedef std::vector<jit_type *> signature_vec;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
385
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
386 virtual ~jit_operation (void);
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
387
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
388 void add_overload (const jit_function& func)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
389 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
390 add_overload (func, func.arguments ());
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
391 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
392
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
393 void add_overload (const jit_function& func,
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
394 const signature_vec& args);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
395
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
396 const jit_function& overload (const signature_vec& types) const;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
397
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
398 jit_type *result (const signature_vec& types) const
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
399 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
400 const jit_function& temp = overload (types);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
401 return temp.result ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
402 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
403
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
404 #define JIT_PARAMS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
405 #define JIT_PARAM_ARGS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
406 #define JIT_OVERLOAD(N) \
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
407 JIT_EXPAND (const jit_function&, overload, jit_type *, const, N) \
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
408 JIT_EXPAND (jit_type *, result, jit_type *, const, N)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
409
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
410 JIT_OVERLOAD (1);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
411 JIT_OVERLOAD (2);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
412 JIT_OVERLOAD (3);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
413
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
414 #undef JIT_PARAMS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
415 #undef JIT_PARAM_ARGS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
416
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
417 const std::string& name (void) const { return mname; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
418
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
419 void stash_name (const std::string& aname) { mname = aname; }
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
420 protected:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
421 virtual jit_function *generate (const signature_vec& types) const;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
422 private:
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
423 Array<octave_idx_type> to_idx (const signature_vec& types) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
424
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
425 const jit_function& do_generate (const signature_vec& types) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
426
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
427 struct signature_cmp
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
428 {
18222
4d90e104bf35 Allow jit-typeinfo.h to compile with clang on OS X (bug #41114)
Michael C. Grant <mcg@cvxr.com>
parents: 17787
diff changeset
429 bool operator() (const signature_vec *lhs, const signature_vec *rhs) const;
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
430 };
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
431
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
432 typedef std::map<const signature_vec *, jit_function *, signature_cmp>
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
433 generated_map;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
434
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
435 mutable generated_map generated;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
436
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
437 std::vector<Array<jit_function> > overloads;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
438
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
439 std::string mname;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
440 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
441
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
442 class
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
443 jit_index_operation : public jit_operation
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
444 {
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
445 public:
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
446 jit_index_operation (void) {} //: module (0), engine (0) { }
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
447
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
448 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
449 void initialize (llvm::Module *amodule, llvm::ExecutionEngine *aengine
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
450 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
451 , gccjit::context agccjit_ctxt
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
452 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
453 )
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
454
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
455 {
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
456 module = amodule;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
457 engine = aengine;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
458 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
459 gccjit_ctxt = agccjit_ctxt;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
460 #endif
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
461 do_initialize ();
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
462 }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
463 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
464
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
465 protected:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
466 virtual jit_function *generate (const signature_vec& types) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
467
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
468 virtual jit_function *generate_matrix (const signature_vec& types) const = 0;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
469
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
470 virtual void do_initialize (void) = 0;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
471
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
472 // helper functions
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
473 // [start_idx, end_idx).
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
474 #ifdef HAVE_LLVM
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
475 llvm::Value *create_arg_array (llvm::IRBuilderD& builder,
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
476 const jit_function &fn, size_t start_idx,
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
477 size_t end_idx) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
478
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
479 llvm::Module *module;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
480 llvm::ExecutionEngine *engine;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
481 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
482 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
483 gccjit::rvalue create_arg_array (const jit_function &fn,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
484 gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
485 size_t start_idx,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
486 size_t end_idx) const;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
487
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
488 gccjit::context gccjit_ctxt;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
489 #endif
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
490 };
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
491
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
492 class
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
493 jit_paren_subsref : public jit_index_operation
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
494 {
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
495 protected:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
496 virtual jit_function *generate_matrix (const signature_vec& types) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
497
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
498 virtual void do_initialize (void);
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
499 private:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
500 jit_function paren_scalar;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
501 };
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
502
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
503 class
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
504 jit_paren_subsasgn : public jit_index_operation
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
505 {
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
506 protected:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
507 jit_function *generate_matrix (const signature_vec& types) const;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
508
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
509 virtual void do_initialize (void);
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
510 private:
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
511 jit_function paren_scalar;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
512 };
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
513
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
514 // A singleton class which handles the construction of jit_types and
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
515 // jit_operations.
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
516 class
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
517 jit_typeinfo
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
518 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
519 public:
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
520 static void initialize (
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
521 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
522 llvm::Module *m, llvm::ExecutionEngine *e
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
523 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
524 );
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
525
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
526 static jit_type *join (jit_type *lhs, jit_type *rhs)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
527 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
528 return instance->do_join (lhs, rhs);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
529 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
530
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
531 static jit_type *get_any (void) { return instance->any; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
532
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
533 static jit_type *get_matrix (void) { return instance->matrix; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
534
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
535 static jit_type *get_scalar (void) { return instance->scalar; }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
536 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
537 static llvm::Type *get_scalar_llvm (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
538 { return instance->scalar->to_llvm (); }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
539 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
540 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
541 static gccjit::type get_scalar_gccjit (void)
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
542 { return instance->scalar->to_gccjit (); }
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
543 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
544
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
545 static jit_type *get_scalar_ptr (void) { return instance->scalar_ptr; }
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
546
15337
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
547 static jit_type *get_any_ptr (void) { return instance->any_ptr; }
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
548
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
549 static jit_type *get_range (void) { return instance->range; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
550
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
551 static jit_type *get_string (void) { return instance->string; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
552
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
553 static jit_type *get_bool (void) { return instance->boolean; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
554
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
555 static jit_type *get_index (void) { return instance->index; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
556
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
557 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
558 static llvm::Type *get_index_llvm (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
559 { return instance->index->to_llvm (); }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
560 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
561
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
562 static jit_type *get_complex (void) { return instance->complex; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
563
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
564 // Get the jit_type of an octave_value
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
565 static jit_type *type_of (const octave_value& ov)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
566 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
567 return instance->do_type_of (ov);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
568 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
569
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
570 static const jit_operation& binary_op (int op)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
571 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
572 return instance->do_binary_op (op);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
573 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
574
15146
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
575 static const jit_operation& unary_op (int op)
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
576 {
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
577 return instance->do_unary_op (op);
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
578 }
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
579
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
580 static const jit_operation& grab (void) { return instance->grab_fn; }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
581
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
582 static const jit_function& get_grab (jit_type *type)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
583 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
584 return instance->grab_fn.overload (type);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
585 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
586
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
587 static const jit_operation& release (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
588 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
589 return instance->release_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
590 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
591
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
592 static const jit_function& get_release (jit_type *type)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
593 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
594 return instance->release_fn.overload (type);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
595 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
596
15337
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
597 static const jit_operation& destroy (void)
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
598 {
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
599 return instance->destroy_fn;
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
600 }
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
601
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
602 static const jit_operation& print_value (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
603 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
604 return instance->print_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
605 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
606
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
607 static const jit_operation& for_init (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
608 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
609 return instance->for_init_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
610 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
611
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
612 static const jit_operation& for_check (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
613 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
614 return instance->for_check_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
615 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
616
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
617 static const jit_operation& for_index (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
618 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
619 return instance->for_index_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
620 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
621
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
622 static const jit_operation& make_range (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
623 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
624 return instance->make_range_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
625 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
626
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
627 static const jit_operation& paren_subsref (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
628 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
629 return instance->paren_subsref_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
630 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
631
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
632 static const jit_operation& paren_subsasgn (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
633 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
634 return instance->paren_subsasgn_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
635 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
636
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
637 static const jit_operation& logically_true (void)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
638 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
639 return instance->logically_true_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
640 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
641
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
642 static const jit_operation& cast (jit_type *result)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
643 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
644 return instance->do_cast (result);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
645 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
646
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
647 static const jit_function& cast (jit_type *to, jit_type *from)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
648 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
649 return instance->do_cast (to, from);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
650 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
651
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
652 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
653 static llvm::Value *insert_error_check (llvm::IRBuilderD& bld)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
654 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
655 return instance->do_insert_error_check (bld);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
656 }
15056
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
657
15603
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
658 static llvm::Value *insert_interrupt_check (llvm::IRBuilderD& bld)
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
659 {
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
660 return instance->do_insert_interrupt_check (bld);
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
661 }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
662 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
663 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
664 static gccjit::rvalue insert_error_check (gccjit::function func)
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
665 {
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
666 return instance->do_insert_error_check (func);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
667 }
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
668
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
669 static gccjit::rvalue insert_interrupt_check (gccjit::function func)
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
670 {
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
671 return instance->do_insert_interrupt_check (func);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
672 }
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
673 #endif
15603
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
674
15056
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
675 static const jit_operation& end (void)
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
676 {
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
677 return instance->end_fn;
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
678 }
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
679
15102
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
680 static const jit_function& end (jit_value *value, jit_value *index,
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
681 jit_value *count)
15056
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
682 {
15102
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
683 return instance->do_end (value, index, count);
15056
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
684 }
15337
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
685
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
686 static const jit_operation& create_undef (void)
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
687 {
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
688 return instance->create_undef_fn;
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
689 }
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
690
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
691 #ifdef HAVE_LLVM
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
692 static llvm::Value *create_complex (llvm::Value *real, llvm::Value *imag)
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
693 {
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
694 return instance->complex_new (real, imag);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
695 }
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
696 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
697
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
698 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
699 static gccjit::context create_gccjit_child_context ()
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
700 {
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
701 return instance->gccjit_ctxt.new_child_context ();
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
702 }
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
703 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
704
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
705
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
706 private:
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
707 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
708 jit_typeinfo (llvm::Module *m, llvm::ExecutionEngine *e);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
709 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
710
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
711 // FIXME: Do these methods really need to be in jit_typeinfo?
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
712 jit_type *do_join (jit_type *lhs, jit_type *rhs)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
713 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
714 // empty case
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
715 if (! lhs)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
716 return rhs;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
717
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
718 if (! rhs)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
719 return lhs;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
720
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
721 // check for a shared parent
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
722 while (lhs != rhs)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
723 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
724 if (lhs->depth () > rhs->depth ())
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
725 lhs = lhs->parent ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
726 else if (lhs->depth () < rhs->depth ())
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
727 rhs = rhs->parent ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
728 else
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
729 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
730 // we MUST have depth > 0 as any is the base type of everything
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
731 do
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
732 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
733 lhs = lhs->parent ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
734 rhs = rhs->parent ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
735 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
736 while (lhs != rhs);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
737 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
738 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
739
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
740 return lhs;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
741 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
742
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
743 jit_type *do_difference (jit_type *lhs, jit_type *)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
744 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
745 // FIXME: Maybe we can do something smarter?
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
746 return lhs;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
747 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
748
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
749 jit_type *do_type_of (const octave_value &ov) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
750
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
751 const jit_operation& do_binary_op (int op) const
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
752 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
753 assert (static_cast<size_t>(op) < binary_ops.size ());
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
754 return binary_ops[op];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
755 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
756
15146
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
757 const jit_operation& do_unary_op (int op) const
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
758 {
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
759 assert (static_cast<size_t> (op) < unary_ops.size ());
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
760 return unary_ops[op];
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
761 }
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
762
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
763 const jit_operation& do_cast (jit_type *to)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
764 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
765 static jit_operation null_function;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
766 if (! to)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
767 return null_function;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
768
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
769 size_t id = to->type_id ();
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
770 if (id >= casts.size ())
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
771 return null_function;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
772 return casts[id];
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
773 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
774
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
775 const jit_function& do_cast (jit_type *to, jit_type *from)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
776 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
777 return do_cast (to).overload (from);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
778 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
779
15102
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
780 const jit_function& do_end (jit_value *value, jit_value *index,
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
781 jit_value *count);
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
782
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
783 jit_type *new_type (const std::string& name, jit_type *parent
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
784 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
785 , llvm::Type *llvm_type
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
786 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
787 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
788 , gccjit::type gccjit_type
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
789 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
790 , bool skip_paren = false);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
791
15019
ae3670d4df29 Update the execution engine's global mapping for external functions
Max Brister <max@2bass.com>
parents: 15016
diff changeset
792 void add_print (jit_type *ty, void *fptr);
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
793
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
794 void add_binary_op (jit_type *ty, int op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
795 , int llvm_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
796 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
797 , enum gcc_jit_binary_op gccjit_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
798 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
799 );
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
800
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
801 void add_binary_icmp (jit_type *ty, int op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
802 , int llvm_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
803 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
804 , enum gcc_jit_comparison gccjit_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
805 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
806 );
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
807
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
808 void add_binary_fcmp (jit_type *ty, int op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
809 , int llvm_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
810 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
811 , enum gcc_jit_comparison gccjit_op
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
812 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
813 );
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
814
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
815 // create a function with an external calling convention
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
816 // forces the function pointer to be specified
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
817 template <typename T>
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
818 jit_function create_external (
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
819 #ifdef HAVE_LLVM
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
820 llvm::ExecutionEngine *ee,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
821 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
822 T fn,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
823 std::string name, jit_type *ret,
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
824 const std::vector<jit_type *>& args
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
825 = std::vector<jit_type *> ())
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
826 {
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
827 jit_function retval = create_function (jit_convention::external, name, ret,
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
828 args);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
829 #ifdef HAVE_LLVM
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
830 retval.add_mapping (ee, fn);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
831 #endif
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
832 return retval;
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
833 }
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
834
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
835 #ifdef HAVE_LLVM
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
836 #define JIT_PARAM_ARGS llvm::ExecutionEngine *ee, T fn, \
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
837 std::string name, jit_type *ret,
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
838 #define JIT_PARAMS ee, fn, name, ret,
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
839 #else
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
840 #define JIT_PARAM_ARGS T fn, \
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
841 std::string name, jit_type *ret,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
842 #define JIT_PARAMS fn, name, ret,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
843 #endif
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
844 #define CREATE_FUNCTION(N) JIT_EXPAND(template <typename T> jit_function, \
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
845 create_external, \
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
846 jit_type *, /* empty */, N)
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
847
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
848 CREATE_FUNCTION(1);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
849 CREATE_FUNCTION(2);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
850 CREATE_FUNCTION(3);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
851 CREATE_FUNCTION(4);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
852
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
853 #undef JIT_PARAM_ARGS
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
854 #undef JIT_PARAMS
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
855 #undef CREATE_FUNCTION
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
856
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
857 // use create_external or create_internal directly
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
858 jit_function create_function (jit_convention::type cc,
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
859 std::string name, jit_type *ret,
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
860 const std::vector<jit_type *>& args
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
861 = std::vector<jit_type *> ());
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
862
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
863 // create an internal calling convention (a function defined in llvm)
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
864 jit_function create_internal (std::string name, jit_type *ret,
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
865 const std::vector<jit_type *>& args
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
866 = std::vector<jit_type *> ())
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
867 {
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
868 return create_function (jit_convention::internal, name, ret, args);
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
869 }
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
870
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
871 #define JIT_PARAM_ARGS std::string name, jit_type *ret,
15893
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
872 #define JIT_PARAMS name, ret,
1f076c40c133 Do not use vectorized llvm commands for complex numbers
Max Brister <max@2bass.com>
parents: 15603
diff changeset
873 #define CREATE_FUNCTION(N) JIT_EXPAND(jit_function, create_internal, \
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
874 jit_type *, /* empty */, N)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
875
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
876 CREATE_FUNCTION(1);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
877 CREATE_FUNCTION(2);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
878 CREATE_FUNCTION(3);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
879 CREATE_FUNCTION(4);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
880
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
881 #undef JIT_PARAM_ARGS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
882 #undef JIT_PARAMS
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
883 #undef CREATE_FUNCTION
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
884
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
885 jit_function create_identity (jit_type *type);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
886
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
887 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
888 llvm::Value *do_insert_error_check (llvm::IRBuilderD& bld);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
889
15603
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
890 llvm::Value *do_insert_interrupt_check (llvm::IRBuilderD& bld);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
891 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
892
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
893 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
894 gccjit::rvalue do_insert_error_check (gccjit::function func);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
895
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
896 gccjit::rvalue do_insert_interrupt_check (gccjit::function func);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
897 #endif
15603
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
898
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
899 void add_builtin (const std::string& name);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
900
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
901 void register_intrinsic (const std::string& name, size_t id,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
902 jit_type *result, jit_type *arg0)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
903 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
904 std::vector<jit_type *> args (1, arg0);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
905 register_intrinsic (name, id, result, args);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
906 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
907
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
908 void register_intrinsic (const std::string& name, size_t id, jit_type *result,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
909 const std::vector<jit_type *>& args);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
910
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
911 void register_generic (const std::string& name, jit_type *result,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
912 jit_type *arg0)
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
913 {
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
914 std::vector<jit_type *> args (1, arg0);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
915 register_generic (name, result, args);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
916 }
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
917
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
918 void register_generic (const std::string& name, jit_type *result,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
919 const std::vector<jit_type *>& args);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
920
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
921 octave_builtin *find_builtin (const std::string& name);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
922
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
923 jit_function mirror_binary (const jit_function& fn);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
924
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
925 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
926 llvm::Function *wrap_complex (llvm::Function *wrap);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
927
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
928 static llvm::Value *pack_complex (llvm::IRBuilderD& bld,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
929 llvm::Value *cplx);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
930
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
931 static llvm::Value *unpack_complex (llvm::IRBuilderD& bld,
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
932 llvm::Value *result);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
933
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
934 llvm::Value *complex_real (llvm::Value *cx);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
935
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
936 llvm::Value *complex_real (llvm::Value *cx, llvm::Value *real);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
937
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
938 llvm::Value *complex_imag (llvm::Value *cx);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
939
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
940 llvm::Value *complex_imag (llvm::Value *cx, llvm::Value *imag);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
941
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
942 llvm::Value *complex_new (llvm::Value *real, llvm::Value *imag);
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
943 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
944
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
945 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
946 gccjit::rvalue complex_real (gccjit::rvalue cx);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
947
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
948 gccjit::rvalue complex_real (gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
949 gccjit::lvalue cx,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
950 gccjit::rvalue real);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
951
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
952 gccjit::rvalue complex_imag (gccjit::rvalue cx);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
953
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
954 gccjit::rvalue complex_imag (gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
955 gccjit::lvalue cx,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
956 gccjit::rvalue imag);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
957
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
958 gccjit::rvalue complex_new (gccjit::block block,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
959 gccjit::rvalue real,
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
960 gccjit::rvalue imag);
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
961 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
962
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
963 void create_int (size_t nbits);
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
964
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
965 jit_type *intN (size_t nbits) const;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
966
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
967 static jit_typeinfo *instance;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
968
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
969 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
970 llvm::Module *module;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
971 llvm::ExecutionEngine *engine;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
972 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
973 int next_id;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
974
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
975 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
976 llvm::GlobalVariable *lerror_state;
15603
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
977 llvm::GlobalVariable *loctave_interrupt_state;
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
978
44272909d926 Stop JIT on interrupt
Max Brister <max@2bass.com>
parents: 15385
diff changeset
979 llvm::Type *sig_atomic_type;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
980 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
981
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
982 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
983 gccjit::rvalue error_state_gccjit;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
984 gccjit::rvalue octave_interrupt_state_gccjit;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
985 gccjit::type sig_atomic_type_gccjit;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
986 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
987
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
988 std::vector<jit_type*> id_to_type;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
989 jit_type *any;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
990 jit_type *matrix;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
991 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
992 gccjit::field field_ref_count;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
993 gccjit::field field_slice_data;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
994 gccjit::field field_slice_len;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
995 gccjit::field field_dimensions;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
996 gccjit::field field_array;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
997 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
998 jit_type *scalar;
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
999 jit_type *scalar_ptr; // a fake type for interfacing with C++
15135
bd6bb87e2bea Support sin, cos, and exp with matrix arguments in JIT
Max Brister <max@2bass.com>
parents: 15124
diff changeset
1000 jit_type *any_ptr; // a fake type for interfacing with C++
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1001 jit_type *range;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1002 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1003 gccjit::field field_rng_base;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1004 gccjit::field field_rng_limit;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1005 gccjit::field field_rng_inc;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1006 gccjit::field field_rng_nelem;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1007 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1008 jit_type *string;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1009 jit_type *boolean;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1010 jit_type *index;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1011 jit_type *complex;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1012 jit_type *unknown_function;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1013 std::map<size_t, jit_type *> ints;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1014 std::map<std::string, jit_type *> builtins;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1015
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1016 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1017 llvm::StructType *complex_ret;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1018 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1019
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1020 std::vector<jit_operation> binary_ops;
15146
709e8928e68c Scalar unary operation support in JIT
Max Brister <max@2bass.com>
parents: 15135
diff changeset
1021 std::vector<jit_operation> unary_ops;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1022 jit_operation grab_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1023 jit_operation release_fn;
15337
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
1024 jit_operation destroy_fn;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1025 jit_operation print_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1026 jit_operation for_init_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1027 jit_operation for_check_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1028 jit_operation for_index_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1029 jit_operation logically_true_fn;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1030 jit_operation make_range_fn;
15078
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
1031 jit_paren_subsref paren_subsref_fn;
fe4752f772e2 Generate ND indexing functions on demand in JIT.
Max Brister <max@2bass.com>
parents: 15068
diff changeset
1032 jit_paren_subsasgn paren_subsasgn_fn;
15102
d29f2583cf7b Support end in multi indexing in JIT
Max Brister <max@2bass.com>
parents: 15096
diff changeset
1033 jit_operation end1_fn;
15056
bc32288f4a42 Support the end keyword for one dimentional indexing in JIT.
Max Brister <max@2bass.com>
parents: 15019
diff changeset
1034 jit_operation end_fn;
15337
3f43e9d6d86e JIT compile anonymous functions
Max Brister <max@2bass.com>
parents: 15334
diff changeset
1035 jit_operation create_undef_fn;
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1036
15135
bd6bb87e2bea Support sin, cos, and exp with matrix arguments in JIT
Max Brister <max@2bass.com>
parents: 15124
diff changeset
1037 jit_function any_call;
bd6bb87e2bea Support sin, cos, and exp with matrix arguments in JIT
Max Brister <max@2bass.com>
parents: 15124
diff changeset
1038
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1039 // type id -> cast function TO that type
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1040 std::vector<jit_operation> casts;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1041
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1042 // type id -> identity function
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1043 std::vector<jit_function> identities;
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1044
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1045 #ifdef HAVE_LLVM
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1046 llvm::IRBuilderD& builder;
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1047 #endif
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1048
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1049 #ifdef HAVE_GCCJIT
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1050 gccjit::context gccjit_ctxt;
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1051 #endif
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1052 };
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1053
20654
b65888ec820e dmalcom gcc jit import
Stefan Mahr <dac922@gmx.de>
parents: 20649
diff changeset
1054 #endif /* ifdef HAVE_JIT */
15016
005cb78e1dd1 Split pt-jit into multiple files.
Max Brister <max@2bass.com>
parents:
diff changeset
1055 #endif