blob: 720e8fccc497243cffd260d4218c099dd190e15f [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();
42}
43
Jason Samsf2649a92009-09-25 16:37:33 -070044void ObjectBase::dumpObj(const char *op) const
45{
46 if (mName) {
47 LOGV("%s RSobj %p, name %s, refs %i,%i from %s,%i links %p,%p,%p",
48 op, this, mName, mUserRefCount, mSysRefCount, mAllocFile, mAllocLine, mNext, mPrev, mRSC);
49 } else {
50 LOGV("%s RSobj %p, no-name, refs %i,%i from %s,%i links %p,%p,%p",
51 op, this, mUserRefCount, mSysRefCount, mAllocFile, mAllocLine, mNext, mPrev, mRSC);
52 }
53}
54
Jason Samse514b452009-09-25 14:51:22 -070055void ObjectBase::setContext(Context *rsc)
56{
57 if (mRSC) {
58 remove();
59 }
60 mRSC = rsc;
61 if (rsc) {
62 add();
63 }
Jason Sams326e0dd2009-05-22 14:03:28 -070064}
65
Jason Sams9397e302009-08-27 20:23:34 -070066void ObjectBase::incUserRef() const
Jason Sams326e0dd2009-05-22 14:03:28 -070067{
Jason Sams9397e302009-08-27 20:23:34 -070068 mUserRefCount ++;
Jason Sams992a0b72009-06-23 12:22:47 -070069 //LOGV("ObjectBase %p inc ref %i", this, mRefCount);
Jason Sams326e0dd2009-05-22 14:03:28 -070070}
71
Jason Sams9397e302009-08-27 20:23:34 -070072void ObjectBase::incSysRef() const
Jason Sams326e0dd2009-05-22 14:03:28 -070073{
Jason Sams9397e302009-08-27 20:23:34 -070074 mSysRefCount ++;
75 //LOGV("ObjectBase %p inc ref %i", this, mRefCount);
76}
77
Jason Samse514b452009-09-25 14:51:22 -070078bool ObjectBase::checkDelete() const
79{
80 if (!(mSysRefCount | mUserRefCount)) {
Jason Sams1fddd902009-09-25 15:25:00 -070081 if (mRSC && mRSC->props.mLogObjects) {
Jason Samsf2649a92009-09-25 16:37:33 -070082 dumpObj("checkDelete");
Jason Samse514b452009-09-25 14:51:22 -070083 }
84 delete this;
85 return true;
86 }
87 return false;
88}
89
90bool ObjectBase::decUserRef() const
Jason Sams9397e302009-08-27 20:23:34 -070091{
92 rsAssert(mUserRefCount > 0);
93 mUserRefCount --;
Jason Samsf2649a92009-09-25 16:37:33 -070094 //dumpObj("decUserRef");
Jason Samse514b452009-09-25 14:51:22 -070095 return checkDelete();
Jason Sams9397e302009-08-27 20:23:34 -070096}
97
Jason Samse514b452009-09-25 14:51:22 -070098bool ObjectBase::zeroUserRef() const
99{
100 mUserRefCount = 0;
Jason Samsf2649a92009-09-25 16:37:33 -0700101 //dumpObj("zeroUserRef");
Jason Samse514b452009-09-25 14:51:22 -0700102 return checkDelete();
103}
104
105bool ObjectBase::decSysRef() const
Jason Sams9397e302009-08-27 20:23:34 -0700106{
107 rsAssert(mSysRefCount > 0);
108 mSysRefCount --;
Jason Samsf2649a92009-09-25 16:37:33 -0700109 //dumpObj("decSysRef");
Jason Samse514b452009-09-25 14:51:22 -0700110 return checkDelete();
Jason Sams326e0dd2009-05-22 14:03:28 -0700111}
112
Jason Samsa0a1b6f2009-06-10 15:04:38 -0700113void ObjectBase::setName(const char *name)
114{
115 delete mName;
116 mName = NULL;
117 if (name) {
118 mName = new char[strlen(name) +1];
119 strcpy(mName, name);
120 }
121}
Jason Samsa4a54e42009-06-10 18:39:40 -0700122
123void ObjectBase::setName(const char *name, uint32_t len)
124{
125 delete mName;
126 mName = NULL;
127 if (name) {
128 mName = new char[len + 1];
129 memcpy(mName, name, len);
130 mName[len] = 0;
131 }
132}
133
Jason Samse514b452009-09-25 14:51:22 -0700134void ObjectBase::add() const
135{
136 rsAssert(!mNext);
137 rsAssert(!mPrev);
138 //LOGV("calling add rsc %p", mRSC);
139 mNext = mRSC->mObjHead;
140 if (mRSC->mObjHead) {
141 mRSC->mObjHead->mPrev = this;
142 }
143 mRSC->mObjHead = this;
144}
145
146void ObjectBase::remove() const
147{
148 //LOGV("calling remove rsc %p", mRSC);
149 if (!mRSC) {
150 rsAssert(!mPrev);
151 rsAssert(!mNext);
152 return;
153 }
154 if (mRSC->mObjHead == this) {
155 mRSC->mObjHead = mNext;
156 }
157 if (mPrev) {
158 mPrev->mNext = mNext;
159 }
160 if (mNext) {
161 mNext->mPrev = mPrev;
162 }
163 mPrev = NULL;
164 mNext = NULL;
165}
166
167void ObjectBase::zeroAllUserRef(Context *rsc)
168{
Jason Sams1fddd902009-09-25 15:25:00 -0700169 if (rsc->props.mLogObjects) {
170 LOGV("Forcing release of all outstanding user refs.");
171 }
Jason Samse514b452009-09-25 14:51:22 -0700172
173 // This operation can be slow, only to be called during context cleanup.
174 const ObjectBase * o = rsc->mObjHead;
175 while (o) {
176 //LOGE("o %p", o);
177 if (o->zeroUserRef()) {
178 // deleted the object and possibly others, restart from head.
179 o = rsc->mObjHead;
180 //LOGE("o head %p", o);
181 } else {
182 o = o->mNext;
183 //LOGE("o next %p", o);
184 }
185 }
Jason Samsf2649a92009-09-25 16:37:33 -0700186
187 if (rsc->props.mLogObjects) {
188 LOGV("Objects remaining.");
189 o = rsc->mObjHead;
190 while (o) {
191 o->dumpObj(" ");
192 o = o->mNext;
193 }
194 }
Jason Samse514b452009-09-25 14:51:22 -0700195}
196