diff options
| author | Jason Sams <rjsams@android.com> | 2011-08-18 18:01:33 -0700 |
|---|---|---|
| committer | Jason Sams <rjsams@android.com> | 2011-08-18 18:01:33 -0700 |
| commit | c7cec1e3577cc77a5a73d5bd5a82733b1b9936a1 (patch) | |
| tree | 7b16f807f7f05630a96b1dbfb88676d0a889ff90 /rsProgram.cpp | |
| parent | dc314a172d48479053f258b485d7d0284b5b5b1f (diff) | |
Fix issue with freeing allocation with circular references.
Change-Id: I45871c20a192815eafee77f95e17a025f6dcf9d1
Diffstat (limited to 'rsProgram.cpp')
| -rw-r--r-- | rsProgram.cpp | 21 |
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; |
