| Index: src/compiler/operator.h
|
| diff --git a/src/compiler/operator.h b/src/compiler/operator.h
|
| index f87a3e4a518aad748f22b82452b56a6195274b7a..74b714b3d65e5d5aec001f860059497948ecf401 100644
|
| --- a/src/compiler/operator.h
|
| +++ b/src/compiler/operator.h
|
| @@ -49,9 +49,12 @@ class Operator : public ZoneObject {
|
| };
|
| typedef base::Flags<Property, uint8_t> Properties;
|
|
|
| - Operator(Opcode opcode, Properties properties, const char* mnemonic)
|
| - : opcode_(opcode), properties_(properties), mnemonic_(mnemonic) {}
|
| - virtual ~Operator();
|
| + // Constructor.
|
| + Operator(Opcode opcode, Properties properties, const char* mnemonic,
|
| + size_t value_in, size_t effect_in, size_t control_in,
|
| + size_t value_out, size_t effect_out, size_t control_out);
|
| +
|
| + virtual ~Operator() {}
|
|
|
| // A small integer unique to all instances of a particular kind of operator,
|
| // useful for quick matching for specific kinds of operators. For fast access
|
| @@ -65,12 +68,14 @@ class Operator : public ZoneObject {
|
| // Check if this operator equals another operator. Equivalent operators can
|
| // be merged, and nodes with equivalent operators and equivalent inputs
|
| // can be merged.
|
| - virtual bool Equals(const Operator*) const = 0;
|
| + virtual bool Equals(const Operator* that) const {
|
| + return this->opcode() == that->opcode();
|
| + }
|
|
|
| // Compute a hashcode to speed up equivalence-set checking.
|
| // Equal operators should always have equal hashcodes, and unequal operators
|
| // should have unequal hashcodes with high probability.
|
| - virtual size_t HashCode() const = 0;
|
| + virtual size_t HashCode() const { return base::hash<Opcode>()(opcode()); }
|
|
|
| // Check whether this operator has the given property.
|
| bool HasProperty(Property property) const {
|
| @@ -78,24 +83,45 @@ class Operator : public ZoneObject {
|
| }
|
|
|
| // Number of data inputs to the operator, for verifying graph structure.
|
| - virtual int InputCount() const = 0;
|
| + // TODO(titzer): convert callers to ValueInputCount();
|
| + int InputCount() const { return ValueInputCount(); }
|
|
|
| // Number of data outputs from the operator, for verifying graph structure.
|
| - virtual int OutputCount() const = 0;
|
| + // TODO(titzer): convert callers to ValueOutputCount();
|
| + int OutputCount() const { return ValueOutputCount(); }
|
|
|
| Properties properties() const { return properties_; }
|
|
|
| + // TODO(titzer): convert return values here to size_t.
|
| + int ValueInputCount() const { return value_in_; }
|
| + int EffectInputCount() const { return effect_in_; }
|
| + int ControlInputCount() const { return control_in_; }
|
| +
|
| + int ValueOutputCount() const { return value_out_; }
|
| + int EffectOutputCount() const { return effect_out_; }
|
| + int ControlOutputCount() const { return control_out_; }
|
| +
|
| + static inline size_t ZeroIfPure(Properties properties) {
|
| + return (properties & kPure) == kPure ? 0 : 1;
|
| + }
|
| +
|
| // TODO(titzer): API for input and output types, for typechecking graph.
|
| protected:
|
| // Print the full operator into the given stream, including any
|
| // static parameters. Useful for debugging and visualizing the IR.
|
| - virtual void PrintTo(std::ostream& os) const = 0; // NOLINT
|
| + virtual void PrintTo(std::ostream& os) const;
|
| friend std::ostream& operator<<(std::ostream& os, const Operator& op);
|
|
|
| private:
|
| Opcode opcode_;
|
| Properties properties_;
|
| const char* mnemonic_;
|
| + uint32_t value_in_;
|
| + uint16_t effect_in_;
|
| + uint16_t control_in_;
|
| + uint16_t value_out_;
|
| + uint8_t effect_out_;
|
| + uint8_t control_out_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(Operator);
|
| };
|
| @@ -105,42 +131,18 @@ DEFINE_OPERATORS_FOR_FLAGS(Operator::Properties)
|
| std::ostream& operator<<(std::ostream& os, const Operator& op);
|
|
|
|
|
| -// An implementation of Operator that has no static parameters. Such operators
|
| -// have just a name, an opcode, and a fixed number of inputs and outputs.
|
| -// They can represented by singletons and shared globally.
|
| -class SimpleOperator : public Operator {
|
| - public:
|
| - SimpleOperator(Opcode opcode, Properties properties, size_t input_count,
|
| - size_t output_count, const char* mnemonic);
|
| - ~SimpleOperator();
|
| -
|
| - virtual bool Equals(const Operator* that) const FINAL;
|
| - virtual size_t HashCode() const FINAL;
|
| - virtual int InputCount() const FINAL;
|
| - virtual int OutputCount() const FINAL;
|
| -
|
| - private:
|
| - virtual void PrintTo(std::ostream& os) const FINAL;
|
| -
|
| - uint8_t input_count_;
|
| - uint8_t output_count_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(SimpleOperator);
|
| -};
|
| -
|
| -
|
| // A templatized implementation of Operator that has one static parameter of
|
| // type {T}.
|
| template <typename T, typename Pred = std::equal_to<T>,
|
| typename Hash = base::hash<T>>
|
| class Operator1 : public Operator {
|
| public:
|
| - Operator1(Opcode opcode, Properties properties, int input_count,
|
| - int output_count, const char* mnemonic, T parameter,
|
| - Pred const& pred = Pred(), Hash const& hash = Hash())
|
| - : Operator(opcode, properties, mnemonic),
|
| - input_count_(input_count),
|
| - output_count_(output_count),
|
| + Operator1(Opcode opcode, Properties properties, const char* mnemonic,
|
| + size_t value_in, size_t effect_in, size_t control_in,
|
| + size_t value_out, size_t effect_out, size_t control_out,
|
| + T parameter, Pred const& pred = Pred(), Hash const& hash = Hash())
|
| + : Operator(opcode, properties, mnemonic, value_in, effect_in, control_in,
|
| + value_out, effect_out, control_out),
|
| parameter_(parameter),
|
| pred_(pred),
|
| hash_(hash) {}
|
| @@ -155,8 +157,6 @@ class Operator1 : public Operator {
|
| virtual size_t HashCode() const FINAL {
|
| return base::hash_combine(this->opcode(), this->hash_(this->parameter()));
|
| }
|
| - virtual int InputCount() const FINAL { return input_count_; }
|
| - virtual int OutputCount() const FINAL { return output_count_; }
|
| virtual void PrintParameter(std::ostream& os) const {
|
| os << "[" << this->parameter() << "]";
|
| }
|
| @@ -168,8 +168,6 @@ class Operator1 : public Operator {
|
| }
|
|
|
| private:
|
| - int const input_count_;
|
| - int const output_count_;
|
| T const parameter_;
|
| Pred const pred_;
|
| Hash const hash_;
|
|
|