summaryrefslogtreecommitdiffstats
path: root/rsClosure.cpp
diff options
context:
space:
mode:
authorYang Ni <yangni@google.com>2015-03-23 17:14:58 -0700
committerYang Ni <yangni@google.com>2015-03-31 13:47:57 -0700
commitbd0af2d161e36e52e6782ccb2d15dd5a36467704 (patch)
treefe585e4f9ed5e170cd8127ea129232104e1f952f /rsClosure.cpp
parent4210d3e2a21bc00d06e894a583211968d17a9510 (diff)
downloadandroid_frameworks_rs-bd0af2d161e36e52e6782ccb2d15dd5a36467704.tar.gz
android_frameworks_rs-bd0af2d161e36e52e6782ccb2d15dd5a36467704.tar.bz2
android_frameworks_rs-bd0af2d161e36e52e6782ccb2d15dd5a36467704.zip
Clean up ScriptGroup2 implementation
b/19944127 - Adjust ref counting - Fix value size type in closure creation Change-Id: I1179d34aa67f845578740e71cc2da4f82419f251
Diffstat (limited to 'rsClosure.cpp')
-rw-r--r--rsClosure.cpp60
1 files changed, 21 insertions, 39 deletions
diff --git a/rsClosure.cpp b/rsClosure.cpp
index 8fb12b81..4b57be4d 100644
--- a/rsClosure.cpp
+++ b/rsClosure.cpp
@@ -12,7 +12,7 @@ RsClosure rsi_ClosureCreate(Context* context, RsScriptKernelID kernelID,
RsAllocation returnValue,
RsScriptFieldID* fieldIDs, size_t fieldIDs_length,
uintptr_t* values, size_t values_length,
- size_t* sizes, size_t sizes_length,
+ int* sizes, size_t sizes_length,
RsClosure* depClosures, size_t depClosures_length,
RsScriptFieldID* depFieldIDs,
size_t depFieldIDs_length) {
@@ -20,31 +20,29 @@ RsClosure rsi_ClosureCreate(Context* context, RsScriptKernelID kernelID,
sizes_length == depClosures_length &&
depClosures_length == depFieldIDs_length);
- return (RsClosure)(new Closure(
+ Closure* c = new Closure(
context, (const ScriptKernelID*)kernelID, (Allocation*)returnValue,
fieldIDs_length, (const ScriptFieldID**)fieldIDs, (const void**)values,
sizes, (const Closure**)depClosures,
- (const ScriptFieldID**)depFieldIDs));
+ (const ScriptFieldID**)depFieldIDs);
+ c->incUserRef();
+ return static_cast<RsClosure>(c);
}
RsClosure rsi_InvokeClosureCreate(Context* context, RsScriptInvokeID invokeID,
const void* params, const size_t paramLength,
const RsScriptFieldID* fieldIDs, const size_t fieldIDs_length,
const uintptr_t* values, const size_t values_length,
- const size_t* sizes, const size_t sizes_length) {
+ const int* sizes, const size_t sizes_length) {
rsAssert(fieldIDs_length == values_length && values_length == sizes_length);
- return (RsClosure)(new Closure(
+ Closure* c = new Closure(
context, (const ScriptInvokeID*)invokeID, params, paramLength,
fieldIDs_length, (const ScriptFieldID**)fieldIDs, (const void**)values,
- sizes));
+ sizes);
+ c->incUserRef();
+ return static_cast<RsClosure>(c);
}
-#if 0
-void rsi_ClosureEval(Context* rsc, RsClosure closure) {
- ((Closure*)closure)->eval();
-}
-#endif
-
void rsi_ClosureSetArg(Context* rsc, RsClosure closure, uint32_t index,
uintptr_t value, size_t size) {
((Closure*)closure)->setArg(index, (const void*)value, size);
@@ -63,7 +61,7 @@ Closure::Closure(Context* context,
const int numValues,
const ScriptFieldID** fieldIDs,
const void** values,
- const size_t* sizes,
+ const int* sizes,
const Closure** depClosures,
const ScriptFieldID** depFieldIDs) :
ObjectBase(context), mContext(context), mFunctionID((IDBase*)kernelID),
@@ -80,16 +78,6 @@ Closure::Closure(Context* context,
for (; i < (size_t)numValues; i++) {
rsAssert(fieldIDs[i] != nullptr);
mGlobals[fieldIDs[i]] = make_pair(values[i], sizes[i]);
- ALOGV("Creating closure %p, binding field %p (Script %p, slot: %d)",
- this, fieldIDs[i], fieldIDs[i]->mScript, fieldIDs[i]->mSlot);
- }
-
- size_t j = mNumArg;
- for (const auto& p : mGlobals) {
- rsAssert(p.first == fieldIDs[j]);
- rsAssert(p.second.first == values[j]);
- rsAssert(p.second.second == sizes[j]);
- j++;
}
for (i = 0; i < mNumArg; i++) {
@@ -97,11 +85,10 @@ Closure::Closure(Context* context,
if (dep != nullptr) {
auto mapping = mArgDeps[dep];
if (mapping == nullptr) {
- mapping = new Map<int, const ObjectBaseRef<ScriptFieldID>*>();
+ mapping = new Map<int, ObjectBaseRef<ScriptFieldID>>();
mArgDeps[dep] = mapping;
}
- (*mapping)[i] = new ObjectBaseRef<ScriptFieldID>(
- const_cast<ScriptFieldID*>(depFieldIDs[i]));
+ (*mapping)[i].set(const_cast<ScriptFieldID*>(depFieldIDs[i]));
}
}
@@ -110,14 +97,12 @@ Closure::Closure(Context* context,
if (dep != nullptr) {
auto mapping = mGlobalDeps[dep];
if (mapping == nullptr) {
- mapping = new Map<const ObjectBaseRef<ScriptFieldID>*,
- const ObjectBaseRef<ScriptFieldID>*>();
+ mapping = new Map<const ScriptFieldID*,
+ ObjectBaseRef<ScriptFieldID>>();
mGlobalDeps[dep] = mapping;
}
- (*mapping)[new ObjectBaseRef<ScriptFieldID>(
- const_cast<ScriptFieldID*>(fieldIDs[i]))] =
- new ObjectBaseRef<ScriptFieldID>(
- const_cast<ScriptFieldID*>(depFieldIDs[i]));
+ fieldIDs[i]->incSysRef();
+ (*mapping)[fieldIDs[i]].set(const_cast<ScriptFieldID*>(depFieldIDs[i]));
}
}
}
@@ -125,8 +110,9 @@ Closure::Closure(Context* context,
Closure::Closure(Context* context, const ScriptInvokeID* invokeID,
const void* params, const size_t paramLength,
const size_t numValues, const ScriptFieldID** fieldIDs,
- const void** values, const size_t* sizes) :
+ const void** values, const int* sizes) :
ObjectBase(context), mContext(context), mFunctionID((IDBase*)invokeID), mIsKernel(false),
+ mArgs(nullptr), mNumArg(0),
mReturnValue(nullptr), mParams(params), mParamLength(paramLength) {
for (size_t i = 0; i < numValues; i++) {
mGlobals[fieldIDs[i]] = make_pair(values[i], sizes[i]);
@@ -136,17 +122,13 @@ Closure::Closure(Context* context, const ScriptInvokeID* invokeID,
Closure::~Closure() {
for (const auto& p : mArgDeps) {
auto map = p.second;
- for (const auto& p1 : *map) {
- delete p1.second;
- }
delete p.second;
}
for (const auto& p : mGlobalDeps) {
auto map = p.second;
for (const auto& p1 : *map) {
- delete p1.first;
- delete p1.second;
+ p1.first->decSysRef();
}
delete p.second;
}
@@ -159,7 +141,7 @@ void Closure::setArg(const uint32_t index, const void* value, const size_t size)
}
void Closure::setGlobal(const ScriptFieldID* fieldID, const void* value,
- const size_t size) {
+ const int size) {
mGlobals[fieldID] = make_pair(value, size);
}