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