typed-optimization.h 2.76 KB
Newer Older
1 2 3 4 5 6 7
// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef V8_COMPILER_TYPED_OPTIMIZATION_H_
#define V8_COMPILER_TYPED_OPTIMIZATION_H_

8
#include "src/base/compiler-specific.h"
9
#include "src/compiler/graph-reducer.h"
10
#include "src/globals.h"
11 12 13 14 15 16 17 18 19 20 21 22 23 24

namespace v8 {
namespace internal {

// Forward declarations.
class CompilationDependencies;
class Factory;
class Isolate;

namespace compiler {

// Forward declarations.
class JSGraph;
class SimplifiedOperatorBuilder;
25
class TypeCache;
26

27 28
class V8_EXPORT_PRIVATE TypedOptimization final
    : public NON_EXPORTED_BASE(AdvancedReducer) {
29 30
 public:
  TypedOptimization(Editor* editor, CompilationDependencies* dependencies,
31
                    JSGraph* jsgraph, const JSHeapBroker* js_heap_broker);
32 33
  ~TypedOptimization();

34 35
  const char* reducer_name() const override { return "TypedOptimization"; }

36 37 38
  Reduction Reduce(Node* node) final;

 private:
39
  Reduction ReduceConvertReceiver(Node* node);
40
  Reduction ReduceCheckHeapObject(Node* node);
41
  Reduction ReduceCheckMaps(Node* node);
42
  Reduction ReduceCheckNumber(Node* node);
43
  Reduction ReduceCheckString(Node* node);
44 45
  Reduction ReduceCheckEqualsInternalizedString(Node* node);
  Reduction ReduceCheckEqualsSymbol(Node* node);
46
  Reduction ReduceLoadField(Node* node);
47
  Reduction ReduceNumberFloor(Node* node);
48
  Reduction ReduceNumberRoundop(Node* node);
49
  Reduction ReduceNumberToUint8Clamped(Node* node);
50
  Reduction ReducePhi(Node* node);
51
  Reduction ReduceReferenceEqual(Node* node);
52
  Reduction ReduceStringComparison(Node* node);
53
  Reduction ReduceSameValue(Node* node);
54
  Reduction ReduceSelect(Node* node);
55
  Reduction ReduceSpeculativeToNumber(Node* node);
56
  Reduction ReduceCheckNotTaggedHole(Node* node);
57
  Reduction ReduceTypeOf(Node* node);
58
  Reduction ReduceToBoolean(Node* node);
59

60 61 62
  Reduction TryReduceStringComparisonOfStringFromSingleCharCode(
      Node* comparison, Node* from_char_code, Node* constant, bool inverted);
  Reduction TryReduceStringComparisonOfStringFromSingleCharCodeToConstant(
63 64
      Node* comparison, Handle<String> string, bool inverted);
  const Operator* NumberComparisonFor(const Operator* op);
65

66 67 68 69 70 71 72 73 74
  CompilationDependencies* dependencies() const { return dependencies_; }
  Factory* factory() const;
  Graph* graph() const;
  Isolate* isolate() const;
  JSGraph* jsgraph() const { return jsgraph_; }
  SimplifiedOperatorBuilder* simplified() const;

  CompilationDependencies* const dependencies_;
  JSGraph* const jsgraph_;
75 76
  Type const true_type_;
  Type const false_type_;
77 78 79 80 81 82 83 84 85 86
  TypeCache const& type_cache_;

  DISALLOW_COPY_AND_ASSIGN(TypedOptimization);
};

}  // namespace compiler
}  // namespace internal
}  // namespace v8

#endif  // V8_COMPILER_TYPED_OPTIMIZATION_H_