summaryrefslogtreecommitdiffstats
path: root/libs/rs/rsLocklessFifo.cpp
diff options
context:
space:
mode:
authorJason Sams <rjsams@android.com>2011-01-18 18:12:26 -0800
committerJason Sams <rjsams@android.com>2011-01-18 18:12:26 -0800
commitd1ac98149737299513da1357e36f68cbb6d74425 (patch)
treed59875cb9ab74b735cd2d417d42020d1a5b5158e /libs/rs/rsLocklessFifo.cpp
parent991040c8261237997915f8a4c899a6ea5012fb42 (diff)
downloadframeworks_base-d1ac98149737299513da1357e36f68cbb6d74425.zip
frameworks_base-d1ac98149737299513da1357e36f68cbb6d74425.tar.gz
frameworks_base-d1ac98149737299513da1357e36f68cbb6d74425.tar.bz2
Fix race condition between GC thread and
the teardown of RS. The RS context was going away while the objects were being deleted within the finializer. Add more debugging for playCoreCommands. Change-Id: I391f0b4db948f43f54017b47b062ab47d6a1ef64
Diffstat (limited to 'libs/rs/rsLocklessFifo.cpp')
-rw-r--r--libs/rs/rsLocklessFifo.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/libs/rs/rsLocklessFifo.cpp b/libs/rs/rsLocklessFifo.cpp
index 804c767..eb2af1c 100644
--- a/libs/rs/rsLocklessFifo.cpp
+++ b/libs/rs/rsLocklessFifo.cpp
@@ -210,3 +210,19 @@ void LocklessCommandFifo::makeSpace(uint32_t bytes) {
void LocklessCommandFifo::dumpState(const char *s) const {
LOGV("%s %p put %p, get %p, buf %p, end %p", s, this, mPut, mGet, mBuffer, mEnd);
}
+
+void LocklessCommandFifo::printDebugData() const {
+ dumpState("printing fifo debug");
+ const uint32_t *pptr = (const uint32_t *)mGet;
+ pptr -= 8 * 4;
+ if (mGet < mBuffer) {
+ pptr = (const uint32_t *)mBuffer;
+ }
+
+
+ for (int ct=0; ct < 16; ct++) {
+ LOGV("fifo %p = 0x%08x 0x%08x 0x%08x 0x%08x", pptr, pptr[0], pptr[1], pptr[2], pptr[3]);
+ pptr += 4;
+ }
+
+}