/* * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.support.v8.renderscript; import android.util.SparseArray; /** * **/ public class Script extends BaseObj { ScriptCThunker mT; android.renderscript.Script getNObj() { return mT; } /** * KernelID is an identifier for a Script + root function pair. It is used * as an identifier for ScriptGroup creation. * * This class should not be directly created. Instead use the method in the * reflected or intrinsic code "getKernelID_funcname()". * */ public static final class KernelID extends BaseObj { android.renderscript.Script.KernelID mN; Script mScript; int mSlot; int mSig; KernelID(int id, RenderScript rs, Script s, int slot, int sig) { super(id, rs); mScript = s; mSlot = slot; mSig = sig; } } private final SparseArray mKIDs = new SparseArray(); /** * Only to be used by generated reflected classes. * * * @param slot * @param sig * @param ein * @param eout * * @return KernelID */ protected KernelID createKernelID(int slot, int sig, Element ein, Element eout) { KernelID k = mKIDs.get(slot); if (k != null) { return k; } // Any native callers to createKernelID must initialize their own native IDs // excpet ScriptCThunker if (mRS.isNative == true) { k = new KernelID(0, mRS, this, slot, sig); if (mT != null) { k.mN = mT.thunkCreateKernelID(slot, sig, ein, eout); } mKIDs.put(slot, k); return k; } int id = mRS.nScriptKernelIDCreate(getID(mRS), slot, sig); if (id == 0) { throw new RSDriverException("Failed to create KernelID"); } k = new KernelID(id, mRS, this, slot, sig); mKIDs.put(slot, k); return k; } /** * FieldID is an identifier for a Script + exported field pair. It is used * as an identifier for ScriptGroup creation. * * This class should not be directly created. Instead use the method in the * reflected or intrinsic code "getFieldID_funcname()". * */ public static final class FieldID extends BaseObj { android.renderscript.Script.FieldID mN; Script mScript; int mSlot; FieldID(int id, RenderScript rs, Script s, int slot) { super(id, rs); mScript = s; mSlot = slot; } } private final SparseArray mFIDs = new SparseArray(); /** * Only to be used by generated reflected classes. * * @param slot * @param e * * @return FieldID */ protected FieldID createFieldID(int slot, Element e) { // Any thunking caller to createFieldID must create its own native IDs // except ScriptC if (mRS.isNative == true) { FieldID f = new FieldID(0, mRS, this, slot); if (mT != null) { f.mN = mT.thunkCreateFieldID(slot, e); } mFIDs.put(slot, f); return f; } FieldID f = mFIDs.get(slot); if (f != null) { return f; } int id = mRS.nScriptFieldIDCreate(getID(mRS), slot); if (id == 0) { throw new RSDriverException("Failed to create FieldID"); } f = new FieldID(id, mRS, this, slot); mFIDs.put(slot, f); return f; } /** * Only intended for use by generated reflected code. * * @param slot */ protected void invoke(int slot) { if (mT != null) { mT.thunkInvoke(slot); return; } mRS.nScriptInvoke(getID(mRS), slot); } /** * Only intended for use by generated reflected code. * * @param slot * @param v */ protected void invoke(int slot, FieldPacker v) { if (mT != null) { mT.thunkInvoke(slot, v); return; } if (v != null) { mRS.nScriptInvokeV(getID(mRS), slot, v.getData()); } else { mRS.nScriptInvoke(getID(mRS), slot); } } /** * Only intended for use by generated reflected code. * * @param va * @param slot */ public void bindAllocation(Allocation va, int slot) { if (mT != null) { mT.thunkBindAllocation(va, slot); return; } mRS.validate(); if (va != null) { mRS.nScriptBindAllocation(getID(mRS), va.getID(mRS), slot); } else { mRS.nScriptBindAllocation(getID(mRS), 0, slot); } } public void setTimeZone(String timeZone) { if (mT != null) { mT.thunkSetTimeZone(timeZone); return; } mRS.validate(); try { mRS.nScriptSetTimeZone(getID(mRS), timeZone.getBytes("UTF-8")); } catch (java.io.UnsupportedEncodingException e) { throw new RuntimeException(e); } } /** * Only intended for use by generated reflected code. * * @param slot * @param ain * @param aout * @param v */ protected void forEach(int slot, Allocation ain, Allocation aout, FieldPacker v) { if (mT != null) { mT.thunkForEach(slot, ain, aout, v); return; } if (ain == null && aout == null) { throw new RSIllegalArgumentException( "At least one of ain or aout is required to be non-null."); } int in_id = 0; if (ain != null) { in_id = ain.getID(mRS); } int out_id = 0; if (aout != null) { out_id = aout.getID(mRS); } byte[] params = null; if (v != null) { params = v.getData(); } mRS.nScriptForEach(getID(mRS), slot, in_id, out_id, params); } protected void forEach(int slot, Allocation ain, Allocation aout, FieldPacker v, LaunchOptions sc) { if (mT != null) { mT.thunkForEach(slot, ain, aout, v, sc); return; } if (ain == null && aout == null) { throw new RSIllegalArgumentException( "At least one of ain or aout is required to be non-null."); } if (sc == null) { forEach(slot, ain, aout, v); return; } int in_id = 0; if (ain != null) { in_id = ain.getID(mRS); } int out_id = 0; if (aout != null) { out_id = aout.getID(mRS); } byte[] params = null; if (v != null) { params = v.getData(); } mRS.nScriptForEachClipped(getID(mRS), slot, in_id, out_id, params, sc.xstart, sc.xend, sc.ystart, sc.yend, sc.zstart, sc.zend); } Script(int id, RenderScript rs) { super(id, rs); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, float v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarF(getID(mRS), index, v); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, double v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarD(getID(mRS), index, v); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, int v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarI(getID(mRS), index, v); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, long v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarJ(getID(mRS), index, v); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, boolean v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarI(getID(mRS), index, v ? 1 : 0); } /** * Only intended for use by generated reflected code. * * @param index * @param o */ public void setVar(int index, BaseObj o) { if (mT != null) { mT.thunkSetVar(index, o); return; } mRS.nScriptSetVarObj(getID(mRS), index, (o == null) ? 0 : o.getID(mRS)); } /** * Only intended for use by generated reflected code. * * @param index * @param v */ public void setVar(int index, FieldPacker v) { if (mT != null) { mT.thunkSetVar(index, v); return; } mRS.nScriptSetVarV(getID(mRS), index, v.getData()); } /** * Only intended for use by generated reflected code. * * @param index * @param v * @param e * @param dims */ public void setVar(int index, FieldPacker v, Element e, int[] dims) { if (mT != null) { mT.thunkSetVar(index, v, e, dims); return; } mRS.nScriptSetVarVE(getID(mRS), index, v.getData(), e.getID(mRS), dims); } public static class Builder { RenderScript mRS; Builder(RenderScript rs) { mRS = rs; } } public static class FieldBase { protected Element mElement; protected Allocation mAllocation; protected void init(RenderScript rs, int dimx) { mAllocation = Allocation.createSized(rs, mElement, dimx, Allocation.USAGE_SCRIPT); } protected void init(RenderScript rs, int dimx, int usages) { mAllocation = Allocation.createSized(rs, mElement, dimx, Allocation.USAGE_SCRIPT | usages); } protected FieldBase() { } public Element getElement() { return mElement; } public Type getType() { return mAllocation.getType(); } public Allocation getAllocation() { return mAllocation; } //@Override public void updateAllocation() { } } public static final class LaunchOptions { protected int xstart = 0; protected int ystart = 0; protected int xend = 0; protected int yend = 0; protected int zstart = 0; protected int zend = 0; protected int strategy; public LaunchOptions setX(int xstartArg, int xendArg) { if (xstartArg < 0 || xendArg <= xstartArg) { throw new RSIllegalArgumentException("Invalid dimensions"); } xstart = xstartArg; xend = xendArg; return this; } public LaunchOptions setY(int ystartArg, int yendArg) { if (ystartArg < 0 || yendArg <= ystartArg) { throw new RSIllegalArgumentException("Invalid dimensions"); } ystart = ystartArg; yend = yendArg; return this; } public LaunchOptions setZ(int zstartArg, int zendArg) { if (zstartArg < 0 || zendArg <= zstartArg) { throw new RSIllegalArgumentException("Invalid dimensions"); } zstart = zstartArg; zend = zendArg; return this; } public int getXStart() { return xstart; } public int getXEnd() { return xend; } public int getYStart() { return ystart; } public int getYEnd() { return yend; } public int getZStart() { return zstart; } public int getZEnd() { return zend; } } }