Allocation.cpp revision a423096c0d49e5cfe13a400b4323a76f89c6885c
1221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams/*
23522f40418fdf877f5a136475dbf75e57a3b7c77Jason Sams * Copyright (C) 2012 The Android Open Source Project
3221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams *
4221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * Licensed under the Apache License, Version 2.0 (the "License");
5221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * you may not use this file except in compliance with the License.
6221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * You may obtain a copy of the License at
7221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams *
8221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams *      http://www.apache.org/licenses/LICENSE-2.0
9221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams *
10221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * Unless required by applicable law or agreed to in writing, software
11221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * distributed under the License is distributed on an "AS IS" BASIS,
12221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * See the License for the specific language governing permissions and
14221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams * limitations under the License.
15221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams */
16221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
17221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams#include "RenderScript.h"
18b206acefa7ef03e02d3e8e161f8a1493329246b3Tim Murray#include <rs.h>
19221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
2069cccdf0659a193d6a75420ec745421fb5c436e6Jason Samsusing namespace android;
219eb7f4b90120ebe4be74343856e86b46495f72dfTim Murrayusing namespace RSC;
22221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
23221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid * Allocation::getIDSafe() const {
24221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    return getID();
25221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
26221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
2769cccdf0659a193d6a75420ec745421fb5c436e6Jason Samsvoid Allocation::updateCacheInfo(sp<const Type> t) {
28221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mCurrentDimX = t->getX();
29221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mCurrentDimY = t->getY();
30221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mCurrentDimZ = t->getZ();
31221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mCurrentCount = mCurrentDimX;
32221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (mCurrentDimY > 1) {
33221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        mCurrentCount *= mCurrentDimY;
34221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
35221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (mCurrentDimZ > 1) {
36221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        mCurrentCount *= mCurrentDimZ;
37221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
38221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
39221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
4084bf2b877024aaa154b66e0f2338d54bdabd855aTim MurrayAllocation::Allocation(void *id, sp<RS> rs, sp<const Type> t, uint32_t usage) :
41baca6c3c3d79a324c7976ba873afdded0b6bcfb5Tim Murray    BaseObj(id, rs), mSelectedY(0), mSelectedZ(0), mSelectedLOD(0),
42baca6c3c3d79a324c7976ba873afdded0b6bcfb5Tim Murray    mSelectedFace(RS_ALLOCATION_CUBEMAP_FACE_POSITIVE_X) {
4369cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams
44221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((usage & ~(RS_ALLOCATION_USAGE_SCRIPT |
45221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                   RS_ALLOCATION_USAGE_GRAPHICS_TEXTURE |
46221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                   RS_ALLOCATION_USAGE_GRAPHICS_VERTEX |
47221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                   RS_ALLOCATION_USAGE_GRAPHICS_CONSTANTS |
48221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                   RS_ALLOCATION_USAGE_GRAPHICS_RENDER_TARGET |
49221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                   RS_ALLOCATION_USAGE_IO_INPUT |
5096267c2ff0133c20cc5643419a3ed3b1e75fe568Tim Murray                   RS_ALLOCATION_USAGE_IO_OUTPUT |
5196267c2ff0133c20cc5643419a3ed3b1e75fe568Tim Murray                   RS_ALLOCATION_USAGE_SHARED)) != 0) {
52221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Unknown usage specified.");
53221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
54221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
553522f40418fdf877f5a136475dbf75e57a3b7c77Jason Sams    if ((usage & RS_ALLOCATION_USAGE_IO_INPUT) != 0) {
56221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        mWriteAllowed = false;
573522f40418fdf877f5a136475dbf75e57a3b7c77Jason Sams        if ((usage & ~(RS_ALLOCATION_USAGE_IO_INPUT |
58221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                       RS_ALLOCATION_USAGE_GRAPHICS_TEXTURE |
59221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                       RS_ALLOCATION_USAGE_SCRIPT)) != 0) {
60221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams            ALOGE("Invalid usage combination.");
61221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        }
62221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
63221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
64221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mType = t;
65221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    mUsage = usage;
66221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
6769cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams    if (t.get() != NULL) {
68221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        updateCacheInfo(t);
69221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
70221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
71221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
72221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validateIsInt32() {
73221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    RsDataType dt = mType->getElement()->getDataType();
74221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((dt == RS_TYPE_SIGNED_32) || (dt == RS_TYPE_UNSIGNED_32)) {
75221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
76221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
77221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    ALOGE("32 bit integer source does not match allocation type %i", dt);
78221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
79221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
80221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validateIsInt16() {
81221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    RsDataType dt = mType->getElement()->getDataType();
82221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((dt == RS_TYPE_SIGNED_16) || (dt == RS_TYPE_UNSIGNED_16)) {
83221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
84221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
85221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    ALOGE("16 bit integer source does not match allocation type %i", dt);
86221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
87221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
88221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validateIsInt8() {
89221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    RsDataType dt = mType->getElement()->getDataType();
90221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((dt == RS_TYPE_SIGNED_8) || (dt == RS_TYPE_UNSIGNED_8)) {
91221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
92221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
93221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    ALOGE("8 bit integer source does not match allocation type %i", dt);
94221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
95221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
96221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validateIsFloat32() {
97221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    RsDataType dt = mType->getElement()->getDataType();
98221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (dt == RS_TYPE_FLOAT_32) {
99221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
100221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
101221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    ALOGE("32 bit float source does not match allocation type %i", dt);
102221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
103221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
104221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validateIsObject() {
105221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    RsDataType dt = mType->getElement()->getDataType();
106221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((dt == RS_TYPE_ELEMENT) ||
107221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_TYPE) ||
108221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_ALLOCATION) ||
109221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_SAMPLER) ||
110221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_SCRIPT) ||
111221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_MESH) ||
112221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_PROGRAM_FRAGMENT) ||
113221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_PROGRAM_VERTEX) ||
114221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_PROGRAM_RASTER) ||
115221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        (dt == RS_TYPE_PROGRAM_STORE)) {
116221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
117221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
118221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    ALOGE("Object source does not match allocation type %i", dt);
119221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
120221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
121221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::updateFromNative() {
122221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    BaseObj::updateFromNative();
123221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
124a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    const void *typeID = RS::dispatch->AllocationGetType(mRS->getContext(), getID());
125221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if(typeID != NULL) {
12669cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams        sp<const Type> old = mType;
12769cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams        sp<Type> t = new Type((void *)typeID, mRS);
128221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        t->updateFromNative();
129221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        updateCacheInfo(t);
130221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        mType = t;
131221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
132221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
133221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
134221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::syncAll(RsAllocationUsageType srcLocation) {
135221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    switch (srcLocation) {
136221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    case RS_ALLOCATION_USAGE_SCRIPT:
137221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    case RS_ALLOCATION_USAGE_GRAPHICS_CONSTANTS:
138221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    case RS_ALLOCATION_USAGE_GRAPHICS_TEXTURE:
139221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    case RS_ALLOCATION_USAGE_GRAPHICS_VERTEX:
140221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        break;
141221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    default:
142221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Source must be exactly one usage type.");
143221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
144a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationSyncAll(mRS->getContext(), getIDSafe(), srcLocation);
145221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
146221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
147221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::ioSendOutput() {
1480b575de8ed0b628d84d256f5846500b0385979bdTim Murray#ifndef RS_COMPATIBILITY_LIB
149221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((mUsage & RS_ALLOCATION_USAGE_IO_OUTPUT) == 0) {
150221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Can only send buffer if IO_OUTPUT usage specified.");
151221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
152a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationIoSend(mRS->getContext(), getID());
1530b575de8ed0b628d84d256f5846500b0385979bdTim Murray#endif
154221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
155221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
156221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::ioGetInput() {
1570b575de8ed0b628d84d256f5846500b0385979bdTim Murray#ifndef RS_COMPATIBILITY_LIB
158221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if ((mUsage & RS_ALLOCATION_USAGE_IO_INPUT) == 0) {
159221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Can only send buffer if IO_OUTPUT usage specified.");
160221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
161a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationIoReceive(mRS->getContext(), getID());
1620b575de8ed0b628d84d256f5846500b0385979bdTim Murray#endif
163221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
164221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
165221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::generateMipmaps() {
166a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationGenerateMipmaps(mRS->getContext(), getID());
167221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
168221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
1690b93e30c8c64fb2f985218adfaceff777f62a42fTim Murrayvoid Allocation::copy1DRangeFrom(uint32_t off, size_t count, const void *data) {
17069cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams
171221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if(count < 1) {
172221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Count must be >= 1.");
173221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
174221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
175221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if((off + count) > mCurrentCount) {
176221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Overflow, Available count %zu, got %zu at offset %zu.", mCurrentCount, count, off);
177221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return;
178221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
179221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
180a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation1DData(mRS->getContext(), getIDSafe(), off, mSelectedLOD, count, data,
1810b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray                       count * mType->getElement()->getSizeBytes());
182221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
183221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
1840b93e30c8c64fb2f985218adfaceff777f62a42fTim Murrayvoid Allocation::copy1DRangeTo(uint32_t off, size_t count, void *data) {
185509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray    if(count < 1) {
186509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray        ALOGE("Count must be >= 1.");
187509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray        return;
188509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray    }
189509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray    if((off + count) > mCurrentCount) {
190509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray        ALOGE("Overflow, Available count %zu, got %zu at offset %zu.", mCurrentCount, count, off);
191509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray        return;
192509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray    }
1930b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray
194a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation1DRead(mRS->getContext(), getIDSafe(), off, mSelectedLOD, count, data,
1950b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray                       count * mType->getElement()->getSizeBytes());
196509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray}
197509ea5c832a865bc9083d53f1f058377a689bab3Tim Murray
198a4cbc2b0cf0f6fbdb21e84a3e17585eda1885e3eTim Murrayvoid Allocation::copy1DRangeFrom(uint32_t off, size_t count, sp<const Allocation> data,
199a4cbc2b0cf0f6fbdb21e84a3e17585eda1885e3eTim Murray                                 uint32_t dataOff) {
20069cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams
201a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationCopy2DRange(mRS->getContext(), getIDSafe(), off, 0,
202221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            mSelectedLOD, mSelectedFace,
203221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            count, 1, data->getIDSafe(), dataOff, 0,
204221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            data->mSelectedLOD, data->mSelectedFace);
205221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
206221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
2070b93e30c8c64fb2f985218adfaceff777f62a42fTim Murrayvoid Allocation::copy1DFrom(const void* data) {
2080b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray    copy1DRangeFrom(0, mCurrentCount, data);
2090b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray}
2100b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray
2110b93e30c8c64fb2f985218adfaceff777f62a42fTim Murrayvoid Allocation::copy1DTo(void* data) {
2120b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray    copy1DRangeTo(0, mCurrentCount, data);
2130b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray}
2140b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray
2150b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray
216221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::validate2DRange(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h) {
217221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (mAdaptedAllocation != NULL) {
218221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
219221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    } else {
220221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        if (((xoff + w) > mCurrentDimX) || ((yoff + h) > mCurrentDimY)) {
221221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams            ALOGE("Updated region larger than allocation.");
222221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        }
223221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
224221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
225221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
226221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::copy2DRangeFrom(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h,
2270b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray                                 const void *data) {
228221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    validate2DRange(xoff, yoff, w, h);
229a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation2DData(mRS->getContext(), getIDSafe(), xoff, yoff, mSelectedLOD, mSelectedFace,
230358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                       w, h, data, w * h * mType->getElement()->getSizeBytes(), w * mType->getElement()->getSizeBytes());
231221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
232221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
233221a4b17cda03916a0599628fcbb5f48605a0e5aJason Samsvoid Allocation::copy2DRangeFrom(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h,
2340b93e30c8c64fb2f985218adfaceff777f62a42fTim Murray                                 sp<const Allocation> data, uint32_t dataXoff, uint32_t dataYoff) {
235221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    validate2DRange(xoff, yoff, w, h);
236a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->AllocationCopy2DRange(mRS->getContext(), getIDSafe(), xoff, yoff,
237221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            mSelectedLOD, mSelectedFace,
238221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            w, h, data->getIDSafe(), dataXoff, dataYoff,
239221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams                            data->mSelectedLOD, data->mSelectedFace);
240221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
241221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
2427b3e3093f745134345dadf89498ad16e1f9c0e71Tim Murrayvoid Allocation::copy2DRangeTo(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h,
2437b3e3093f745134345dadf89498ad16e1f9c0e71Tim Murray                               void* data) {
2447b3e3093f745134345dadf89498ad16e1f9c0e71Tim Murray    validate2DRange(xoff, yoff, w, h);
245a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation2DRead(mRS->getContext(), getIDSafe(), xoff, yoff, mSelectedLOD, mSelectedFace,
246358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                       w, h, data, w * h * mType->getElement()->getSizeBytes(), w * mType->getElement()->getSizeBytes());
2477b3e3093f745134345dadf89498ad16e1f9c0e71Tim Murray}
2487b3e3093f745134345dadf89498ad16e1f9c0e71Tim Murray
249358747a3118301c5faeee73c98dd5f839bbfb54aTim Murrayvoid Allocation::copy2DStridedFrom(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h,
250358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                                   const void *data, size_t stride) {
251358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray    validate2DRange(xoff, yoff, w, h);
252a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation2DData(mRS->getContext(), getIDSafe(), xoff, yoff, mSelectedLOD, mSelectedFace,
253358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                       w, h, data, w * h * mType->getElement()->getSizeBytes(), stride);
254358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray}
255358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray
256358747a3118301c5faeee73c98dd5f839bbfb54aTim Murrayvoid Allocation::copy2DStridedFrom(const void* data, size_t stride) {
257358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray    copy2DStridedFrom(0, 0, mCurrentDimX, mCurrentDimY, data, stride);
258358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray}
259358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray
260358747a3118301c5faeee73c98dd5f839bbfb54aTim Murrayvoid Allocation::copy2DStridedTo(uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h,
261358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                                 void *data, size_t stride) {
262358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray    validate2DRange(xoff, yoff, w, h);
263a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    RS::dispatch->Allocation2DRead(mRS->getContext(), getIDSafe(), xoff, yoff, mSelectedLOD, mSelectedFace,
264358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray                       w, h, data, w * h * mType->getElement()->getSizeBytes(), stride);
265358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray}
266358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray
267358747a3118301c5faeee73c98dd5f839bbfb54aTim Murrayvoid Allocation::copy2DStridedTo(void* data, size_t stride) {
268358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray    copy2DStridedTo(0, 0, mCurrentDimX, mCurrentDimY, data, stride);
269358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray}
270358747a3118301c5faeee73c98dd5f839bbfb54aTim Murray
27184bf2b877024aaa154b66e0f2338d54bdabd855aTim Murrayandroid::sp<Allocation> Allocation::createTyped(sp<RS> rs, sp<const Type> type,
272684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                RsAllocationMipmapControl mips, uint32_t usage) {
273a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    void *id = RS::dispatch->AllocationCreateTyped(rs->getContext(), type->getID(), mips, usage, 0);
274221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (id == 0) {
275221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Allocation creation failed.");
276221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        return NULL;
277221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
278221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    return new Allocation(id, rs, type, usage);
279221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
280221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
28184bf2b877024aaa154b66e0f2338d54bdabd855aTim Murrayandroid::sp<Allocation> Allocation::createTyped(sp<RS> rs, sp<const Type> type,
282684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                RsAllocationMipmapControl mips, uint32_t usage,
283684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                void *pointer) {
284a423096c0d49e5cfe13a400b4323a76f89c6885cTim Murray    void *id = RS::dispatch->AllocationCreateTyped(rs->getContext(), type->getID(), mips, usage,
285099bc262f862cdeb547cf8a78fe9e0e92560f437Tim Murray                                       (uintptr_t)pointer);
286221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    if (id == 0) {
287221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams        ALOGE("Allocation creation failed.");
288221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    }
289221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    return new Allocation(id, rs, type, usage);
290221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
291221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
29284bf2b877024aaa154b66e0f2338d54bdabd855aTim Murrayandroid::sp<Allocation> Allocation::createTyped(sp<RS> rs, sp<const Type> type,
293684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                uint32_t usage) {
294221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    return createTyped(rs, type, RS_ALLOCATION_MIPMAP_NONE, usage);
295221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
296221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
29784bf2b877024aaa154b66e0f2338d54bdabd855aTim Murrayandroid::sp<Allocation> Allocation::createSized(sp<RS> rs, sp<const Element> e,
298684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                size_t count, uint32_t usage) {
299221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    Type::Builder b(rs, e);
300221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams    b.setX(count);
30169cccdf0659a193d6a75420ec745421fb5c436e6Jason Sams    sp<const Type> t = b.create();
302221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams
303684726cbbd177ee4ee9000e9422058547acd237fTim Murray    return createTyped(rs, t, usage);
304684726cbbd177ee4ee9000e9422058547acd237fTim Murray}
305684726cbbd177ee4ee9000e9422058547acd237fTim Murray
306684726cbbd177ee4ee9000e9422058547acd237fTim Murrayandroid::sp<Allocation> Allocation::createSized2D(sp<RS> rs, sp<const Element> e,
307684726cbbd177ee4ee9000e9422058547acd237fTim Murray                                                  size_t x, size_t y, uint32_t usage) {
308684726cbbd177ee4ee9000e9422058547acd237fTim Murray    Type::Builder b(rs, e);
309684726cbbd177ee4ee9000e9422058547acd237fTim Murray    b.setX(x);
310684726cbbd177ee4ee9000e9422058547acd237fTim Murray    b.setY(y);
311684726cbbd177ee4ee9000e9422058547acd237fTim Murray    sp<const Type> t = b.create();
312684726cbbd177ee4ee9000e9422058547acd237fTim Murray
313684726cbbd177ee4ee9000e9422058547acd237fTim Murray    return createTyped(rs, t, usage);
314221a4b17cda03916a0599628fcbb5f48605a0e5aJason Sams}
315