/* * Copyright (C) 2013 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_STRUCTURED_TYPE_H #define ANDROID_STRUCTURED_TYPE_H #include "rsElement.h" // --------------------------------------------------------------------------- namespace android { namespace renderscript { /***************************************************************************** * CAUTION * * Any layout changes for this class may require a corresponding change to be * made to frameworks/rs/driver/runtime/rs_structs.h, which contains * a partial copy of the information below. * *****************************************************************************/ class Type : public ObjectBase { public: const static uint32_t mMaxArrays = 4; struct Hal { mutable void *drv; struct State { const Element * element; // Size of the structure in the various dimensions. A missing Dimension is // specified as a 0 and not a 1. uint32_t dimX; uint32_t dimY; uint32_t dimZ; uint32_t *lodDimX; uint32_t *lodDimY; uint32_t *lodDimZ; uint32_t *arrays; uint32_t lodCount; uint32_t dimYuv; uint32_t arrayCount; bool faces; }; State state; }; Hal mHal; void operator delete(void* ptr); Type * createTex2D(const Element *, size_t w, size_t h, bool mip); size_t getCellCount() const {return mCellCount;} size_t getElementSizeBytes() const {return mElement->getSizeBytes();} size_t getPackedSizeBytes() const {return mCellCount * mElement->getSizeBytes();} const Element * getElement() const {return mElement.get();} uint32_t getDimX() const {return mHal.state.dimX;} uint32_t getDimY() const {return mHal.state.dimY;} uint32_t getDimZ() const {return mHal.state.dimZ;} bool getDimLOD() const {return mDimLOD;} bool getDimFaces() const {return mHal.state.faces;} uint32_t getDimYuv() const {return mHal.state.dimYuv;} uint32_t getArray(uint32_t idx) const { if (idx < mHal.state.arrayCount) { return mHal.state.arrays[idx]; } return 0; } uint32_t getLODDimX(uint32_t lod) const { rsAssert(lod < mHal.state.lodCount); return mHal.state.lodDimX[lod]; } uint32_t getLODDimY(uint32_t lod) const { rsAssert(lod < mHal.state.lodCount); return mHal.state.lodDimY[lod]; } uint32_t getLODDimZ(uint32_t lod) const { rsAssert(lod < mHal.state.lodCount); return mHal.state.lodDimZ[lod]; } uint32_t getLODCount() const {return mHal.state.lodCount;} bool getIsNp2() const; void clear(); void compute(); void dumpLOGV(const char *prefix) const; virtual void serialize(Context *rsc, OStream *stream) const; virtual RsA3DClassID getClassId() const { return RS_A3D_CLASS_ID_TYPE; } static Type *createFromStream(Context *rsc, IStream *stream); ObjectBaseRef cloneAndResize1D(Context *rsc, uint32_t dimX) const; ObjectBaseRef cloneAndResize2D(Context *rsc, uint32_t dimX, uint32_t dimY) const; static ObjectBaseRef getTypeRef(Context *rsc, const Element *e, const RsTypeCreateParams *params, size_t len); static Type* getType(Context *rsc, const Element *e, const RsTypeCreateParams *params, size_t len) { ObjectBaseRef type = getTypeRef(rsc, e, params, len); type->incUserRef(); return type.get(); } static ObjectBaseRef getTypeRef(Context *rsc, const Element *e, uint32_t dimX, uint32_t dimY = 0) { RsTypeCreateParams p; memset(&p, 0, sizeof(p)); p.dimX = dimX; p.dimY = dimY; return getTypeRef(rsc, e, &p, sizeof(p)); } void incRefs(const void *ptr, size_t ct, size_t startOff = 0) const; void decRefs(const void *ptr, size_t ct, size_t startOff = 0) const; virtual void callUpdateCacheObject(const Context *rsc, void *dstObj) const; protected: void makeLODTable(); bool mDimLOD; // Internal structure from most to least significant. // * Array dimensions // * Faces // * Mipmaps // * xyz ObjectBaseRef mElement; // count of mipmap levels, 0 indicates no mipmapping size_t mCellCount; protected: virtual void preDestroy() const; virtual ~Type(); private: Type(Context *); Type(const Type &); }; class TypeState { public: TypeState(); ~TypeState(); // Cache of all existing types. Vector mTypes; }; } } #endif //ANDROID_STRUCTURED_TYPE