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