diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-01-29 17:31:33 +0000 | 
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-01-29 17:31:33 +0000 | 
| commit | cf406756ce34fc67cf18f73f3036a4e223805da5 (patch) | |
| tree | 1a0384b245f2adf1a7efab0b6a97490fe2883bad /llvm | |
| parent | 289dcedea5403f8faa670a3c149f991a9e8f9f50 (diff) | |
| download | bcm5719-llvm-cf406756ce34fc67cf18f73f3036a4e223805da5.tar.gz bcm5719-llvm-cf406756ce34fc67cf18f73f3036a4e223805da5.zip | |
LoopVectorize: Clean up ValueMap a bit and avoid double lookups.
No intended functionality change.
llvm-svn: 173809
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Transforms/Vectorize/LoopVectorize.cpp | 22 | 
1 files changed, 12 insertions, 10 deletions
| diff --git a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp index 339f40bf6e5..16eb21ef1d5 100644 --- a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp +++ b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp @@ -223,31 +223,34 @@ private:      ValueMap(unsigned UnrollFactor) : UF(UnrollFactor) {}      /// \return True if 'Key' is saved in the Value Map. -    bool has(Value *Key) { return MapStoreage.count(Key); } +    bool has(Value *Key) const { return MapStorage.count(Key); }      /// Initializes a new entry in the map. Sets all of the vector parts to the      /// save value in 'Val'.      /// \return A reference to a vector with splat values.      VectorParts &splat(Value *Key, Value *Val) { -      MapStoreage[Key].clear(); -      MapStoreage[Key].append(UF, Val); -      return MapStoreage[Key]; +      VectorParts &Entry = MapStorage[Key]; +      Entry.assign(UF, Val); +      return Entry;      }      ///\return A reference to the value that is stored at 'Key'.      VectorParts &get(Value *Key) { -      if (!has(Key)) -        MapStoreage[Key].resize(UF); -      return MapStoreage[Key]; +      VectorParts &Entry = MapStorage[Key]; +      if (Entry.empty()) +        Entry.resize(UF); +      assert(Entry.size() == UF); +      return Entry;      } +  private:      /// The unroll factor. Each entry in the map stores this number of vector      /// elements.      unsigned UF;      /// Map storage. We use std::map and not DenseMap because insertions to a      /// dense map invalidates its iterators. -    std::map<Value*, VectorParts> MapStoreage; +    std::map<Value *, VectorParts> MapStorage;    };    /// The original loop. @@ -824,8 +827,7 @@ InnerLoopVectorizer::getVectorValue(Value *V) {    // If this scalar is unknown, assume that it is a constant or that it is    // loop invariant. Broadcast V and save the value for future uses.    Value *B = getBroadcastInstrs(V); -  WidenMap.splat(V, B); -  return WidenMap.get(V); +  return WidenMap.splat(V, B);  }  Value *InnerLoopVectorizer::reverseVector(Value *Vec) { | 

