summaryrefslogtreecommitdiff
path: root/rsProgram.cpp
diff options
context:
space:
mode:
authorJason Sams <rjsams@android.com>2011-08-18 18:01:33 -0700
committerJason Sams <rjsams@android.com>2011-08-18 18:01:33 -0700
commitc7cec1e3577cc77a5a73d5bd5a82733b1b9936a1 (patch)
tree7b16f807f7f05630a96b1dbfb88676d0a889ff90 /rsProgram.cpp
parentdc314a172d48479053f258b485d7d0284b5b5b1f (diff)
Fix issue with freeing allocation with circular references.
Change-Id: I45871c20a192815eafee77f95e17a025f6dcf9d1
Diffstat (limited to 'rsProgram.cpp')
-rw-r--r--rsProgram.cpp21
1 files changed, 13 insertions, 8 deletions
diff --git a/rsProgram.cpp b/rsProgram.cpp
index 33eb422e..4178aa5b 100644
--- a/rsProgram.cpp
+++ b/rsProgram.cpp
@@ -70,15 +70,8 @@ Program::Program(Context *rsc, const char * shaderText, uint32_t shaderLength,
}
Program::~Program() {
+ freeChildren();
- for (uint32_t ct=0; ct < mHal.state.constantsCount; ct++) {
- bindAllocation(NULL, NULL, ct);
- }
-
- for (uint32_t ct=0; ct < mHal.state.texturesCount; ct++) {
- bindTexture(NULL, ct, NULL);
- bindSampler(NULL, ct, NULL);
- }
delete[] mHal.state.textures;
delete[] mHal.state.samplers;
delete[] mHal.state.textureTargets;
@@ -90,6 +83,18 @@ Program::~Program() {
mHal.state.texturesCount = 0;
}
+bool Program::freeChildren() {
+ for (uint32_t ct=0; ct < mHal.state.constantsCount; ct++) {
+ bindAllocation(NULL, NULL, ct);
+ }
+
+ for (uint32_t ct=0; ct < mHal.state.texturesCount; ct++) {
+ bindTexture(NULL, ct, NULL);
+ bindSampler(NULL, ct, NULL);
+ }
+ return false;
+}
+
void Program::initMemberVars() {
mDirty = true;