Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 1 | /* |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 2 | * Copyright (C) 2013 The Android Open Source Project |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #include "rsContext.h" |
| 18 | |
Stephen Hines | 10f3170 | 2013-08-15 17:30:12 -0700 | [diff] [blame] | 19 | #if !defined(RS_SERVER) && !defined(RS_COMPATIBILITY_LIB) |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 20 | #include "system/graphics.h" |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 21 | #endif |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 22 | |
Stephen Hines | 10f3170 | 2013-08-15 17:30:12 -0700 | [diff] [blame] | 23 | #ifdef RS_COMPATIBILITY_LIB |
| 24 | #include "rsCompatibilityLib.h" |
| 25 | #endif |
| 26 | |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 27 | using namespace android; |
| 28 | using namespace android::renderscript; |
| 29 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 30 | Type::Type(Context *rsc) : ObjectBase(rsc) { |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 31 | memset(&mHal, 0, sizeof(mHal)); |
| 32 | mDimLOD = false; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 33 | } |
| 34 | |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 35 | void Type::preDestroy() const { |
Chris Wailes | 93d6bc8 | 2014-07-28 16:54:38 -0700 | [diff] [blame] | 36 | auto &types = mRSC->mStateType.mTypes; |
| 37 | |
| 38 | for (auto typeIter = types.begin(), endIter = types.end(); |
| 39 | typeIter != endIter; typeIter++) { |
| 40 | |
| 41 | if (this == *typeIter) { |
| 42 | types.erase(typeIter); |
| 43 | return; |
Jason Sams | 8154954 | 2010-02-17 15:38:10 -0800 | [diff] [blame] | 44 | } |
| 45 | } |
Jason Sams | 225afd3 | 2010-10-21 14:06:55 -0700 | [diff] [blame] | 46 | } |
| 47 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 48 | Type::~Type() { |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 49 | clear(); |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 50 | } |
| 51 | |
Tim Murray | 49a8777 | 2014-07-10 10:00:00 -0700 | [diff] [blame] | 52 | void Type::operator delete(void* ptr) { |
| 53 | if (ptr) { |
| 54 | Type *t = (Type*) ptr; |
| 55 | t->getContext()->mHal.funcs.freeRuntimeMem(ptr); |
| 56 | } |
| 57 | } |
| 58 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 59 | void Type::clear() { |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 60 | if (mHal.state.lodCount) { |
| 61 | delete [] mHal.state.lodDimX; |
| 62 | delete [] mHal.state.lodDimY; |
| 63 | delete [] mHal.state.lodDimZ; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 64 | } |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 65 | if (mHal.state.arrayCount > 0) { |
| 66 | delete [] mHal.state.arrays; |
| 67 | } |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 68 | mElement.clear(); |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 69 | memset(&mHal, 0, sizeof(mHal)); |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 70 | } |
| 71 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 72 | TypeState::TypeState() { |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 73 | } |
| 74 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 75 | TypeState::~TypeState() { |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 76 | rsAssert(!mTypes.size()); |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 77 | } |
| 78 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 79 | void Type::compute() { |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 80 | uint32_t oldLODCount = mHal.state.lodCount; |
| 81 | if (mDimLOD) { |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 82 | uint32_t l2x = rsFindHighBit(mHal.state.dimX) + 1; |
| 83 | uint32_t l2y = rsFindHighBit(mHal.state.dimY) + 1; |
| 84 | uint32_t l2z = rsFindHighBit(mHal.state.dimZ) + 1; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 85 | |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 86 | mHal.state.lodCount = rsMax(l2x, l2y); |
| 87 | mHal.state.lodCount = rsMax(mHal.state.lodCount, l2z); |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 88 | } else { |
Jason Sams | d06653c | 2014-08-01 16:18:33 -0700 | [diff] [blame] | 89 | if (mHal.state.dimYuv) { |
| 90 | mHal.state.lodCount = 3; |
| 91 | } else { |
| 92 | mHal.state.lodCount = 1; |
| 93 | } |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 94 | } |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 95 | if (mHal.state.lodCount != oldLODCount) { |
| 96 | if (oldLODCount) { |
| 97 | delete [] mHal.state.lodDimX; |
| 98 | delete [] mHal.state.lodDimY; |
| 99 | delete [] mHal.state.lodDimZ; |
Alex Sakhartchouk | 417e6a4 | 2010-07-15 11:33:03 -0700 | [diff] [blame] | 100 | } |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 101 | mHal.state.lodDimX = new uint32_t[mHal.state.lodCount]; |
| 102 | mHal.state.lodDimY = new uint32_t[mHal.state.lodCount]; |
| 103 | mHal.state.lodDimZ = new uint32_t[mHal.state.lodCount]; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 104 | } |
| 105 | |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 106 | uint32_t tx = mHal.state.dimX; |
| 107 | uint32_t ty = mHal.state.dimY; |
| 108 | uint32_t tz = mHal.state.dimZ; |
Jason Sams | 61656a7 | 2013-09-03 16:21:18 -0700 | [diff] [blame] | 109 | mCellCount = 0; |
Jason Sams | d06653c | 2014-08-01 16:18:33 -0700 | [diff] [blame] | 110 | if (!mHal.state.dimYuv) { |
| 111 | for (uint32_t lod=0; lod < mHal.state.lodCount; lod++) { |
| 112 | mHal.state.lodDimX[lod] = tx; |
| 113 | mHal.state.lodDimY[lod] = ty; |
| 114 | mHal.state.lodDimZ[lod] = tz; |
| 115 | mCellCount += tx * rsMax(ty, 1u) * rsMax(tz, 1u); |
| 116 | if (tx > 1) tx >>= 1; |
| 117 | if (ty > 1) ty >>= 1; |
| 118 | if (tz > 1) tz >>= 1; |
| 119 | } |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 120 | } |
| 121 | |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 122 | if (mHal.state.faces) { |
Jason Sams | 61656a7 | 2013-09-03 16:21:18 -0700 | [diff] [blame] | 123 | mCellCount *= 6; |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 124 | } |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 125 | #ifndef RS_SERVER |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 126 | // YUV only supports basic 2d |
| 127 | // so we can stash the plane pointers in the mipmap levels. |
| 128 | if (mHal.state.dimYuv) { |
Jason Sams | 61656a7 | 2013-09-03 16:21:18 -0700 | [diff] [blame] | 129 | mHal.state.lodDimX[1] = mHal.state.lodDimX[0] / 2; |
| 130 | mHal.state.lodDimY[1] = mHal.state.lodDimY[0] / 2; |
| 131 | mHal.state.lodDimX[2] = mHal.state.lodDimX[0] / 2; |
| 132 | mHal.state.lodDimY[2] = mHal.state.lodDimY[0] / 2; |
Jason Sams | d06653c | 2014-08-01 16:18:33 -0700 | [diff] [blame] | 133 | mCellCount += mHal.state.lodDimX[0] * mHal.state.lodDimY[0]; |
Jason Sams | 61656a7 | 2013-09-03 16:21:18 -0700 | [diff] [blame] | 134 | mCellCount += mHal.state.lodDimX[1] * mHal.state.lodDimY[1]; |
| 135 | mCellCount += mHal.state.lodDimX[2] * mHal.state.lodDimY[2]; |
| 136 | |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 137 | switch(mHal.state.dimYuv) { |
| 138 | case HAL_PIXEL_FORMAT_YV12: |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 139 | break; |
| 140 | case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21 |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 141 | mHal.state.lodDimX[1] = mHal.state.lodDimX[0]; |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 142 | break; |
Jason Sams | 61656a7 | 2013-09-03 16:21:18 -0700 | [diff] [blame] | 143 | #ifndef RS_COMPATIBILITY_LIB |
| 144 | case HAL_PIXEL_FORMAT_YCbCr_420_888: |
| 145 | break; |
| 146 | #endif |
Jason Sams | bc0ca6b | 2013-02-15 18:13:43 -0800 | [diff] [blame] | 147 | default: |
| 148 | rsAssert(0); |
| 149 | } |
| 150 | } |
Tim Murray | 0b575de | 2013-03-15 15:56:43 -0700 | [diff] [blame] | 151 | #endif |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 152 | mHal.state.element = mElement.get(); |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 153 | } |
| 154 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 155 | void Type::dumpLOGV(const char *prefix) const { |
Jason Sams | e12c1c5 | 2009-09-27 17:50:38 -0700 | [diff] [blame] | 156 | char buf[1024]; |
| 157 | ObjectBase::dumpLOGV(prefix); |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 158 | ALOGV("%s Type: x=%u y=%u z=%u mip=%i face=%i", prefix, |
| 159 | mHal.state.dimX, |
| 160 | mHal.state.dimY, |
| 161 | mHal.state.dimZ, |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 162 | mHal.state.lodCount, |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 163 | mHal.state.faces); |
Jason Sams | 87319de | 2010-11-22 16:20:16 -0800 | [diff] [blame] | 164 | snprintf(buf, sizeof(buf), "%s element: ", prefix); |
Jason Sams | e12c1c5 | 2009-09-27 17:50:38 -0700 | [diff] [blame] | 165 | mElement->dumpLOGV(buf); |
| 166 | } |
| 167 | |
Jason Sams | e3150cf | 2012-07-24 18:10:20 -0700 | [diff] [blame] | 168 | void Type::serialize(Context *rsc, OStream *stream) const { |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 169 | // Need to identify ourselves |
| 170 | stream->addU32((uint32_t)getClassId()); |
Jason Sams | 48ecf6a | 2013-07-09 15:35:29 -0700 | [diff] [blame] | 171 | stream->addString(getName()); |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 172 | |
Jason Sams | e3150cf | 2012-07-24 18:10:20 -0700 | [diff] [blame] | 173 | mElement->serialize(rsc, stream); |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 174 | |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 175 | stream->addU32(mHal.state.dimX); |
| 176 | stream->addU32(mHal.state.dimY); |
| 177 | stream->addU32(mHal.state.dimZ); |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 178 | |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 179 | stream->addU8((uint8_t)(mHal.state.lodCount ? 1 : 0)); |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 180 | stream->addU8((uint8_t)(mHal.state.faces ? 1 : 0)); |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 181 | } |
| 182 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 183 | Type *Type::createFromStream(Context *rsc, IStream *stream) { |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 184 | // First make sure we are reading the correct object |
Alex Sakhartchouk | b825f67 | 2010-06-04 10:06:50 -0700 | [diff] [blame] | 185 | RsA3DClassID classID = (RsA3DClassID)stream->loadU32(); |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 186 | if (classID != RS_A3D_CLASS_ID_TYPE) { |
Steve Block | af12ac6 | 2012-01-06 19:20:56 +0000 | [diff] [blame] | 187 | ALOGE("type loading skipped due to invalid class id\n"); |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 188 | return nullptr; |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 189 | } |
| 190 | |
Jason Sams | 48ecf6a | 2013-07-09 15:35:29 -0700 | [diff] [blame] | 191 | const char *name = stream->loadString(); |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 192 | |
| 193 | Element *elem = Element::createFromStream(rsc, stream); |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 194 | if (!elem) { |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 195 | return nullptr; |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 196 | } |
| 197 | |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 198 | RsTypeCreateParams p; |
| 199 | memset(&p, 0, sizeof(p)); |
| 200 | p.dimX = stream->loadU32(); |
| 201 | p.dimY = stream->loadU32(); |
| 202 | p.dimZ = stream->loadU32(); |
| 203 | p.mipmaps = stream->loadU8(); |
| 204 | p.faces = stream->loadU8(); |
| 205 | Type *type = Type::getType(rsc, elem, &p, sizeof(p)); |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 206 | elem->decUserRef(); |
Jason Sams | 48ecf6a | 2013-07-09 15:35:29 -0700 | [diff] [blame] | 207 | |
| 208 | delete [] name; |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 209 | return type; |
Alex Sakhartchouk | fb6b614 | 2010-05-21 12:53:13 -0700 | [diff] [blame] | 210 | } |
| 211 | |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 212 | bool Type::getIsNp2() const { |
Jason Sams | ef21edc | 2010-02-22 15:37:51 -0800 | [diff] [blame] | 213 | uint32_t x = getDimX(); |
| 214 | uint32_t y = getDimY(); |
| 215 | uint32_t z = getDimZ(); |
| 216 | |
| 217 | if (x && (x & (x-1))) { |
| 218 | return true; |
| 219 | } |
| 220 | if (y && (y & (y-1))) { |
| 221 | return true; |
| 222 | } |
| 223 | if (z && (z & (z-1))) { |
| 224 | return true; |
| 225 | } |
| 226 | return false; |
| 227 | } |
| 228 | |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 229 | ObjectBaseRef<Type> Type::getTypeRef(Context *rsc, const Element *e, |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 230 | const RsTypeCreateParams *params, size_t len) { |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 231 | ObjectBaseRef<Type> returnRef; |
Jason Sams | e12c1c5 | 2009-09-27 17:50:38 -0700 | [diff] [blame] | 232 | |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 233 | TypeState * stc = &rsc->mStateType; |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 234 | |
| 235 | ObjectBase::asyncLock(); |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 236 | for (uint32_t ct=0; ct < stc->mTypes.size(); ct++) { |
| 237 | Type *t = stc->mTypes[ct]; |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 238 | if (t->getElement() != e) continue; |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 239 | if (t->getDimX() != params->dimX) continue; |
| 240 | if (t->getDimY() != params->dimY) continue; |
| 241 | if (t->getDimZ() != params->dimZ) continue; |
| 242 | if (t->getDimLOD() != params->mipmaps) continue; |
| 243 | if (t->getDimFaces() != params->faces) continue; |
| 244 | if (t->getDimYuv() != params->yuv) continue; |
| 245 | if (t->getArray(0) != params->array0) continue; |
| 246 | if (t->getArray(1) != params->array1) continue; |
| 247 | if (t->getArray(2) != params->array2) continue; |
| 248 | if (t->getArray(3) != params->array3) continue; |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 249 | returnRef.set(t); |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 250 | ObjectBase::asyncUnlock(); |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 251 | return returnRef; |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 252 | } |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 253 | ObjectBase::asyncUnlock(); |
| 254 | |
Tim Murray | 665eafe | 2014-07-01 10:04:48 -0700 | [diff] [blame] | 255 | // Type objects must use allocator specified by the driver |
| 256 | void* allocMem = rsc->mHal.funcs.allocRuntimeMem(sizeof(Type), 0); |
| 257 | if (!allocMem) { |
| 258 | rsc->setError(RS_ERROR_FATAL_DRIVER, "Couldn't allocate memory for Type"); |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 259 | return nullptr; |
Tim Murray | 665eafe | 2014-07-01 10:04:48 -0700 | [diff] [blame] | 260 | } |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 261 | |
Tim Murray | 665eafe | 2014-07-01 10:04:48 -0700 | [diff] [blame] | 262 | Type *nt = new (allocMem) Type(rsc); |
Tim Murray | e3af53b | 2014-06-10 09:46:51 -0700 | [diff] [blame] | 263 | |
| 264 | #ifdef RS_FIND_OFFSETS |
| 265 | ALOGE("pointer for type: %p", nt); |
| 266 | ALOGE("pointer for type.drv: %p", &nt->mHal.drv); |
| 267 | #endif |
| 268 | |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 269 | nt->mDimLOD = params->mipmaps; |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 270 | returnRef.set(nt); |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 271 | nt->mElement.set(e); |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 272 | nt->mHal.state.dimX = params->dimX; |
| 273 | nt->mHal.state.dimY = params->dimY; |
| 274 | nt->mHal.state.dimZ = params->dimZ; |
| 275 | nt->mHal.state.faces = params->faces; |
| 276 | nt->mHal.state.dimYuv = params->yuv; |
| 277 | |
| 278 | nt->mHal.state.arrayCount = 0; |
| 279 | if (params->array0 > 0) nt->mHal.state.arrayCount ++; |
| 280 | if (params->array1 > 0) nt->mHal.state.arrayCount ++; |
| 281 | if (params->array2 > 0) nt->mHal.state.arrayCount ++; |
| 282 | if (params->array3 > 0) nt->mHal.state.arrayCount ++; |
| 283 | if (nt->mHal.state.arrayCount > 0) { |
| 284 | nt->mHal.state.arrays = new uint32_t[nt->mHal.state.arrayCount]; |
| 285 | if (params->array0 > 0) nt->mHal.state.arrays[0] = params->array0; |
| 286 | if (params->array1 > 1) nt->mHal.state.arrays[1] = params->array1; |
| 287 | if (params->array2 > 2) nt->mHal.state.arrays[2] = params->array2; |
| 288 | if (params->array3 > 3) nt->mHal.state.arrays[3] = params->array3; |
| 289 | } |
| 290 | |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 291 | nt->compute(); |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 292 | |
| 293 | ObjectBase::asyncLock(); |
Chris Wailes | 93d6bc8 | 2014-07-28 16:54:38 -0700 | [diff] [blame] | 294 | stc->mTypes.push_back(nt); |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 295 | ObjectBase::asyncUnlock(); |
| 296 | |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 297 | return returnRef; |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 298 | } |
| 299 | |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 300 | ObjectBaseRef<Type> Type::cloneAndResize1D(Context *rsc, uint32_t dimX) const { |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 301 | RsTypeCreateParams p; |
| 302 | memset(&p, 0, sizeof(p)); |
| 303 | p.dimX = dimX; |
| 304 | p.dimY = getDimY(); |
| 305 | p.dimZ = getDimZ(); |
| 306 | p.mipmaps = getDimLOD(); |
| 307 | return getTypeRef(rsc, mElement.get(), &p, sizeof(p)); |
Jason Sams | f0c1df4 | 2010-10-26 13:09:17 -0700 | [diff] [blame] | 308 | } |
| 309 | |
Alex Sakhartchouk | c700e64 | 2011-08-16 13:09:46 -0700 | [diff] [blame] | 310 | ObjectBaseRef<Type> Type::cloneAndResize2D(Context *rsc, |
Alex Sakhartchouk | afb743a | 2010-11-09 17:00:54 -0800 | [diff] [blame] | 311 | uint32_t dimX, |
| 312 | uint32_t dimY) const { |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 313 | RsTypeCreateParams p; |
| 314 | memset(&p, 0, sizeof(p)); |
| 315 | p.dimX = dimX; |
| 316 | p.dimY = dimY; |
| 317 | p.dimZ = getDimZ(); |
| 318 | p.mipmaps = getDimLOD(); |
| 319 | p.faces = getDimFaces(); |
| 320 | p.yuv = getDimYuv(); |
| 321 | return getTypeRef(rsc, mElement.get(), &p, sizeof(p)); |
Jason Sams | 96abf81 | 2010-10-05 13:32:49 -0700 | [diff] [blame] | 322 | } |
| 323 | |
| 324 | |
Stephen Hines | 9f70a4e | 2012-04-02 20:18:48 -0700 | [diff] [blame] | 325 | void Type::incRefs(const void *ptr, size_t ct, size_t startOff) const { |
| 326 | const uint8_t *p = static_cast<const uint8_t *>(ptr); |
| 327 | const Element *e = mHal.state.element; |
| 328 | uint32_t stride = e->getSizeBytes(); |
| 329 | |
| 330 | p += stride * startOff; |
| 331 | while (ct > 0) { |
| 332 | e->incRefs(p); |
| 333 | ct--; |
| 334 | p += stride; |
| 335 | } |
| 336 | } |
| 337 | |
| 338 | |
| 339 | void Type::decRefs(const void *ptr, size_t ct, size_t startOff) const { |
| 340 | if (!mHal.state.element->getHasReferences()) { |
| 341 | return; |
| 342 | } |
| 343 | const uint8_t *p = static_cast<const uint8_t *>(ptr); |
| 344 | const Element *e = mHal.state.element; |
| 345 | uint32_t stride = e->getSizeBytes(); |
| 346 | |
| 347 | p += stride * startOff; |
| 348 | while (ct > 0) { |
| 349 | e->decRefs(p); |
| 350 | ct--; |
| 351 | p += stride; |
| 352 | } |
| 353 | } |
| 354 | |
Jason Sams | a36c50a | 2014-06-17 12:06:06 -0700 | [diff] [blame] | 355 | void Type::callUpdateCacheObject(const Context *rsc, void *dstObj) const { |
Chris Wailes | 44bef6f | 2014-08-12 13:51:10 -0700 | [diff] [blame] | 356 | if (rsc->mHal.funcs.type.updateCachedObject != nullptr) { |
Jason Sams | a36c50a | 2014-06-17 12:06:06 -0700 | [diff] [blame] | 357 | rsc->mHal.funcs.type.updateCachedObject(rsc, this, (rs_type *)dstObj); |
| 358 | } else { |
| 359 | *((const void **)dstObj) = this; |
| 360 | } |
| 361 | } |
Stephen Hines | 9f70a4e | 2012-04-02 20:18:48 -0700 | [diff] [blame] | 362 | |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 363 | ////////////////////////////////////////////////// |
Jason Sams | e5ffb87 | 2009-08-09 17:01:55 -0700 | [diff] [blame] | 364 | // |
Jason Sams | 326e0dd | 2009-05-22 14:03:28 -0700 | [diff] [blame] | 365 | namespace android { |
| 366 | namespace renderscript { |
| 367 | |
Jason Sams | c975cf4 | 2011-04-28 18:26:48 -0700 | [diff] [blame] | 368 | RsType rsi_TypeCreate(Context *rsc, RsElement _e, uint32_t dimX, |
Stephen Hines | 8f615d6 | 2013-12-20 12:23:32 -0800 | [diff] [blame] | 369 | uint32_t dimY, uint32_t dimZ, bool mipmaps, bool faces, uint32_t yuv) { |
Jason Sams | 2353ae3 | 2010-10-14 17:48:46 -0700 | [diff] [blame] | 370 | Element *e = static_cast<Element *>(_e); |
Jason Sams | 2353ae3 | 2010-10-14 17:48:46 -0700 | [diff] [blame] | 371 | |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 372 | RsTypeCreateParams p; |
| 373 | memset(&p, 0, sizeof(p)); |
| 374 | p.dimX = dimX; |
| 375 | p.dimY = dimY; |
| 376 | p.dimZ = dimZ; |
| 377 | p.mipmaps = mipmaps; |
| 378 | p.faces = faces; |
| 379 | p.yuv = yuv; |
| 380 | return Type::getType(rsc, e, &p, sizeof(p)); |
| 381 | } |
| 382 | |
Jason Sams | 554d08c | 2015-01-12 16:23:50 -0800 | [diff] [blame] | 383 | RsType rsi_TypeCreate2(Context *rsc, const RsTypeCreateParams *p, size_t len) { |
Jason Sams | c7968a0 | 2014-11-11 16:24:36 -0800 | [diff] [blame] | 384 | Element *e = static_cast<Element *>(p->e); |
| 385 | return Type::getType(rsc, e, p, len); |
Jason Sams | 2353ae3 | 2010-10-14 17:48:46 -0700 | [diff] [blame] | 386 | } |
| 387 | |
Jason Sams | c975cf4 | 2011-04-28 18:26:48 -0700 | [diff] [blame] | 388 | } |
| 389 | } |
| 390 | |
Tim Murray | c2ce707 | 2013-07-17 18:38:53 -0700 | [diff] [blame] | 391 | extern "C" void rsaTypeGetNativeData(RsContext con, RsType type, uintptr_t *typeData, uint32_t typeDataSize) { |
Alex Sakhartchouk | dc763f3 | 2010-10-27 14:10:07 -0700 | [diff] [blame] | 392 | rsAssert(typeDataSize == 6); |
Alex Sakhartchouk | 50bfc35 | 2011-12-20 12:37:59 -0800 | [diff] [blame] | 393 | // Pack the data in the follofing way mHal.state.dimX; mHal.state.dimY; mHal.state.dimZ; |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 394 | // mHal.state.lodCount; mHal.state.faces; mElement; into typeData |
Alex Sakhartchouk | dc763f3 | 2010-10-27 14:10:07 -0700 | [diff] [blame] | 395 | Type *t = static_cast<Type *>(type); |
| 396 | |
| 397 | (*typeData++) = t->getDimX(); |
| 398 | (*typeData++) = t->getDimY(); |
| 399 | (*typeData++) = t->getDimZ(); |
Alex Sakhartchouk | 246fbee | 2012-03-08 14:52:36 -0800 | [diff] [blame] | 400 | (*typeData++) = t->getDimLOD() ? 1 : 0; |
Alex Sakhartchouk | dc763f3 | 2010-10-27 14:10:07 -0700 | [diff] [blame] | 401 | (*typeData++) = t->getDimFaces() ? 1 : 0; |
Tim Murray | 099bc26 | 2013-03-20 16:54:03 -0700 | [diff] [blame] | 402 | (*typeData++) = (uintptr_t)t->getElement(); |
Alex Sakhartchouk | dc763f3 | 2010-10-27 14:10:07 -0700 | [diff] [blame] | 403 | t->getElement()->incUserRef(); |
| 404 | } |