blob: 05791cbf49311ec9f2b07d5f7b8a995e8ae07c85 [file] [log] [blame]
Jason Sams326e0dd2009-05-22 14:03:28 -07001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "rsObjectBase.h"
Jason Samse514b452009-09-25 14:51:22 -070018#include "rsContext.h"
Jason Sams326e0dd2009-05-22 14:03:28 -070019
20using namespace android;
21using namespace android::renderscript;
22
Jason Samse514b452009-09-25 14:51:22 -070023ObjectBase::ObjectBase(Context *rsc)
Jason Sams326e0dd2009-05-22 14:03:28 -070024{
Jason Sams9397e302009-08-27 20:23:34 -070025 mUserRefCount = 0;
26 mSysRefCount = 0;
Jason Samsa0a1b6f2009-06-10 15:04:38 -070027 mName = NULL;
Jason Samse514b452009-09-25 14:51:22 -070028 mRSC = NULL;
29 mNext = NULL;
30 mPrev = NULL;
Jason Samsf2649a92009-09-25 16:37:33 -070031 mAllocFile = __FILE__;
32 mAllocLine = __LINE__;
Jason Samse514b452009-09-25 14:51:22 -070033 setContext(rsc);
Jason Sams326e0dd2009-05-22 14:03:28 -070034}
35
36ObjectBase::~ObjectBase()
37{
Jason Samse514b452009-09-25 14:51:22 -070038 //LOGV("~ObjectBase %p ref %i,%i", this, mUserRefCount, mSysRefCount);
Jason Sams9397e302009-08-27 20:23:34 -070039 rsAssert(!mUserRefCount);
40 rsAssert(!mSysRefCount);
Jason Samse514b452009-09-25 14:51:22 -070041 remove();
Jason Samsbf3c14e2009-11-02 14:25:10 -080042 delete[] mName;
Jason Samse514b452009-09-25 14:51:22 -070043}
44
Jason Samse12c1c52009-09-27 17:50:38 -070045void ObjectBase::dumpLOGV(const char *op) const
Jason Samsf2649a92009-09-25 16:37:33 -070046{
47 if (mName) {
48 LOGV("%s RSobj %p, name %s, refs %i,%i from %s,%i links %p,%p,%p",
49 op, this, mName, mUserRefCount, mSysRefCount, mAllocFile, mAllocLine, mNext, mPrev, mRSC);
50 } else {
51 LOGV("%s RSobj %p, no-name, refs %i,%i from %s,%i links %p,%p,%p",
52 op, this, mUserRefCount, mSysRefCount, mAllocFile, mAllocLine, mNext, mPrev, mRSC);
53 }
54}
55
Jason Samse514b452009-09-25 14:51:22 -070056void ObjectBase::setContext(Context *rsc)
57{
58 if (mRSC) {
59 remove();
60 }
61 mRSC = rsc;
62 if (rsc) {
63 add();
64 }
Jason Sams326e0dd2009-05-22 14:03:28 -070065}
66
Jason Sams9397e302009-08-27 20:23:34 -070067void ObjectBase::incUserRef() const
Jason Sams326e0dd2009-05-22 14:03:28 -070068{
Jason Sams9397e302009-08-27 20:23:34 -070069 mUserRefCount ++;
Jason Sams992a0b72009-06-23 12:22:47 -070070 //LOGV("ObjectBase %p inc ref %i", this, mRefCount);
Jason Sams326e0dd2009-05-22 14:03:28 -070071}
72
Jason Sams9397e302009-08-27 20:23:34 -070073void ObjectBase::incSysRef() const
Jason Sams326e0dd2009-05-22 14:03:28 -070074{
Jason Sams9397e302009-08-27 20:23:34 -070075 mSysRefCount ++;
76 //LOGV("ObjectBase %p inc ref %i", this, mRefCount);
77}
78
Jason Samse514b452009-09-25 14:51:22 -070079bool ObjectBase::checkDelete() const
80{
81 if (!(mSysRefCount | mUserRefCount)) {
Jason Sams1fddd902009-09-25 15:25:00 -070082 if (mRSC && mRSC->props.mLogObjects) {
Jason Samse12c1c52009-09-27 17:50:38 -070083 dumpLOGV("checkDelete");
Jason Samse514b452009-09-25 14:51:22 -070084 }
85 delete this;
86 return true;
87 }
88 return false;
89}
90
91bool ObjectBase::decUserRef() const
Jason Sams9397e302009-08-27 20:23:34 -070092{
93 rsAssert(mUserRefCount > 0);
94 mUserRefCount --;
Jason Samsf2649a92009-09-25 16:37:33 -070095 //dumpObj("decUserRef");
Jason Samse514b452009-09-25 14:51:22 -070096 return checkDelete();
Jason Sams9397e302009-08-27 20:23:34 -070097}
98
Jason Samse514b452009-09-25 14:51:22 -070099bool ObjectBase::zeroUserRef() const
100{
101 mUserRefCount = 0;
Jason Samsf2649a92009-09-25 16:37:33 -0700102 //dumpObj("zeroUserRef");
Jason Samse514b452009-09-25 14:51:22 -0700103 return checkDelete();
104}
105
106bool ObjectBase::decSysRef() const
Jason Sams9397e302009-08-27 20:23:34 -0700107{
108 rsAssert(mSysRefCount > 0);
109 mSysRefCount --;
Jason Samsf2649a92009-09-25 16:37:33 -0700110 //dumpObj("decSysRef");
Jason Samse514b452009-09-25 14:51:22 -0700111 return checkDelete();
Jason Sams326e0dd2009-05-22 14:03:28 -0700112}
113
Jason Samsa0a1b6f2009-06-10 15:04:38 -0700114void ObjectBase::setName(const char *name)
115{
Jason Samse402ed32009-11-03 11:25:42 -0800116 setName(name, strlen(name));
Jason Samsa0a1b6f2009-06-10 15:04:38 -0700117}
Jason Samsa4a54e42009-06-10 18:39:40 -0700118
119void ObjectBase::setName(const char *name, uint32_t len)
120{
121 delete mName;
122 mName = NULL;
123 if (name) {
124 mName = new char[len + 1];
125 memcpy(mName, name, len);
126 mName[len] = 0;
127 }
128}
129
Jason Samse514b452009-09-25 14:51:22 -0700130void ObjectBase::add() const
131{
132 rsAssert(!mNext);
133 rsAssert(!mPrev);
134 //LOGV("calling add rsc %p", mRSC);
135 mNext = mRSC->mObjHead;
136 if (mRSC->mObjHead) {
137 mRSC->mObjHead->mPrev = this;
138 }
139 mRSC->mObjHead = this;
140}
141
142void ObjectBase::remove() const
143{
144 //LOGV("calling remove rsc %p", mRSC);
145 if (!mRSC) {
146 rsAssert(!mPrev);
147 rsAssert(!mNext);
148 return;
149 }
150 if (mRSC->mObjHead == this) {
151 mRSC->mObjHead = mNext;
152 }
153 if (mPrev) {
154 mPrev->mNext = mNext;
155 }
156 if (mNext) {
157 mNext->mPrev = mPrev;
158 }
159 mPrev = NULL;
160 mNext = NULL;
161}
162
163void ObjectBase::zeroAllUserRef(Context *rsc)
164{
Jason Sams1fddd902009-09-25 15:25:00 -0700165 if (rsc->props.mLogObjects) {
166 LOGV("Forcing release of all outstanding user refs.");
167 }
Jason Samse514b452009-09-25 14:51:22 -0700168
169 // This operation can be slow, only to be called during context cleanup.
170 const ObjectBase * o = rsc->mObjHead;
171 while (o) {
172 //LOGE("o %p", o);
173 if (o->zeroUserRef()) {
174 // deleted the object and possibly others, restart from head.
175 o = rsc->mObjHead;
176 //LOGE("o head %p", o);
177 } else {
178 o = o->mNext;
179 //LOGE("o next %p", o);
180 }
181 }
Jason Samsf2649a92009-09-25 16:37:33 -0700182
183 if (rsc->props.mLogObjects) {
184 LOGV("Objects remaining.");
185 o = rsc->mObjHead;
186 while (o) {
Jason Samse12c1c52009-09-27 17:50:38 -0700187 o->dumpLOGV(" ");
Jason Samsf2649a92009-09-25 16:37:33 -0700188 o = o->mNext;
189 }
190 }
Jason Samse514b452009-09-25 14:51:22 -0700191}
192
Jason Samsc21cf402009-11-17 17:26:46 -0800193void ObjectBase::dumpAll(Context *rsc)
194{
195 if (rsc->props.mLogObjects) {
196 LOGV("Dumping all objects");
197 const ObjectBase * o = rsc->mObjHead;
198 while (o) {
199 o->dumpLOGV(" ");
200 o = o->mNext;
201 }
202 }
203}
204