diff options
| author | 2016-05-17 16:30:10 +0100 | |
|---|---|---|
| committer | 2016-06-02 19:04:20 +0100 | |
| commit | 372f10e5b0b34e2bb6e2b79aeba6c441e14afd1f (patch) | |
| tree | 1f29c2467c8909ef0e0147f37f176caa1bcd2ccc /compiler/utils/array_ref.h | |
| parent | 1b66fdf3f33c72dfdda4d31f6f17b6a0d8607402 (diff) | |
Refactor handling of input records.
Introduce HInstruction::GetInputRecords(), a new virtual
function that returns an ArrayRef<> to all input records.
Implement all other functions dealing with input records as
wrappers around GetInputRecords(). Rewrite functions that
previously used multiple virtual calls to deal with input
records, especially in loops, to prefetch the ArrayRef<>
only once for each instruction.  Besides avoiding all the
extra calls, this also allows the compiler (clang++) to
perform additional optimizations.
This speeds up the Nexus 5 boot image compilation by ~0.5s
(4% of "Compile Dex File", 2% of dex2oat time) on AOSP ToT.
Change-Id: Id8ebe0fb9405e38d918972a11bd724146e4ca578
Diffstat (limited to 'compiler/utils/array_ref.h')
| -rw-r--r-- | compiler/utils/array_ref.h | 31 | 
1 files changed, 18 insertions, 13 deletions
| diff --git a/compiler/utils/array_ref.h b/compiler/utils/array_ref.h index 5c33639a6a..8dc9ab4a5e 100644 --- a/compiler/utils/array_ref.h +++ b/compiler/utils/array_ref.h @@ -39,9 +39,6 @@ namespace art {   */  template <typename T>  class ArrayRef { - private: -  struct tag { }; -   public:    typedef T value_type;    typedef T& reference; @@ -63,14 +60,14 @@ class ArrayRef {    template <size_t size>    explicit constexpr ArrayRef(T (&array)[size]) -    : array_(array), size_(size) { +      : array_(array), size_(size) {    } -  template <typename U, size_t size> -  explicit constexpr ArrayRef(U (&array)[size], -                              typename std::enable_if<std::is_same<T, const U>::value, tag>::type -                                  t ATTRIBUTE_UNUSED = tag()) -    : array_(array), size_(size) { +  template <typename U, +            size_t size, +            typename = typename std::enable_if<std::is_same<T, const U>::value>::type> +  explicit constexpr ArrayRef(U (&array)[size]) +      : array_(array), size_(size) {    }    constexpr ArrayRef(T* array_in, size_t size_in) @@ -165,13 +162,21 @@ class ArrayRef {    value_type* data() { return array_; }    const value_type* data() const { return array_; } -  ArrayRef SubArray(size_type pos) const { -    return SubArray(pos, size_ - pos); +  ArrayRef SubArray(size_type pos) { +    return SubArray(pos, size() - pos); +  } +  ArrayRef<const T> SubArray(size_type pos) const { +    return SubArray(pos, size() - pos); +  } +  ArrayRef SubArray(size_type pos, size_type length) { +    DCHECK_LE(pos, size()); +    DCHECK_LE(length, size() - pos); +    return ArrayRef(data() + pos, length);    } -  ArrayRef SubArray(size_type pos, size_type length) const { +  ArrayRef<const T> SubArray(size_type pos, size_type length) const {      DCHECK_LE(pos, size());      DCHECK_LE(length, size() - pos); -    return ArrayRef(array_ + pos, length); +    return ArrayRef<const T>(data() + pos, length);    }   private: |