summaryrefslogtreecommitdiffstats
path: root/include/private
diff options
context:
space:
mode:
authorMathias Agopian <mathias@google.com>2010-05-17 17:27:26 -0700
committerMathias Agopian <mathias@google.com>2010-05-17 17:27:26 -0700
commitcd30f4f849bb215509bd2645726048271b5db01e (patch)
tree6182174b30879d9bbee5532faa2b098b9c81715c /include/private
parentc5859388bd6c666a83017869bf8a9935defe0bd0 (diff)
downloadframeworks_base-cd30f4f849bb215509bd2645726048271b5db01e.zip
frameworks_base-cd30f4f849bb215509bd2645726048271b5db01e.tar.gz
frameworks_base-cd30f4f849bb215509bd2645726048271b5db01e.tar.bz2
fix some bugs in SharedBufferStack::resize
added buffers should now be labeled properly. Change-Id: I28aa753fbe89ab89134e7753575319478934c7fa
Diffstat (limited to 'include/private')
-rw-r--r--include/private/surfaceflinger/SharedBufferStack.h9
1 files changed, 5 insertions, 4 deletions
diff --git a/include/private/surfaceflinger/SharedBufferStack.h b/include/private/surfaceflinger/SharedBufferStack.h
index c23832d..a1a02e0 100644
--- a/include/private/surfaceflinger/SharedBufferStack.h
+++ b/include/private/surfaceflinger/SharedBufferStack.h
@@ -295,7 +295,8 @@ private:
friend class BufferList;
uint32_t mask, curr;
const_iterator(uint32_t mask) :
- mask(mask), curr(31 - __builtin_clz(mask)) { }
+ mask(mask), curr(__builtin_clz(mask)) {
+ }
public:
inline bool operator == (const const_iterator& rhs) const {
return mask == rhs.mask;
@@ -304,9 +305,9 @@ private:
return mask != rhs.mask;
}
inline int operator *() const { return curr; }
- inline const const_iterator& operator ++(int) {
- mask &= ~curr;
- curr = 31 - __builtin_clz(mask);
+ inline const const_iterator& operator ++() {
+ mask &= ~(1<<(31-curr));
+ curr = __builtin_clz(mask);
return *this;
}
};