blob: 20d8a39d1c5aeebe85d52c7e067a2b802e976605 [file] [log] [blame]
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001// Copyright 2014 the V8 project authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef V8_COMPILER_SIMPLIFIED_OPERATOR_H_
6#define V8_COMPILER_SIMPLIFIED_OPERATOR_H_
7
Emily Bernierd0a1eb72015-03-24 16:35:39 -04008#include <iosfwd>
9
Ben Murdochb8a8cc12014-11-26 15:28:44 +000010#include "src/handles.h"
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000011#include "src/machine-type.h"
12#include "src/objects.h"
Ben Murdochb8a8cc12014-11-26 15:28:44 +000013
14namespace v8 {
15namespace internal {
16
17// Forward declarations.
Ben Murdoch097c5b22016-05-18 11:27:45 +010018class Type;
Ben Murdochb8a8cc12014-11-26 15:28:44 +000019class Zone;
20
21
22namespace compiler {
23
24// Forward declarations.
25class Operator;
Emily Bernierd0a1eb72015-03-24 16:35:39 -040026struct SimplifiedOperatorGlobalCache;
Ben Murdochb8a8cc12014-11-26 15:28:44 +000027
Ben Murdochc5610432016-08-08 18:44:38 +010028enum BaseTaggedness : uint8_t { kUntaggedBase, kTaggedBase };
Ben Murdochb8a8cc12014-11-26 15:28:44 +000029
Ben Murdochc5610432016-08-08 18:44:38 +010030size_t hash_value(BaseTaggedness);
Ben Murdochb8a8cc12014-11-26 15:28:44 +000031
Emily Bernierd0a1eb72015-03-24 16:35:39 -040032std::ostream& operator<<(std::ostream&, BaseTaggedness);
33
34
35// An access descriptor for loads/stores of array buffers.
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000036class BufferAccess final {
Emily Bernierd0a1eb72015-03-24 16:35:39 -040037 public:
38 explicit BufferAccess(ExternalArrayType external_array_type)
39 : external_array_type_(external_array_type) {}
40
41 ExternalArrayType external_array_type() const { return external_array_type_; }
42 MachineType machine_type() const;
43
44 private:
45 ExternalArrayType const external_array_type_;
46};
47
48bool operator==(BufferAccess, BufferAccess);
49bool operator!=(BufferAccess, BufferAccess);
50
51size_t hash_value(BufferAccess);
52
53std::ostream& operator<<(std::ostream&, BufferAccess);
54
55BufferAccess const BufferAccessOf(const Operator* op) WARN_UNUSED_RESULT;
56
Ben Murdochb8a8cc12014-11-26 15:28:44 +000057
58// An access descriptor for loads/stores of fixed structures like field
59// accesses of heap objects. Accesses from either tagged or untagged base
60// pointers are supported; untagging is done automatically during lowering.
61struct FieldAccess {
62 BaseTaggedness base_is_tagged; // specifies if the base pointer is tagged.
63 int offset; // offset of the field, without tag.
Emily Bernierd0a1eb72015-03-24 16:35:39 -040064 MaybeHandle<Name> name; // debugging only.
Ben Murdochb8a8cc12014-11-26 15:28:44 +000065 Type* type; // type of the field.
66 MachineType machine_type; // machine type of the field.
Ben Murdochc5610432016-08-08 18:44:38 +010067 WriteBarrierKind write_barrier_kind; // write barrier hint.
Ben Murdochb8a8cc12014-11-26 15:28:44 +000068
69 int tag() const { return base_is_tagged == kTaggedBase ? kHeapObjectTag : 0; }
70};
71
Emily Bernierd0a1eb72015-03-24 16:35:39 -040072bool operator==(FieldAccess const&, FieldAccess const&);
73bool operator!=(FieldAccess const&, FieldAccess const&);
74
75size_t hash_value(FieldAccess const&);
76
77std::ostream& operator<<(std::ostream&, FieldAccess const&);
78
79FieldAccess const& FieldAccessOf(const Operator* op) WARN_UNUSED_RESULT;
80
Ben Murdochb8a8cc12014-11-26 15:28:44 +000081
82// An access descriptor for loads/stores of indexed structures like characters
83// in strings or off-heap backing stores. Accesses from either tagged or
84// untagged base pointers are supported; untagging is done automatically during
85// lowering.
86struct ElementAccess {
87 BaseTaggedness base_is_tagged; // specifies if the base pointer is tagged.
88 int header_size; // size of the header, without tag.
89 Type* type; // type of the element.
90 MachineType machine_type; // machine type of the element.
Ben Murdochc5610432016-08-08 18:44:38 +010091 WriteBarrierKind write_barrier_kind; // write barrier hint.
Ben Murdochb8a8cc12014-11-26 15:28:44 +000092
93 int tag() const { return base_is_tagged == kTaggedBase ? kHeapObjectTag : 0; }
94};
95
Emily Bernierd0a1eb72015-03-24 16:35:39 -040096bool operator==(ElementAccess const&, ElementAccess const&);
97bool operator!=(ElementAccess const&, ElementAccess const&);
Ben Murdochb8a8cc12014-11-26 15:28:44 +000098
Emily Bernierd0a1eb72015-03-24 16:35:39 -040099size_t hash_value(ElementAccess const&);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000100
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400101std::ostream& operator<<(std::ostream&, ElementAccess const&);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000102
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400103ElementAccess const& ElementAccessOf(const Operator* op) WARN_UNUSED_RESULT;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000104
Ben Murdochc5610432016-08-08 18:44:38 +0100105Type* TypeOf(const Operator* op) WARN_UNUSED_RESULT;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000106
107// Interface for building simplified operators, which represent the
108// medium-level operations of V8, including adding numbers, allocating objects,
109// indexing into objects and arrays, etc.
110// All operators are typed but many are representation independent.
111
112// Number values from JS can be in one of these representations:
113// - Tagged: word-sized integer that is either
114// - a signed small integer (31 or 32 bits plus a tag)
115// - a tagged pointer to a HeapNumber object that has a float64 field
116// - Int32: an untagged signed 32-bit integer
117// - Uint32: an untagged unsigned 32-bit integer
118// - Float64: an untagged float64
119
120// Additional representations for intermediate code or non-JS code:
121// - Int64: an untagged signed 64-bit integer
122// - Uint64: an untagged unsigned 64-bit integer
123// - Float32: an untagged float32
124
125// Boolean values can be:
126// - Bool: a tagged pointer to either the canonical JS #false or
127// the canonical JS #true object
128// - Bit: an untagged integer 0 or 1, but word-sized
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000129class SimplifiedOperatorBuilder final : public ZoneObject {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000130 public:
131 explicit SimplifiedOperatorBuilder(Zone* zone);
132
133 const Operator* BooleanNot();
134 const Operator* BooleanToNumber();
135
136 const Operator* NumberEqual();
137 const Operator* NumberLessThan();
138 const Operator* NumberLessThanOrEqual();
139 const Operator* NumberAdd();
140 const Operator* NumberSubtract();
141 const Operator* NumberMultiply();
142 const Operator* NumberDivide();
143 const Operator* NumberModulus();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000144 const Operator* NumberBitwiseOr();
145 const Operator* NumberBitwiseXor();
146 const Operator* NumberBitwiseAnd();
147 const Operator* NumberShiftLeft();
148 const Operator* NumberShiftRight();
149 const Operator* NumberShiftRightLogical();
Ben Murdochda12d292016-06-02 14:46:10 +0100150 const Operator* NumberImul();
151 const Operator* NumberClz32();
152 const Operator* NumberCeil();
153 const Operator* NumberFloor();
154 const Operator* NumberRound();
155 const Operator* NumberTrunc();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000156 const Operator* NumberToInt32();
157 const Operator* NumberToUint32();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000158 const Operator* NumberIsHoleNaN();
159
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000160 const Operator* ReferenceEqual(Type* type);
161
162 const Operator* StringEqual();
163 const Operator* StringLessThan();
164 const Operator* StringLessThanOrEqual();
Ben Murdochda12d292016-06-02 14:46:10 +0100165 const Operator* StringToNumber();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000166
Ben Murdochc5610432016-08-08 18:44:38 +0100167 const Operator* ChangeTaggedSignedToInt32();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000168 const Operator* ChangeTaggedToInt32();
169 const Operator* ChangeTaggedToUint32();
170 const Operator* ChangeTaggedToFloat64();
Ben Murdochc5610432016-08-08 18:44:38 +0100171 const Operator* ChangeInt31ToTaggedSigned();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000172 const Operator* ChangeInt32ToTagged();
173 const Operator* ChangeUint32ToTagged();
174 const Operator* ChangeFloat64ToTagged();
Ben Murdochc5610432016-08-08 18:44:38 +0100175 const Operator* ChangeTaggedToBit();
176 const Operator* ChangeBitToTagged();
177 const Operator* TruncateTaggedToWord32();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000178
Ben Murdochc5610432016-08-08 18:44:38 +0100179 const Operator* ObjectIsCallable();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000180 const Operator* ObjectIsNumber();
Ben Murdoch097c5b22016-05-18 11:27:45 +0100181 const Operator* ObjectIsReceiver();
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400182 const Operator* ObjectIsSmi();
Ben Murdochc5610432016-08-08 18:44:38 +0100183 const Operator* ObjectIsString();
Ben Murdochda12d292016-06-02 14:46:10 +0100184 const Operator* ObjectIsUndetectable();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000185
Ben Murdochc5610432016-08-08 18:44:38 +0100186 const Operator* TypeGuard(Type* type);
187
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000188 const Operator* Allocate(PretenureFlag pretenure = NOT_TENURED);
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400189
190 const Operator* LoadField(FieldAccess const&);
191 const Operator* StoreField(FieldAccess const&);
192
193 // load-buffer buffer, offset, length
194 const Operator* LoadBuffer(BufferAccess);
195
196 // store-buffer buffer, offset, length, value
197 const Operator* StoreBuffer(BufferAccess);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000198
199 // load-element [base + index], length
200 const Operator* LoadElement(ElementAccess const&);
201
202 // store-element [base + index], length, value
203 const Operator* StoreElement(ElementAccess const&);
204
205 private:
206 Zone* zone() const { return zone_; }
207
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400208 const SimplifiedOperatorGlobalCache& cache_;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000209 Zone* const zone_;
210
211 DISALLOW_COPY_AND_ASSIGN(SimplifiedOperatorBuilder);
212};
213
214} // namespace compiler
215} // namespace internal
216} // namespace v8
217
218#endif // V8_COMPILER_SIMPLIFIED_OPERATOR_H_