blob: deb9c290779d8f9ad1678dc4404aaf90c44c2e6f [file] [log] [blame]
Jason Sams326e0dd2009-05-22 14:03:28 -07001/*
Jason Samsbc0ca6b2013-02-15 18:13:43 -08002 * Copyright (C) 2013 The Android Open Source Project
Jason Sams326e0dd2009-05-22 14:03:28 -07003 *
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#ifndef ANDROID_STRUCTURED_ALLOCATION_H
18#define ANDROID_STRUCTURED_ALLOCATION_H
19
20#include "rsType.h"
21
Miao Wang82e135c2017-02-27 23:35:35 -080022#include <vector>
23
Miao Wangc3e57652017-03-24 11:45:47 -070024struct AHardwareBuffer;
25
Jason Sams326e0dd2009-05-22 14:03:28 -070026// ---------------------------------------------------------------------------
27namespace android {
Jason Sams3522f402012-03-23 11:47:26 -070028
Jason Sams326e0dd2009-05-22 14:03:28 -070029namespace renderscript {
30
Jason Sams5c3e3bc2009-10-26 15:19:28 -070031class Program;
Miao Wangf750c532017-03-03 16:03:44 -080032class GrallocConsumer;
Jason Sams326e0dd2009-05-22 14:03:28 -070033
Stephen Hines1e5149f2011-08-08 15:06:40 -070034/*****************************************************************************
35 * CAUTION
36 *
37 * Any layout changes for this class may require a corresponding change to be
38 * made to frameworks/compile/libbcc/lib/ScriptCRT/rs_core.c, which contains
39 * a partial copy of the information below.
40 *
41 *****************************************************************************/
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080042class Allocation : public ObjectBase {
Stephen Hines1e5149f2011-08-08 15:06:40 -070043 // The graphics equivalent of malloc. The allocation contains a structure of elements.
Jason Sams326e0dd2009-05-22 14:03:28 -070044
Jason Sams326e0dd2009-05-22 14:03:28 -070045public:
Jason Sams807fdc42012-07-25 17:55:39 -070046 const static int MAX_LOD = 16;
Miao Wang47a58812015-07-23 21:59:16 -070047 // The mininum alignment requirement for RenderScript. Must be power of 2 and larger than 0.
48 const static size_t kMinimumRSAlignment = 16;
Miao Wang75474682015-10-26 16:50:13 -070049 // The maximun number of Allocations that can share a single BufferQueue;
50 const static uint32_t MAX_NUM_ALLOC = 16;
Jason Sams807fdc42012-07-25 17:55:39 -070051
Jason Samsbad80742011-03-16 16:29:28 -070052 struct Hal {
53 void * drv;
54
55 struct State {
Alex Sakhartchouk064aa7e2011-10-18 10:54:29 -070056 const Type * type;
Jason Samsbad80742011-03-16 16:29:28 -070057
58 uint32_t usageFlags;
59 RsAllocationMipmapControl mipmapControl;
60
61 // Cached fields from the Type and Element
62 // to prevent pointer chasing in critical loops.
Jason Samsa572aca2013-01-09 11:52:26 -080063 uint32_t yuv;
Jason Samsbad80742011-03-16 16:29:28 -070064 uint32_t elementSizeBytes;
65 bool hasMipmaps;
66 bool hasFaces;
67 bool hasReferences;
Tim Murray2e1a94d2012-11-29 13:12:25 -080068 void * userProvidedPtr;
Jason Samscf27eb42012-02-10 13:24:18 -080069 int32_t surfaceTextureID;
Miao Wangc3e57652017-03-24 11:45:47 -070070 AHardwareBuffer *nativeBuffer;
Jason Samsddceab92013-08-07 13:02:32 -070071 int64_t timestamp;
Jason Samscfea6c12015-02-09 12:50:22 -080072
73 // Allocation adapter state
74 const Allocation *baseAlloc;
75 uint32_t originX;
76 uint32_t originY;
77 uint32_t originZ;
78 uint32_t originLOD;
79 uint32_t originFace;
80 uint32_t originArray[Type::mMaxArrays];
Jason Samsbad80742011-03-16 16:29:28 -070081 };
82 State state;
Jason Samseb4fe182011-05-26 16:33:01 -070083
84 struct DrvState {
Jason Sams709a0972012-11-15 18:18:04 -080085 struct LodState {
86 void * mallocPtr;
87 size_t stride;
88 uint32_t dimX;
89 uint32_t dimY;
90 uint32_t dimZ;
91 } lod[android::renderscript::Allocation::MAX_LOD];
92 size_t faceOffset;
93 uint32_t lodCount;
94 uint32_t faceCount;
Jason Sams61656a72013-09-03 16:21:18 -070095
96 struct YuvState {
97 uint32_t shift;
98 uint32_t step;
99 } yuv;
Jason Samse49da132014-10-23 17:32:27 -0700100
101 int grallocFlags;
Jason Samscfea6c12015-02-09 12:50:22 -0800102 uint32_t dimArray[Type::mMaxArrays];
Jason Sams709a0972012-11-15 18:18:04 -0800103 };
104 mutable DrvState drvState;
Jason Samseb4fe182011-05-26 16:33:01 -0700105
Jason Samsbad80742011-03-16 16:29:28 -0700106 };
107 Hal mHal;
108
Tim Murray34689382013-03-11 12:12:03 -0700109 void operator delete(void* ptr);
110
Jason Samseb4fe182011-05-26 16:33:01 -0700111 static Allocation * createAllocation(Context *rsc, const Type *, uint32_t usages,
Jason Sams179e9a42011-11-23 15:02:15 -0800112 RsAllocationMipmapControl mc = RS_ALLOCATION_MIPMAP_NONE,
113 void *ptr = 0);
Miao Wang47a58812015-07-23 21:59:16 -0700114 static Allocation * createAllocationStrided(Context *rsc, const Type *, uint32_t usages,
115 RsAllocationMipmapControl mc = RS_ALLOCATION_MIPMAP_NONE,
116 void *ptr = 0, size_t byteAligned = 16);
Jason Samscfea6c12015-02-09 12:50:22 -0800117 static Allocation * createAdapter(Context *rsc, const Allocation *alloc, const Type *type);
118
119
Jason Sams326e0dd2009-05-22 14:03:28 -0700120 virtual ~Allocation();
Jason Samsbad80742011-03-16 16:29:28 -0700121 void updateCache();
Jason Sams326e0dd2009-05-22 14:03:28 -0700122
Alex Sakhartchouk064aa7e2011-10-18 10:54:29 -0700123 const Type * getType() const {return mHal.state.type;}
Jason Sams326e0dd2009-05-22 14:03:28 -0700124
Jason Sams366c9c82010-12-08 16:14:36 -0800125 void syncAll(Context *rsc, RsAllocationUsageType src);
126
Jason Sams96abf812010-10-05 13:32:49 -0700127 void copyRange1D(Context *rsc, const Allocation *src, int32_t srcOff, int32_t destOff, int32_t len);
128
129 void resize1D(Context *rsc, uint32_t dimX);
130 void resize2D(Context *rsc, uint32_t dimX, uint32_t dimY);
Jason Sams326e0dd2009-05-22 14:03:28 -0700131
Stephen Hines6ae039b2012-01-18 18:46:27 -0800132 void data(Context *rsc, uint32_t xoff, uint32_t lod, uint32_t count, const void *data, size_t sizeBytes);
Jason Sams4b45b892010-12-29 14:31:29 -0800133 void data(Context *rsc, uint32_t xoff, uint32_t yoff, uint32_t lod, RsAllocationCubemapFace face,
Tim Murray358747a2012-11-26 13:52:04 -0800134 uint32_t w, uint32_t h, const void *data, size_t sizeBytes, size_t stride);
Jason Sams3bbc0fd2013-04-09 14:16:13 -0700135 void data(Context *rsc, uint32_t xoff, uint32_t yoff, uint32_t zoff, uint32_t lod,
136 uint32_t w, uint32_t h, uint32_t d, const void *data, size_t sizeBytes, size_t stride);
Jason Sams326e0dd2009-05-22 14:03:28 -0700137
Jason Sams807fdc42012-07-25 17:55:39 -0700138 void read(Context *rsc, uint32_t xoff, uint32_t lod, uint32_t count, void *data, size_t sizeBytes);
Tim Murray358747a2012-11-26 13:52:04 -0800139 void read(Context *rsc, uint32_t xoff, uint32_t yoff, uint32_t lod, RsAllocationCubemapFace face,
140 uint32_t w, uint32_t h, void *data, size_t sizeBytes, size_t stride);
Jason Sams3bbc0fd2013-04-09 14:16:13 -0700141 void read(Context *rsc, uint32_t xoff, uint32_t yoff, uint32_t zoff, uint32_t lod,
142 uint32_t w, uint32_t h, uint32_t d, void *data, size_t sizeBytes, size_t stride);
Jason Sams807fdc42012-07-25 17:55:39 -0700143
Miao Wangcc8cea72015-02-19 18:14:46 -0800144 void elementData(Context *rsc, uint32_t x, uint32_t y, uint32_t z,
Stephen Hines6ae039b2012-01-18 18:46:27 -0800145 const void *data, uint32_t elementOff, size_t sizeBytes);
Miao Wangcc8cea72015-02-19 18:14:46 -0800146
147 void elementRead(Context *rsc, uint32_t x, uint32_t y, uint32_t z,
148 void *data, uint32_t elementOff, size_t sizeBytes);
Jason Sams5f0c84c2010-08-31 13:50:42 -0700149
Jason Sams5c3e3bc2009-10-26 15:19:28 -0700150 void addProgramToDirty(const Program *);
151 void removeProgramToDirty(const Program *);
Jason Samse5ffb872009-08-09 17:01:55 -0700152
Jason Samsc21cf402009-11-17 17:26:46 -0800153 virtual void dumpLOGV(const char *prefix) const;
Jason Samse3150cf2012-07-24 18:10:20 -0700154 virtual void serialize(Context *rsc, OStream *stream) const;
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700155 virtual RsA3DClassID getClassId() const { return RS_A3D_CLASS_ID_ALLOCATION; }
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700156 static Allocation *createFromStream(Context *rsc, IStream *stream);
Jason Samsc21cf402009-11-17 17:26:46 -0800157
Jason Samsb89b0b72010-12-13 17:11:21 -0800158 bool getIsScript() const {
Jason Samsbad80742011-03-16 16:29:28 -0700159 return (mHal.state.usageFlags & RS_ALLOCATION_USAGE_SCRIPT) != 0;
Jason Samsb89b0b72010-12-13 17:11:21 -0800160 }
Jason Samsebc50192010-12-13 15:32:35 -0800161 bool getIsTexture() const {
Jason Samsbad80742011-03-16 16:29:28 -0700162 return (mHal.state.usageFlags & RS_ALLOCATION_USAGE_GRAPHICS_TEXTURE) != 0;
Jason Samsebc50192010-12-13 15:32:35 -0800163 }
Alex Sakhartchouk7d9c5ff2011-04-01 14:19:01 -0700164 bool getIsRenderTarget() const {
165 return (mHal.state.usageFlags & RS_ALLOCATION_USAGE_GRAPHICS_RENDER_TARGET) != 0;
166 }
Jason Samsebc50192010-12-13 15:32:35 -0800167 bool getIsBufferObject() const {
Jason Samsbad80742011-03-16 16:29:28 -0700168 return (mHal.state.usageFlags & RS_ALLOCATION_USAGE_GRAPHICS_VERTEX) != 0;
Jason Samsebc50192010-12-13 15:32:35 -0800169 }
Jason Sams760f1f72010-06-25 12:45:41 -0700170
Jason Sams96abf812010-10-05 13:32:49 -0700171 void incRefs(const void *ptr, size_t ct, size_t startOff = 0) const;
172 void decRefs(const void *ptr, size_t ct, size_t startOff = 0) const;
Jason Samsa36c50a2014-06-17 12:06:06 -0700173 virtual void callUpdateCacheObject(const Context *rsc, void *dstObj) const;
Jason Samsc7cec1e2011-08-18 18:01:33 -0700174 virtual bool freeChildren();
Jason Samse3929c92010-08-09 18:13:33 -0700175
Jason Samseb4fe182011-05-26 16:33:01 -0700176 void sendDirty(const Context *rsc) const;
Jason Samsb89b0b72010-12-13 17:11:21 -0800177 bool getHasGraphicsMipmaps() const {
Jason Samsbad80742011-03-16 16:29:28 -0700178 return mHal.state.mipmapControl != RS_ALLOCATION_MIPMAP_NONE;
Jason Samsb89b0b72010-12-13 17:11:21 -0800179 }
180
Miao Wang75474682015-10-26 16:50:13 -0700181 void setupGrallocConsumer(const Context *rsc, uint32_t numAlloc);
182 void shareBufferQueue(const Context *rsc, const Allocation *alloc);
Jason Sams733396b2013-02-22 12:46:18 -0800183 void * getSurface(const Context *rsc);
Jason Sams7ac2a4d2012-02-15 12:04:24 -0800184 void setSurface(const Context *rsc, RsNativeWindow sur);
185 void ioSend(const Context *rsc);
186 void ioReceive(const Context *rsc);
Miao Wang75474682015-10-26 16:50:13 -0700187 int64_t getTimeStamp() {return mHal.state.timestamp;}
Jason Sams5c3e3bc2009-10-26 15:19:28 -0700188
Jason Sams442b7ff2015-03-06 16:50:11 -0800189 void adapterOffset(Context *rsc, const uint32_t *offsets, size_t len);
190
Jason Samsb8a94e22014-02-24 17:52:32 -0800191 void * getPointer(const Context *rsc, uint32_t lod, RsAllocationCubemapFace face,
192 uint32_t z, uint32_t array, size_t *stride);
193
Jason Samsc0d68472015-01-20 14:29:52 -0800194 void * getPointerUnchecked(uint32_t x, uint32_t y,
195 uint32_t z = 0, uint32_t lod = 0,
196 RsAllocationCubemapFace face = RS_ALLOCATION_CUBEMAP_FACE_POSITIVE_X,
197 uint32_t a1 = 0, uint32_t a2 = 0, uint32_t a3 = 0, uint32_t a4 = 0) const {
198
199 uint8_t * p = (uint8_t *) mHal.drvState.lod[lod].mallocPtr;
200 p += x * getType()->getElementSizeBytes();
201 p += y * mHal.drvState.lod[lod].stride;
202 p += z * mHal.drvState.lod[lod].stride * mHal.drvState.lod[lod].dimY;
203
204 // Todo: arrays
205
206 return p;
207 }
208
Chris Wailes4b3c34e2014-06-11 12:00:29 -0700209 bool hasSameDims(const Allocation *Other) const;
210
Alex Sakhartchouk1e5168d2010-09-01 16:34:48 -0700211protected:
Miao Wang82e135c2017-02-27 23:35:35 -0800212 std::vector<const Program *> mToDirtyList;
Alex Sakhartchouk064aa7e2011-10-18 10:54:29 -0700213 ObjectBaseRef<const Type> mType;
214 void setType(const Type *t) {
215 mType.set(t);
216 mHal.state.type = t;
217 }
Jason Sams5c3e3bc2009-10-26 15:19:28 -0700218
Miao Wang62237212017-02-27 15:19:36 -0800219#ifndef RS_COMPATIBILITY_LIB
Miao Wangf750c532017-03-03 16:03:44 -0800220 GrallocConsumer *mGrallocConsumer = nullptr;
Miao Wang75474682015-10-26 16:50:13 -0700221 bool mBufferQueueInited = false;
222 uint32_t mCurrentIdx;
Jason Samsddceab92013-08-07 13:02:32 -0700223#endif
224
225
Jason Samsfa84da22010-03-01 15:31:04 -0800226private:
Jason Samsc7cec1e2011-08-18 18:01:33 -0700227 void freeChildrenUnlocked();
Jason Sams179e9a42011-11-23 15:02:15 -0800228 Allocation(Context *rsc, const Type *, uint32_t usages, RsAllocationMipmapControl mc, void *ptr);
Jason Samscfea6c12015-02-09 12:50:22 -0800229 Allocation(Context *rsc, const Allocation *, const Type *);
Alex Sakhartchouk2d1220c2011-11-15 15:15:21 -0800230
231 uint32_t getPackedSize() const;
Jason Sams807fdc42012-07-25 17:55:39 -0700232 static void writePackedData(Context *rsc, const Type *type, uint8_t *dst,
233 const uint8_t *src, bool dstPadded);
Jason Samse3150cf2012-07-24 18:10:20 -0700234 void unpackVec3Allocation(Context *rsc, const void *data, size_t dataSize);
235 void packVec3Allocation(Context *rsc, OStream *stream) const;
Jason Sams326e0dd2009-05-22 14:03:28 -0700236};
237
Rahul Chaudhry7974fc02017-02-09 12:33:28 -0800238} // namespace renderscript
239} // namespace android
Jason Sams326e0dd2009-05-22 14:03:28 -0700240#endif