diff options
| author | 2018-10-16 14:24:51 +0000 | |
|---|---|---|
| committer | 2018-10-16 14:24:51 +0000 | |
| commit | 8677e4bd3a091588c3b8058439f7022edab57f6e (patch) | |
| tree | e3e7bf9fdcc3676e256397a33825d6f67095c7e7 /compiler/optimizing/nodes.h | |
| parent | 4c8d22fa559e248490544e2bd7309b4b1014e972 (diff) | |
| parent | b546163926889130354ccdbcccb80c0331c13f3c (diff) | |
Merge "Fix HNewArray with unresolved primitive array type."
Diffstat (limited to 'compiler/optimizing/nodes.h')
| -rw-r--r-- | compiler/optimizing/nodes.h | 16 | 
1 files changed, 15 insertions, 1 deletions
| diff --git a/compiler/optimizing/nodes.h b/compiler/optimizing/nodes.h index 97b50d36da..6ebe89eae1 100644 --- a/compiler/optimizing/nodes.h +++ b/compiler/optimizing/nodes.h @@ -4849,10 +4849,11 @@ class HNeg final : public HUnaryOperation {  class HNewArray final : public HExpression<2> {   public: -  HNewArray(HInstruction* cls, HInstruction* length, uint32_t dex_pc) +  HNewArray(HInstruction* cls, HInstruction* length, uint32_t dex_pc, size_t component_size_shift)        : HExpression(kNewArray, DataType::Type::kReference, SideEffects::CanTriggerGC(), dex_pc) {      SetRawInputAt(0, cls);      SetRawInputAt(1, length); +    SetPackedField<ComponentSizeShiftField>(component_size_shift);    }    bool IsClonable() const override { return true; } @@ -4874,10 +4875,23 @@ class HNewArray final : public HExpression<2> {      return InputAt(1);    } +  size_t GetComponentSizeShift() { +    return GetPackedField<ComponentSizeShiftField>(); +  } +    DECLARE_INSTRUCTION(NewArray);   protected:    DEFAULT_COPY_CONSTRUCTOR(NewArray); + + private: +  static constexpr size_t kFieldComponentSizeShift = kNumberOfGenericPackedBits; +  static constexpr size_t kFieldComponentSizeShiftSize = MinimumBitsToStore(3u); +  static constexpr size_t kNumberOfNewArrayPackedBits = +      kFieldComponentSizeShift + kFieldComponentSizeShiftSize; +  static_assert(kNumberOfNewArrayPackedBits <= kMaxNumberOfPackedBits, "Too many packed fields."); +  using ComponentSizeShiftField = +      BitField<size_t, kFieldComponentSizeShift, kFieldComponentSizeShift>;  };  class HAdd final : public HBinaryOperation { |