rsType.cpp revision c2ce707a3d1a8eae79bcf1c749afc6d6e7969ad9
1326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams/*
2bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams * Copyright (C) 2013 The Android Open Source Project
3326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
4326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Licensed under the Apache License, Version 2.0 (the "License");
5326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * you may not use this file except in compliance with the License.
6326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * You may obtain a copy of the License at
7326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
8326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *      http://www.apache.org/licenses/LICENSE-2.0
9326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *
10326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Unless required by applicable law or agreed to in writing, software
11326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * distributed under the License is distributed on an "AS IS" BASIS,
12326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * See the License for the specific language governing permissions and
14326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * limitations under the License.
15326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams */
16326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
17326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsContext.h"
18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
190b575de8ed0b628d84d256f5846500b0385979bdTim Murray#ifndef RS_SERVER
20bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams#include "system/graphics.h"
210b575de8ed0b628d84d256f5846500b0385979bdTim Murray#endif
22bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams
23326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android;
24326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android::renderscript;
25326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
26afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukType::Type(Context *rsc) : ObjectBase(rsc) {
27246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    memset(&mHal, 0, sizeof(mHal));
28246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    mDimLOD = false;
29326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
30326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
31c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchoukvoid Type::preDestroy() const {
328154954868694e1f233d87d4933a474518b1cb81Jason Sams    for (uint32_t ct = 0; ct < mRSC->mStateType.mTypes.size(); ct++) {
338154954868694e1f233d87d4933a474518b1cb81Jason Sams        if (mRSC->mStateType.mTypes[ct] == this) {
348154954868694e1f233d87d4933a474518b1cb81Jason Sams            mRSC->mStateType.mTypes.removeAt(ct);
358154954868694e1f233d87d4933a474518b1cb81Jason Sams            break;
368154954868694e1f233d87d4933a474518b1cb81Jason Sams        }
378154954868694e1f233d87d4933a474518b1cb81Jason Sams    }
38225afd317e101a7be5fe02c0a86361146ea89f05Jason Sams}
39225afd317e101a7be5fe02c0a86361146ea89f05Jason Sams
40afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukType::~Type() {
41246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    clear();
42326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
43326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
44afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid Type::clear() {
45246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    if (mHal.state.lodCount) {
46246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        delete [] mHal.state.lodDimX;
47246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        delete [] mHal.state.lodDimY;
48246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        delete [] mHal.state.lodDimZ;
4986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        delete [] mHal.state.lodOffset;
50326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
51326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    mElement.clear();
5250bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    memset(&mHal, 0, sizeof(mHal));
53326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
54326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
55afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukTypeState::TypeState() {
56326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
57326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
58afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukTypeState::~TypeState() {
59c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    rsAssert(!mTypes.size());
60326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
61326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
6286087f2f1da630d43f4010c246619f3fd4fad286Stephen Hinessize_t Type::getOffsetForFace(uint32_t face) const {
6386087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    rsAssert(mHal.state.faces);
6486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    return 0;
6586087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines}
6686087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
67afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid Type::compute() {
68246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    uint32_t oldLODCount = mHal.state.lodCount;
69246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    if (mDimLOD) {
7050bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk        uint32_t l2x = rsFindHighBit(mHal.state.dimX) + 1;
7150bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk        uint32_t l2y = rsFindHighBit(mHal.state.dimY) + 1;
7250bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk        uint32_t l2z = rsFindHighBit(mHal.state.dimZ) + 1;
73326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
74246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodCount = rsMax(l2x, l2y);
75246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodCount = rsMax(mHal.state.lodCount, l2z);
76326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    } else {
77246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodCount = 1;
78326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
79246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    if (mHal.state.lodCount != oldLODCount) {
80246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        if (oldLODCount) {
81246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk            delete [] mHal.state.lodDimX;
82246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk            delete [] mHal.state.lodDimY;
83246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk            delete [] mHal.state.lodDimZ;
8486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines            delete [] mHal.state.lodOffset;
85417e6a486adb02b3b29ada9725286f554cc6d0d3Alex Sakhartchouk        }
86246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimX = new uint32_t[mHal.state.lodCount];
87246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimY = new uint32_t[mHal.state.lodCount];
88246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimZ = new uint32_t[mHal.state.lodCount];
8986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        mHal.state.lodOffset = new uint32_t[mHal.state.lodCount];
90326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
91326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
9250bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    uint32_t tx = mHal.state.dimX;
9350bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    uint32_t ty = mHal.state.dimY;
9450bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    uint32_t tz = mHal.state.dimZ;
9586087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    size_t offset = 0;
96246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    for (uint32_t lod=0; lod < mHal.state.lodCount; lod++) {
97246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimX[lod] = tx;
98246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimY[lod] = ty;
99246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk        mHal.state.lodDimZ[lod]  = tz;
10086087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        mHal.state.lodOffset[lod] = offset;
10186087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        offset += tx * rsMax(ty, 1u) * rsMax(tz, 1u) * mElement->getSizeBytes();
1027c52898ac201043a26b3edb7526d414684cfb96bJason Sams        if (tx > 1) tx >>= 1;
1037c52898ac201043a26b3edb7526d414684cfb96bJason Sams        if (ty > 1) ty >>= 1;
1047c52898ac201043a26b3edb7526d414684cfb96bJason Sams        if (tz > 1) tz >>= 1;
105326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
106326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
107326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    // At this point the offset is the size of a mipmap chain;
10886087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    mMipChainSizeBytes = offset;
109326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
11050bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    if (mHal.state.faces) {
11186087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        offset *= 6;
112326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams    }
1130b575de8ed0b628d84d256f5846500b0385979bdTim Murray#ifndef RS_SERVER
114bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams    // YUV only supports basic 2d
115bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams    // so we can stash the plane pointers in the mipmap levels.
116bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams    if (mHal.state.dimYuv) {
117bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams        switch(mHal.state.dimYuv) {
118bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams        case HAL_PIXEL_FORMAT_YV12:
119bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodOffset[1] = offset;
120bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimX[1] = mHal.state.lodDimX[0] / 2;
121bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimY[1] = mHal.state.lodDimY[0] / 2;
122bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            offset += offset / 4;
123bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodOffset[2] = offset;
124bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimX[2] = mHal.state.lodDimX[0] / 2;
125bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimY[2] = mHal.state.lodDimY[0] / 2;
126bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            offset += offset / 4;
127bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            break;
128bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams        case HAL_PIXEL_FORMAT_YCrCb_420_SP:  // NV21
129bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodOffset[1] = offset;
130bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimX[1] = mHal.state.lodDimX[0];
131bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            mHal.state.lodDimY[1] = mHal.state.lodDimY[0] / 2;
132bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            offset += offset / 2;
133bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            break;
134bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams        default:
135bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams            rsAssert(0);
136bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams        }
137bc0ca6ba4e31239bf77060578d0bdf1a10e04168Jason Sams    }
1380b575de8ed0b628d84d256f5846500b0385979bdTim Murray#endif
13986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    mTotalSizeBytes = offset;
14050bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    mHal.state.element = mElement.get();
141326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
142326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
14386087f2f1da630d43f4010c246619f3fd4fad286Stephen Hinesuint32_t Type::getLODOffset(uint32_t lod, uint32_t x) const {
14486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    uint32_t offset = mHal.state.lodOffset[lod];
14586087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    offset += x * mElement->getSizeBytes();
14686087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    return offset;
14786087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines}
14886087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
14986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hinesuint32_t Type::getLODOffset(uint32_t lod, uint32_t x, uint32_t y) const {
15086087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    uint32_t offset = mHal.state.lodOffset[lod];
15186087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    offset += (x + y * mHal.state.lodDimX[lod]) * mElement->getSizeBytes();
15286087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    return offset;
15386087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines}
15486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
15586087f2f1da630d43f4010c246619f3fd4fad286Stephen Hinesuint32_t Type::getLODOffset(uint32_t lod, uint32_t x, uint32_t y, uint32_t z) const {
15686087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    uint32_t offset = mHal.state.lodOffset[lod];
15786087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    offset += (x +
15886087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines               y * mHal.state.lodDimX[lod] +
15986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines               z * mHal.state.lodDimX[lod] * mHal.state.lodDimY[lod]) * mElement->getSizeBytes();
16086087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    return offset;
16186087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines}
16286087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
16386087f2f1da630d43f4010c246619f3fd4fad286Stephen Hinesuint32_t Type::getLODFaceOffset(uint32_t lod, RsAllocationCubemapFace face,
16486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines                                uint32_t x, uint32_t y) const {
16586087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    uint32_t offset = mHal.state.lodOffset[lod];
16686087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    offset += (x + y * mHal.state.lodDimX[lod]) * mElement->getSizeBytes();
16786087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
16886087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    if (face != 0) {
16986087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        uint32_t faceOffset = getSizeBytes() / 6;
17086087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines        offset += faceOffset * face;
17186087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    }
17286087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines    return offset;
17386087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines}
17486087f2f1da630d43f4010c246619f3fd4fad286Stephen Hines
175afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukvoid Type::dumpLOGV(const char *prefix) const {
176e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams    char buf[1024];
177e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams    ObjectBase::dumpLOGV(prefix);
17850bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    ALOGV("%s   Type: x=%u y=%u z=%u mip=%i face=%i", prefix,
17950bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk                                                      mHal.state.dimX,
18050bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk                                                      mHal.state.dimY,
18150bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk                                                      mHal.state.dimZ,
182246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk                                                      mHal.state.lodCount,
18350bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk                                                      mHal.state.faces);
18487319de2b16a185cf360827c96a42cf1fcaae744Jason Sams    snprintf(buf, sizeof(buf), "%s element: ", prefix);
185e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams    mElement->dumpLOGV(buf);
186e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams}
187e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams
188e3150cfb3edb028407669e4a65e087eae77e718cJason Samsvoid Type::serialize(Context *rsc, OStream *stream) const {
189fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    // Need to identify ourselves
190fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    stream->addU32((uint32_t)getClassId());
191fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
192fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    String8 name(getName());
193fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    stream->addString(&name);
194fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
195e3150cfb3edb028407669e4a65e087eae77e718cJason Sams    mElement->serialize(rsc, stream);
196fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
19750bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    stream->addU32(mHal.state.dimX);
19850bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    stream->addU32(mHal.state.dimY);
19950bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    stream->addU32(mHal.state.dimZ);
200fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
201246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    stream->addU8((uint8_t)(mHal.state.lodCount ? 1 : 0));
20250bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    stream->addU8((uint8_t)(mHal.state.faces ? 1 : 0));
203fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk}
204fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
205afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex SakhartchoukType *Type::createFromStream(Context *rsc, IStream *stream) {
206fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    // First make sure we are reading the correct object
207b825f67adb5d1e1751fe108e6dbf9c6f2555c283Alex Sakhartchouk    RsA3DClassID classID = (RsA3DClassID)stream->loadU32();
208afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk    if (classID != RS_A3D_CLASS_ID_TYPE) {
209af12ac6a08651464f8d823add667c706f993b587Steve Block        ALOGE("type loading skipped due to invalid class id\n");
210fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk        return NULL;
211fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    }
212fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
213fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    String8 name;
214fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    stream->loadString(&name);
215fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
216fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    Element *elem = Element::createFromStream(rsc, stream);
217afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk    if (!elem) {
218fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk        return NULL;
219fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk    }
220fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
221f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    uint32_t x = stream->loadU32();
222f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    uint32_t y = stream->loadU32();
223f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    uint32_t z = stream->loadU32();
224f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    uint8_t lod = stream->loadU8();
225f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    uint8_t faces = stream->loadU8();
226a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams    Type *type = Type::getType(rsc, elem, x, y, z, lod != 0, faces !=0, 0);
227c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    elem->decUserRef();
228c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    return type;
229fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk}
230fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk
231afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchoukbool Type::getIsNp2() const {
232ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    uint32_t x = getDimX();
233ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    uint32_t y = getDimY();
234ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    uint32_t z = getDimZ();
235ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams
236ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    if (x && (x & (x-1))) {
237ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams        return true;
238ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    }
239ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    if (y && (y & (y-1))) {
240ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams        return true;
241ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    }
242ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    if (z && (z & (z-1))) {
243ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams        return true;
244ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    }
245ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams    return false;
246ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams}
247ef21edcc70fc2734a3dc7995d3c3af1f90d16ef8Jason Sams
248c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex SakhartchoukObjectBaseRef<Type> Type::getTypeRef(Context *rsc, const Element *e,
249c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk                                     uint32_t dimX, uint32_t dimY, uint32_t dimZ,
250a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams                                     bool dimLOD, bool dimFaces, uint32_t dimYuv) {
251c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    ObjectBaseRef<Type> returnRef;
252e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams
25396abf819e50b59ba8cf886c13f894633eb0a24baJason Sams    TypeState * stc = &rsc->mStateType;
254f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams
255f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    ObjectBase::asyncLock();
25696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams    for (uint32_t ct=0; ct < stc->mTypes.size(); ct++) {
25796abf819e50b59ba8cf886c13f894633eb0a24baJason Sams        Type *t = stc->mTypes[ct];
258f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        if (t->getElement() != e) continue;
25996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams        if (t->getDimX() != dimX) continue;
260f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        if (t->getDimY() != dimY) continue;
261f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        if (t->getDimZ() != dimZ) continue;
262f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        if (t->getDimLOD() != dimLOD) continue;
263f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        if (t->getDimFaces() != dimFaces) continue;
264a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams        if (t->getDimYuv() != dimYuv) continue;
265c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk        returnRef.set(t);
266f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams        ObjectBase::asyncUnlock();
267c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk        return returnRef;
26896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams    }
269f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    ObjectBase::asyncUnlock();
270f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams
27196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams
27296abf819e50b59ba8cf886c13f894633eb0a24baJason Sams    Type *nt = new Type(rsc);
273246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    nt->mDimLOD = dimLOD;
274c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    returnRef.set(nt);
275f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    nt->mElement.set(e);
27650bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    nt->mHal.state.dimX = dimX;
27750bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    nt->mHal.state.dimY = dimY;
27850bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    nt->mHal.state.dimZ = dimZ;
27950bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    nt->mHal.state.faces = dimFaces;
280a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams    nt->mHal.state.dimYuv = dimYuv;
28196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams    nt->compute();
282f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams
283f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    ObjectBase::asyncLock();
284f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    stc->mTypes.push(nt);
285f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams    ObjectBase::asyncUnlock();
286f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams
287c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    return returnRef;
28896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams}
28996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams
290c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex SakhartchoukObjectBaseRef<Type> Type::cloneAndResize1D(Context *rsc, uint32_t dimX) const {
291c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    return getTypeRef(rsc, mElement.get(), dimX,
292a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams                      getDimY(), getDimZ(), getDimLOD(), getDimFaces(), getDimYuv());
293f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams}
29496abf819e50b59ba8cf886c13f894633eb0a24baJason Sams
295c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex SakhartchoukObjectBaseRef<Type> Type::cloneAndResize2D(Context *rsc,
296afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk                              uint32_t dimX,
297afb743aca56c18beb7ab924e75cb6e070ef3e55aAlex Sakhartchouk                              uint32_t dimY) const {
298c700e649ca44d0dcff8b271e42d949ea72fe3c63Alex Sakhartchouk    return getTypeRef(rsc, mElement.get(), dimX, dimY,
299a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams                      getDimZ(), getDimLOD(), getDimFaces(), getDimYuv());
30096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams}
30196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams
30296abf819e50b59ba8cf886c13f894633eb0a24baJason Sams
3039f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hinesvoid Type::incRefs(const void *ptr, size_t ct, size_t startOff) const {
3049f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    const uint8_t *p = static_cast<const uint8_t *>(ptr);
3059f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    const Element *e = mHal.state.element;
3069f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    uint32_t stride = e->getSizeBytes();
3079f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
3089f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    p += stride * startOff;
3099f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    while (ct > 0) {
3109f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        e->incRefs(p);
3119f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        ct--;
3129f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        p += stride;
3139f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    }
3149f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines}
3159f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
3169f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
3179f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hinesvoid Type::decRefs(const void *ptr, size_t ct, size_t startOff) const {
3189f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    if (!mHal.state.element->getHasReferences()) {
3199f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        return;
3209f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    }
3219f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    const uint8_t *p = static_cast<const uint8_t *>(ptr);
3229f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    const Element *e = mHal.state.element;
3239f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    uint32_t stride = e->getSizeBytes();
3249f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
3259f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    p += stride * startOff;
3269f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    while (ct > 0) {
3279f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        e->decRefs(p);
3289f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        ct--;
3299f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines        p += stride;
3309f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines    }
3319f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines}
3329f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
3339f70a4e63825afe9f786483722e1669b3625f5e9Stephen Hines
334326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams//////////////////////////////////////////////////
335e5ffb879ae535a899a486285a23bea05e912480fJason Sams//
336326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android {
337326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript {
338326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
339c975cf4a71b63ccbd20f1f3b3341c5f2e6025b45Jason SamsRsType rsi_TypeCreate(Context *rsc, RsElement _e, uint32_t dimX,
340a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams                     uint32_t dimY, uint32_t dimZ, bool mips, bool faces, uint32_t yuv) {
3412353ae303868d04e3a26002b2f2dc456c15e8170Jason Sams    Element *e = static_cast<Element *>(_e);
3422353ae303868d04e3a26002b2f2dc456c15e8170Jason Sams
343a572aca4eb4ddb32c10baa1f529431cfefd756b8Jason Sams    return Type::getType(rsc, e, dimX, dimY, dimZ, mips, faces, yuv);
344326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams}
345326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams
346c975cf4a71b63ccbd20f1f3b3341c5f2e6025b45Jason Sams}
347c975cf4a71b63ccbd20f1f3b3341c5f2e6025b45Jason Sams}
348c975cf4a71b63ccbd20f1f3b3341c5f2e6025b45Jason Sams
349c2ce707a3d1a8eae79bcf1c749afc6d6e7969ad9Tim Murrayextern "C" void rsaTypeGetNativeData(RsContext con, RsType type, uintptr_t *typeData, uint32_t typeDataSize) {
350dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    rsAssert(typeDataSize == 6);
35150bfc354e61e174a465893fd0dafe913f1954478Alex Sakhartchouk    // Pack the data in the follofing way mHal.state.dimX; mHal.state.dimY; mHal.state.dimZ;
352246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    // mHal.state.lodCount; mHal.state.faces; mElement; into typeData
353dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    Type *t = static_cast<Type *>(type);
354dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk
355dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    (*typeData++) = t->getDimX();
356dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    (*typeData++) = t->getDimY();
357dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    (*typeData++) = t->getDimZ();
358246fbee66ccb17cb1f08a5420e104a709183bce1Alex Sakhartchouk    (*typeData++) = t->getDimLOD() ? 1 : 0;
359dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    (*typeData++) = t->getDimFaces() ? 1 : 0;
360099bc262f862cdeb547cf8a78fe9e0e92560f437Tim Murray    (*typeData++) = (uintptr_t)t->getElement();
361dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk    t->getElement()->incUserRef();
362dc763f345db3e796efc28dc4b4d8edffda5a803eAlex Sakhartchouk}
363