rsAllocation.cpp revision f0c1df480304a72ce41e7d4b088319cbd7f0938a
1326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams/* 2326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams * Copyright (C) 2009 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 */ 16fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#ifndef ANDROID_RS_BUILD_FOR_HOST 17326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsContext.h" 18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 191aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/gl.h> 207fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams#include <GLES2/gl2.h> 211aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams#include <GLES/glext.h> 22fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#else 23fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#include "rsContextHostStub.h" 24fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 25fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#include <OpenGL/gl.h> 26fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#include <OpenGl/glext.h> 27fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#endif 281aa5a4eb81b8b88aeb5d2b6f4c47356fd0a62923Jason Sams 2939f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk#include "utils/StopWatch.h" 3039f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk 31326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android; 32326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android::renderscript; 33326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 34e514b45de8561fbc6ef6770845102ca10b0a69d7Jason SamsAllocation::Allocation(Context *rsc, const Type *type) : ObjectBase(rsc) 35326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 36fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams init(rsc, type); 37fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 38fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mPtr = malloc(mType->getSizeBytes()); 3910e5e570bab66a6cd543c857b26c576795eb240fJason Sams if (mType->getElement()->getHasReferences()) { 4010e5e570bab66a6cd543c857b26c576795eb240fJason Sams memset(mPtr, 0, mType->getSizeBytes()); 4110e5e570bab66a6cd543c857b26c576795eb240fJason Sams } 42fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams if (!mPtr) { 43fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams LOGE("Allocation::Allocation, alloc failure"); 44fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams } 45fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams} 46fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 47fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason SamsAllocation::Allocation(Context *rsc, const Type *type, void *bmp, 48fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams void *callbackData, RsBitmapCallback_t callback) 49fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams: ObjectBase(rsc) 50fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams{ 51fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams init(rsc, type); 52fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 53fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mPtr = bmp; 54fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mUserBitmapCallback = callback; 55fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mUserBitmapCallbackData = callbackData; 56fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams} 57fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 58fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Samsvoid Allocation::init(Context *rsc, const Type *type) 59fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams{ 60326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mPtr = NULL; 61326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 62326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mCpuWrite = false; 63326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mCpuRead = false; 64326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mGpuWrite = false; 65326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mGpuRead = false; 66326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 67326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mReadWriteRatio = 0; 68326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mUpdateSize = 0; 69326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 70326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mIsTexture = false; 71326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mTextureID = 0; 72326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mIsVertexBuffer = false; 73326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mBufferID = 0; 74cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = false; 75326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 76fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mUserBitmapCallback = NULL; 77fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mUserBitmapCallbackData = NULL; 78fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 79326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mType.set(type); 80e5ffb879ae535a899a486285a23bea05e912480fJason Sams rsAssert(type); 81fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams 82fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mPtr = NULL; 83326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 84326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 85326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsAllocation::~Allocation() 86326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 87fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams if (mUserBitmapCallback != NULL) { 88fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams mUserBitmapCallback(mUserBitmapCallbackData); 89fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams } else { 90fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams free(mPtr); 91fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams } 92bf3c14ebf456c745c084605dddeda08afdfc7987Jason Sams mPtr = NULL; 93e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams 94e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams if (mBufferID) { 95e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams // Causes a SW crash.... 96e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams //LOGV(" mBufferID %i", mBufferID); 97e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams //glDeleteBuffers(1, &mBufferID); 98e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams //mBufferID = 0; 99e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams } 100e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams if (mTextureID) { 101e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams glDeleteTextures(1, &mTextureID); 102e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams mTextureID = 0; 103e402ed33486730f1d06f080cdfc48132bf612b3aJason Sams } 104326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 105326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 106326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setCpuWritable(bool) 107326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 108326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 109326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 110326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setGpuWritable(bool) 111326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 112326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 113326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 114326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setCpuReadable(bool) 115326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 116326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 117326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 118326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setGpuReadable(bool) 119326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 120326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 121326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 122326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsbool Allocation::fixAllocation() 123326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 124326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return false; 125326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 126326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 1277fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Samsvoid Allocation::deferedUploadToTexture(const Context *rsc, bool genMipmap, uint32_t lodOffset) 128326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 129326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(lodOffset < mType->getLODCount()); 130cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mIsTexture = true; 131cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mTextureLOD = lodOffset; 132cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 1337fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams mTextureGenMipmap = !mType->getDimLOD() && genMipmap; 134cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams} 135cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 136cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Samsvoid Allocation::uploadToTexture(const Context *rsc) 137cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams{ 138cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams //rsAssert(!mTextureId); 139cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 140cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mIsTexture = true; 141cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (!rsc->checkDriver()) { 142cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 143cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams return; 144cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 145326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 146d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum type = mType->getElement()->getComponent().getGLType(); 147d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum format = mType->getElement()->getComponent().getGLFormat(); 148565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams 149565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams if (!type || !format) { 150565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams return; 151565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams } 152565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams 15339f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk bool isFirstUpload = false; 15439f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk 155326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (!mTextureID) { 156326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glGenTextures(1, &mTextureID); 15713e2634a71a30d289ed8d821aef61c7d1687460eJason Sams 15813e2634a71a30d289ed8d821aef61c7d1687460eJason Sams if (!mTextureID) { 15913e2634a71a30d289ed8d821aef61c7d1687460eJason Sams // This should not happen, however, its likely the cause of the 16013e2634a71a30d289ed8d821aef61c7d1687460eJason Sams // white sqare bug. 16113e2634a71a30d289ed8d821aef61c7d1687460eJason Sams // Force a crash to 1: restart the app, 2: make sure we get a bugreport. 16213e2634a71a30d289ed8d821aef61c7d1687460eJason Sams LOGE("Upload to texture failed to gen mTextureID"); 16313e2634a71a30d289ed8d821aef61c7d1687460eJason Sams rsc->dumpDebug(); 164cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 165cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams return; 16613e2634a71a30d289ed8d821aef61c7d1687460eJason Sams } 16739f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk isFirstUpload = true; 168326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 169326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindTexture(GL_TEXTURE_2D, mTextureID); 1705f0b4e19811e7e0ba59888939a3d0761297099fbJason Sams glPixelStorei(GL_UNPACK_ALIGNMENT, 1); 171326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 172e514b45de8561fbc6ef6770845102ca10b0a69d7Jason Sams Adapter2D adapt(getContext(), this); 173cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams for(uint32_t lod = 0; (lod + mTextureLOD) < mType->getLODCount(); lod++) { 174cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams adapt.setLOD(lod+mTextureLOD); 175326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 176326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t * ptr = static_cast<uint16_t *>(adapt.getElement(0,0)); 17739f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk if(isFirstUpload) { 17839f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk glTexImage2D(GL_TEXTURE_2D, lod, format, 17939f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk adapt.getDimX(), adapt.getDimY(), 18039f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk 0, format, type, ptr); 18139f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } else { 18239f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk glTexSubImage2D(GL_TEXTURE_2D, lod, 0, 0, 18339f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk adapt.getDimX(), adapt.getDimY(), 18439f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk format, type, ptr); 18539f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } 186326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 1877fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams if (mTextureGenMipmap) { 188fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#ifndef ANDROID_RS_BUILD_FOR_HOST 1897fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams glGenerateMipmap(GL_TEXTURE_2D); 190fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#endif //ANDROID_RS_BUILD_FOR_HOST 1917fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams } 1927fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams 193c1ed589021e280cda59a0521cb96b3e9eb629e1bJason Sams rsc->checkError("Allocation::uploadToTexture"); 194326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 195326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 196cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Samsvoid Allocation::deferedUploadToBufferObject(const Context *rsc) 197cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams{ 198cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mIsVertexBuffer = true; 199cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 200cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams} 201cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 202cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Samsvoid Allocation::uploadToBufferObject(const Context *rsc) 203326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 204326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(!mType->getDimY()); 205326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(!mType->getDimZ()); 206326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 207cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mIsVertexBuffer = true; 208cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (!rsc->checkDriver()) { 209cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 210cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams return; 211cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 212cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 213326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (!mBufferID) { 214326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glGenBuffers(1, &mBufferID); 215326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 216cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (!mBufferID) { 217cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams LOGE("Upload to buffer object failed"); 218cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 219cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams return; 220cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 221cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 222326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindBuffer(GL_ARRAY_BUFFER, mBufferID); 223326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBufferData(GL_ARRAY_BUFFER, mType->getSizeBytes(), getPtr(), GL_DYNAMIC_DRAW); 224326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindBuffer(GL_ARRAY_BUFFER, 0); 225c1ed589021e280cda59a0521cb96b3e9eb629e1bJason Sams rsc->checkError("Allocation::uploadToBufferObject"); 226326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 227326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 228cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Samsvoid Allocation::uploadCheck(const Context *rsc) 229cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams{ 230cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (mUploadDefered) { 231cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = false; 232cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (mIsVertexBuffer) { 233cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams uploadToBufferObject(rsc); 234cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 235cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams if (mIsTexture) { 236cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams uploadToTexture(rsc); 237cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 238cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams } 239cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams} 240cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams 241e5ffb879ae535a899a486285a23bea05e912480fJason Sams 2425f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::data(Context *rsc, const void *data, uint32_t sizeBytes) 243326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 2449397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams uint32_t size = mType->getSizeBytes(); 2459397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams if (size != sizeBytes) { 2469397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams LOGE("Allocation::data called with mismatched size expected %i, got %i", size, sizeBytes); 2479397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams return; 2489397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams } 249e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 250e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams if (mType->getElement()->getHasReferences()) { 251e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams incRefs(data, sizeBytes / mType->getElement()->getSizeBytes()); 252e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams decRefs(mPtr, sizeBytes / mType->getElement()->getSizeBytes()); 253e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams } 254e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 2559397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams memcpy(mPtr, data, size); 2565c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams sendDirty(); 257cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 258326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 259326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 260e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Samsvoid Allocation::read(void *data) 261e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams{ 262e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams memcpy(data, mPtr, mType->getSizeBytes()); 263e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams} 264e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams 2655f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::subData(Context *rsc, uint32_t xoff, uint32_t count, const void *data, uint32_t sizeBytes) 266326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 267326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t eSize = mType->getElementSizeBytes(); 268326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t * ptr = static_cast<uint8_t *>(mPtr); 269326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams ptr += eSize * xoff; 2709397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams uint32_t size = count * eSize; 2719397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams 2729397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams if (size != sizeBytes) { 2739397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams LOGE("Allocation::subData called with mismatched size expected %i, got %i", size, sizeBytes); 274e12c1c591b4219e80f29c6c0e0c62c9578b75450Jason Sams mType->dumpLOGV("type info"); 2759397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams return; 2769397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams } 277e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 278e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams if (mType->getElement()->getHasReferences()) { 279e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams incRefs(data, count); 280e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams decRefs(ptr, count); 281e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams } 282e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 2839397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams memcpy(ptr, data, size); 2845c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams sendDirty(); 285cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 286326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 287326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 2885f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::subData(Context *rsc, uint32_t xoff, uint32_t yoff, 2899397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams uint32_t w, uint32_t h, const void *data, uint32_t sizeBytes) 290326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 291326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t eSize = mType->getElementSizeBytes(); 292326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t lineSize = eSize * w; 293326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t destW = mType->getDimX(); 294326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 295326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint8_t *src = static_cast<const uint8_t *>(data); 296326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t *dst = static_cast<uint8_t *>(mPtr); 297326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams dst += eSize * (xoff + yoff * destW); 2989397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams 2999397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams if ((lineSize * eSize * h) != sizeBytes) { 3009397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams rsAssert(!"Allocation::subData called with mismatched size"); 3019397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams return; 3029397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams } 3039397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams 304326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for (uint32_t line=yoff; line < (yoff+h); line++) { 305e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams if (mType->getElement()->getHasReferences()) { 306e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams incRefs(src, w); 307e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams decRefs(dst, w); 308e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams } 309326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams memcpy(dst, src, lineSize); 310326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams src += lineSize; 311326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams dst += destW * eSize; 312326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 3135c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams sendDirty(); 314cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams mUploadDefered = true; 315326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 316326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 3175f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::subData(Context *rsc, uint32_t xoff, uint32_t yoff, uint32_t zoff, 3189397e30ce5fe3f6af9212a93b490836b04fdfffaJason Sams uint32_t w, uint32_t h, uint32_t d, const void *data, uint32_t sizeBytes) 319326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 320326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 321326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 3225f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::subElementData(Context *rsc, uint32_t x, const void *data, 3235f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams uint32_t cIdx, uint32_t sizeBytes) 3245f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams{ 3255f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams uint32_t eSize = mType->getElementSizeBytes(); 3265f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams uint8_t * ptr = static_cast<uint8_t *>(mPtr); 3275f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams ptr += eSize * x; 3285f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3295f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (cIdx >= mType->getElement()->getFieldCount()) { 3305f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData component %i out of range.", cIdx); 3315f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData component out of range."); 3325f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3335f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3345f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3355f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (x >= mType->getDimX()) { 3365f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData X offset %i out of range.", x); 3375f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData X offset out of range."); 3385f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3395f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3405f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3415f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams const Element * e = mType->getElement()->getField(cIdx); 3425f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams ptr += mType->getElement()->getFieldOffsetBytes(cIdx); 3435f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3445f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (sizeBytes != e->getSizeBytes()) { 3455f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData data size %i does not match field size %i.", sizeBytes, e->getSizeBytes()); 3465f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData bad size."); 3475f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3485f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3495f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3505f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (e->getHasReferences()) { 3515f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams e->incRefs(data); 3525f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams e->decRefs(ptr); 3535f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3545f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3555f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams memcpy(ptr, data, sizeBytes); 3565f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams sendDirty(); 3575f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams mUploadDefered = true; 3585f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams} 3595f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3605f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid Allocation::subElementData(Context *rsc, uint32_t x, uint32_t y, 3615f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams const void *data, uint32_t cIdx, uint32_t sizeBytes) 3625f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams{ 3635f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams uint32_t eSize = mType->getElementSizeBytes(); 3645f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams uint8_t * ptr = static_cast<uint8_t *>(mPtr); 3655f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams ptr += eSize * (x + y * mType->getDimX()); 3665f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3675f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (x >= mType->getDimX()) { 3685f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData X offset %i out of range.", x); 3695f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData X offset out of range."); 3705f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3715f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3725f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3735f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (y >= mType->getDimY()) { 3745f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData X offset %i out of range.", x); 3755f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData X offset out of range."); 3765f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3775f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3785f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3795f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (cIdx >= mType->getElement()->getFieldCount()) { 3805f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData component %i out of range.", cIdx); 3815f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData component out of range."); 3825f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3835f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3845f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3855f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams const Element * e = mType->getElement()->getField(cIdx); 3865f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams ptr += mType->getElement()->getFieldOffsetBytes(cIdx); 3875f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3885f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (sizeBytes != e->getSizeBytes()) { 3895f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams LOGE("Error Allocation::subElementData data size %i does not match field size %i.", sizeBytes, e->getSizeBytes()); 3905f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "subElementData bad size."); 3915f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams return; 3925f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3935f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3945f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams if (e->getHasReferences()) { 3955f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams e->incRefs(data); 3965f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams e->decRefs(ptr); 3975f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams } 3985f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 3995f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams memcpy(ptr, data, sizeBytes); 4005f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams sendDirty(); 4015f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams mUploadDefered = true; 4025f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams} 4035f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 4045c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Samsvoid Allocation::addProgramToDirty(const Program *p) 4055c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams{ 406fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk mToDirtyList.push(p); 4075c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams} 4085c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams 4095c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Samsvoid Allocation::removeProgramToDirty(const Program *p) 4105c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams{ 4115c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams for (size_t ct=0; ct < mToDirtyList.size(); ct++) { 4125c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams if (mToDirtyList[ct] == p) { 4135c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams mToDirtyList.removeAt(ct); 4145c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams return; 4155c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams } 4165c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams } 4175c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams rsAssert(0); 4185c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams} 419326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 420c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Samsvoid Allocation::dumpLOGV(const char *prefix) const 421c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams{ 422c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams ObjectBase::dumpLOGV(prefix); 423c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams 424c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams String8 s(prefix); 425c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams s.append(" type "); 426c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams if (mType.get()) { 427c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams mType->dumpLOGV(s.string()); 428c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams } 429c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams 430c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams LOGV("%s allocation ptr=%p mCpuWrite=%i, mCpuRead=%i, mGpuWrite=%i, mGpuRead=%i", 431c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams prefix, mPtr, mCpuWrite, mCpuRead, mGpuWrite, mGpuRead); 432c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams 43343999e7b320883dbb6eb306bbe22902ebd2fcebaJason Sams LOGV("%s allocation mIsTexture=%i mTextureID=%i, mIsVertexBuffer=%i, mBufferID=%i", 434c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams prefix, mIsTexture, mTextureID, mIsVertexBuffer, mBufferID); 435c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams 436c21cf40f6ae69091bf24f87b5eeabc95e73dd271Jason Sams} 437326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 438fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchoukvoid Allocation::serialize(OStream *stream) const 439fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk{ 440fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // Need to identify ourselves 441fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk stream->addU32((uint32_t)getClassId()); 442fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 443fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk String8 name(getName()); 444fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk stream->addString(&name); 445fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 446fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // First thing we need to serialize is the type object since it will be needed 447fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // to initialize the class 448fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk mType->serialize(stream); 449fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 450fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk uint32_t dataSize = mType->getSizeBytes(); 451fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // Write how much data we are storing 452fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk stream->addU32(dataSize); 453fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // Now write the data 454fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk stream->addByteArray(mPtr, dataSize); 455fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk} 456fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 457fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex SakhartchoukAllocation *Allocation::createFromStream(Context *rsc, IStream *stream) 458fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk{ 459fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // First make sure we are reading the correct object 460b825f67adb5d1e1751fe108e6dbf9c6f2555c283Alex Sakhartchouk RsA3DClassID classID = (RsA3DClassID)stream->loadU32(); 461b825f67adb5d1e1751fe108e6dbf9c6f2555c283Alex Sakhartchouk if(classID != RS_A3D_CLASS_ID_ALLOCATION) { 462fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk LOGE("allocation loading skipped due to invalid class id\n"); 463fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk return NULL; 464fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk } 465fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 466fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk String8 name; 467fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk stream->loadString(&name); 468fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 469fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk Type *type = Type::createFromStream(rsc, stream); 470fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk if(!type) { 471fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk return NULL; 472fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk } 473fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk type->compute(); 474fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 475fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // Number of bytes we wrote out for this allocation 476fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk uint32_t dataSize = stream->loadU32(); 477fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk if(dataSize != type->getSizeBytes()) { 478fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk LOGE("failed to read allocation because numbytes written is not the same loaded type wants\n"); 479225afd317e101a7be5fe02c0a86361146ea89f05Jason Sams ObjectBase::checkDelete(type); 480fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk return NULL; 481fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk } 482fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 483fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk Allocation *alloc = new Allocation(rsc, type); 484fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk alloc->setName(name.string(), name.size()); 485fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 486fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk // Read in all of our allocation data 4875f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams alloc->data(rsc, stream->getPtr() + stream->getPos(), dataSize); 488e6d9fbc31bef01219cc812e819c505ff01673c6fAlex Sakhartchouk stream->reset(stream->getPos() + dataSize); 489fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 490fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk return alloc; 491fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk} 492fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 4935c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Samsvoid Allocation::sendDirty() const 4945c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams{ 4955c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams for (size_t ct=0; ct < mToDirtyList.size(); ct++) { 4965c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams mToDirtyList[ct]->forceDirty(); 4975c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams } 4985c3e3bc8af6de6be5e6bd68e1d5168496f99e6cfJason Sams} 499326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 50096abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid Allocation::incRefs(const void *ptr, size_t ct, size_t startOff) const 501e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams{ 502e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams const uint8_t *p = static_cast<const uint8_t *>(ptr); 503e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams const Element *e = mType->getElement(); 504e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams uint32_t stride = e->getSizeBytes(); 505e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 50696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams p += stride * startOff; 507e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams while (ct > 0) { 508e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams e->incRefs(p); 509e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams ct --; 510e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams p += stride; 511e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams } 512e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams} 513e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 51496abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid Allocation::decRefs(const void *ptr, size_t ct, size_t startOff) const 515e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams{ 516e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams const uint8_t *p = static_cast<const uint8_t *>(ptr); 517e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams const Element *e = mType->getElement(); 518e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams uint32_t stride = e->getSizeBytes(); 519e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 52096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams p += stride * startOff; 521e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams while (ct > 0) { 522e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams e->decRefs(p); 523e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams ct --; 524e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams p += stride; 525e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams } 526e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams} 527e3929c9bc6f3897e132304faf1b40c3cf1f47474Jason Sams 52896abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid Allocation::copyRange1D(Context *rsc, const Allocation *src, int32_t srcOff, int32_t destOff, int32_t len) 52996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams{ 53096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams} 53196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 53296abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid Allocation::resize1D(Context *rsc, uint32_t dimX) 53396abf819e50b59ba8cf886c13f894633eb0a24baJason Sams{ 53496abf819e50b59ba8cf886c13f894633eb0a24baJason Sams Type *t = mType->cloneAndResize1D(rsc, dimX); 53596abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 53696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams uint32_t oldDimX = mType->getDimX(); 53796abf819e50b59ba8cf886c13f894633eb0a24baJason Sams if (dimX == oldDimX) { 53896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams return; 53996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams } 54096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 54196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams if (dimX < oldDimX) { 54296abf819e50b59ba8cf886c13f894633eb0a24baJason Sams decRefs(mPtr, oldDimX - dimX, dimX); 54396abf819e50b59ba8cf886c13f894633eb0a24baJason Sams } 54496abf819e50b59ba8cf886c13f894633eb0a24baJason Sams mPtr = realloc(mPtr, t->getSizeBytes()); 54596abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 54696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams if (dimX > oldDimX) { 54796abf819e50b59ba8cf886c13f894633eb0a24baJason Sams const Element *e = mType->getElement(); 54896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams uint32_t stride = e->getSizeBytes(); 54996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams memset(((uint8_t *)mPtr) + stride * oldDimX, 0, stride * (dimX - oldDimX)); 55096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams } 55196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams mType.set(t); 55296abf819e50b59ba8cf886c13f894633eb0a24baJason Sams} 55396abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 55496abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid Allocation::resize2D(Context *rsc, uint32_t dimX, uint32_t dimY) 55596abf819e50b59ba8cf886c13f894633eb0a24baJason Sams{ 55696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams LOGE("not implemented"); 55796abf819e50b59ba8cf886c13f894633eb0a24baJason Sams} 55896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 559326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams///////////////// 560565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams// 561326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 562326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 563326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android { 564326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript { 565326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 5667fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Samsvoid rsi_AllocationUploadToTexture(Context *rsc, RsAllocation va, bool genmip, uint32_t baseMipLevel) 567326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 568326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *alloc = static_cast<Allocation *>(va); 5697fabe1a3bf8de37d86021bb7f744c791db81aed3Jason Sams alloc->deferedUploadToTexture(rsc, genmip, baseMipLevel); 570326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 571326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 572326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_AllocationUploadToBufferObject(Context *rsc, RsAllocation va) 573326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 574326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *alloc = static_cast<Allocation *>(va); 575cf4c7c9b2f513be77a5b9853319ca82ac2b128edJason Sams alloc->deferedUploadToBufferObject(rsc); 576326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 577326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 578565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Samsstatic void mip565(const Adapter2D &out, const Adapter2D &in) 579326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 580326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t w = out.getDimX(); 581326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t h = out.getDimY(); 582326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 583e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams for (uint32_t y=0; y < h; y++) { 584326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t *oPtr = static_cast<uint16_t *>(out.getElement(0, y)); 585326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint16_t *i1 = static_cast<uint16_t *>(in.getElement(0, y*2)); 586326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint16_t *i2 = static_cast<uint16_t *>(in.getElement(0, y*2+1)); 587326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 588e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams for (uint32_t x=0; x < w; x++) { 589565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams *oPtr = rsBoxFilter565(i1[0], i1[1], i2[0], i2[1]); 590565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams oPtr ++; 591565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams i1 += 2; 592565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams i2 += 2; 593565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams } 594565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams } 595565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams} 596565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams 597565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Samsstatic void mip8888(const Adapter2D &out, const Adapter2D &in) 598565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams{ 599565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams uint32_t w = out.getDimX(); 600565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams uint32_t h = out.getDimY(); 601565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams 602e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams for (uint32_t y=0; y < h; y++) { 603565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams uint32_t *oPtr = static_cast<uint32_t *>(out.getElement(0, y)); 604565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams const uint32_t *i1 = static_cast<uint32_t *>(in.getElement(0, y*2)); 605565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams const uint32_t *i2 = static_cast<uint32_t *>(in.getElement(0, y*2+1)); 606565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams 607e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams for (uint32_t x=0; x < w; x++) { 608565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams *oPtr = rsBoxFilter8888(i1[0], i1[1], i2[0], i2[1]); 609326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams oPtr ++; 610326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams i1 += 2; 611326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams i2 += 2; 612326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 613326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 614326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 615326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 6162f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Samsstatic void mip8(const Adapter2D &out, const Adapter2D &in) 6172f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams{ 6182f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams uint32_t w = out.getDimX(); 6192f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams uint32_t h = out.getDimY(); 6202f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams 6212f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams for (uint32_t y=0; y < h; y++) { 6222f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams uint8_t *oPtr = static_cast<uint8_t *>(out.getElement(0, y)); 6232f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams const uint8_t *i1 = static_cast<uint8_t *>(in.getElement(0, y*2)); 6242f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams const uint8_t *i2 = static_cast<uint8_t *>(in.getElement(0, y*2+1)); 6252f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams 6262f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams for (uint32_t x=0; x < w; x++) { 6272f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams *oPtr = (uint8_t)(((uint32_t)i1[0] + i1[1] + i2[0] + i2[1]) * 0.25f); 6282f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams oPtr ++; 6292f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams i1 += 2; 6302f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams i2 += 2; 6312f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams } 6322f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams } 6332f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams} 6342f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams 635e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Samsstatic void mip(const Adapter2D &out, const Adapter2D &in) 636e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams{ 637e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams switch(out.getBaseType()->getElement()->getSizeBits()) { 638e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams case 32: 639e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams mip8888(out, in); 640e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams break; 641e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams case 16: 642e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams mip565(out, in); 643e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams break; 6442f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams case 8: 6452f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams mip8(out, in); 6462f6d8617769b5fd6287404a31d4e10140ebdcf7eJason Sams break; 647e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams 648e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams } 649e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams 650e9f5c53929c6c46872c4e9ba7cc3d0e528f5ad01Jason Sams} 651326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 6526678e9b2568ad041429a2477177133fe4932159fJason Samstypedef void (*ElementConverter_t)(void *dst, const void *src, uint32_t count); 6536678e9b2568ad041429a2477177133fe4932159fJason Sams 6546678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_16(void *dst, const void *src, uint32_t count) 6556678e9b2568ad041429a2477177133fe4932159fJason Sams{ 6566678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count * 2); 6576678e9b2568ad041429a2477177133fe4932159fJason Sams} 6586678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_8(void *dst, const void *src, uint32_t count) 6596678e9b2568ad041429a2477177133fe4932159fJason Sams{ 6606678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count); 6616678e9b2568ad041429a2477177133fe4932159fJason Sams} 6626678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_32(void *dst, const void *src, uint32_t count) 6636678e9b2568ad041429a2477177133fe4932159fJason Sams{ 6646678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count * 4); 6656678e9b2568ad041429a2477177133fe4932159fJason Sams} 6666678e9b2568ad041429a2477177133fe4932159fJason Sams 6676678e9b2568ad041429a2477177133fe4932159fJason Sams 6686678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_888_to_565(void *dst, const void *src, uint32_t count) 6696678e9b2568ad041429a2477177133fe4932159fJason Sams{ 6706678e9b2568ad041429a2477177133fe4932159fJason Sams uint16_t *d = static_cast<uint16_t *>(dst); 6716678e9b2568ad041429a2477177133fe4932159fJason Sams const uint8_t *s = static_cast<const uint8_t *>(src); 6726678e9b2568ad041429a2477177133fe4932159fJason Sams 6736678e9b2568ad041429a2477177133fe4932159fJason Sams while(count--) { 6746678e9b2568ad041429a2477177133fe4932159fJason Sams *d = rs888to565(s[0], s[1], s[2]); 6756678e9b2568ad041429a2477177133fe4932159fJason Sams d++; 6766678e9b2568ad041429a2477177133fe4932159fJason Sams s+= 3; 6776678e9b2568ad041429a2477177133fe4932159fJason Sams } 6786678e9b2568ad041429a2477177133fe4932159fJason Sams} 6796678e9b2568ad041429a2477177133fe4932159fJason Sams 6806678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_8888_to_565(void *dst, const void *src, uint32_t count) 6816678e9b2568ad041429a2477177133fe4932159fJason Sams{ 6826678e9b2568ad041429a2477177133fe4932159fJason Sams uint16_t *d = static_cast<uint16_t *>(dst); 6836678e9b2568ad041429a2477177133fe4932159fJason Sams const uint8_t *s = static_cast<const uint8_t *>(src); 6846678e9b2568ad041429a2477177133fe4932159fJason Sams 6856678e9b2568ad041429a2477177133fe4932159fJason Sams while(count--) { 6866678e9b2568ad041429a2477177133fe4932159fJason Sams *d = rs888to565(s[0], s[1], s[2]); 6876678e9b2568ad041429a2477177133fe4932159fJason Sams d++; 6886678e9b2568ad041429a2477177133fe4932159fJason Sams s+= 4; 6896678e9b2568ad041429a2477177133fe4932159fJason Sams } 6906678e9b2568ad041429a2477177133fe4932159fJason Sams} 6916678e9b2568ad041429a2477177133fe4932159fJason Sams 692a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Samsstatic ElementConverter_t pickConverter(const Element *dst, const Element *src) 693a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams{ 694d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum srcGLType = src->getComponent().getGLType(); 695d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum srcGLFmt = src->getComponent().getGLFormat(); 696d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum dstGLType = dst->getComponent().getGLType(); 697d01d970cf5973aa5186cc02c80fb2c143a69b0b1Jason Sams GLenum dstGLFmt = dst->getComponent().getGLFormat(); 698a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams 699a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams if (srcGLFmt == dstGLFmt && srcGLType == dstGLType) { 700a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams switch(dst->getSizeBytes()) { 701a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams case 4: 702a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams return elementConverter_cpy_32; 703a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams case 2: 704a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams return elementConverter_cpy_16; 705a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams case 1: 706a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams return elementConverter_cpy_8; 707a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams } 7086678e9b2568ad041429a2477177133fe4932159fJason Sams } 7096678e9b2568ad041429a2477177133fe4932159fJason Sams 710a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams if (srcGLType == GL_UNSIGNED_BYTE && 711a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams srcGLFmt == GL_RGB && 712a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams dstGLType == GL_UNSIGNED_SHORT_5_6_5 && 71344b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams dstGLFmt == GL_RGB) { 714a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams 7156678e9b2568ad041429a2477177133fe4932159fJason Sams return elementConverter_888_to_565; 7166678e9b2568ad041429a2477177133fe4932159fJason Sams } 7176678e9b2568ad041429a2477177133fe4932159fJason Sams 718a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams if (srcGLType == GL_UNSIGNED_BYTE && 719a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams srcGLFmt == GL_RGBA && 720a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams dstGLType == GL_UNSIGNED_SHORT_5_6_5 && 72144b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams dstGLFmt == GL_RGB) { 7226678e9b2568ad041429a2477177133fe4932159fJason Sams 723a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams return elementConverter_8888_to_565; 724565ac36ee479f9d7b83e2030ac9646a09cb886a1Jason Sams } 7256678e9b2568ad041429a2477177133fe4932159fJason Sams 726a57c0a72c3b3babc2757d081ff8146ebaa2caf4cJason Sams LOGE("pickConverter, unsuported combo, src %p, dst %p", src, dst); 72744b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams LOGE("pickConverter, srcGLType = %x, srcGLFmt = %x", srcGLType, srcGLFmt); 72844b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams LOGE("pickConverter, dstGLType = %x, dstGLFmt = %x", dstGLType, dstGLFmt); 72944b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams src->dumpLOGV("SRC "); 73044b289491a7e7e279b5c2134ea7a29f758df3621Jason Sams dst->dumpLOGV("DST "); 7316678e9b2568ad041429a2477177133fe4932159fJason Sams return 0; 7326678e9b2568ad041429a2477177133fe4932159fJason Sams} 7336678e9b2568ad041429a2477177133fe4932159fJason Sams 734fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#ifndef ANDROID_RS_BUILD_FOR_HOST 735fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk 736fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason SamsRsAllocation rsi_AllocationCreateBitmapRef(Context *rsc, RsType vtype, 737fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams void *bmp, void *callbackData, RsBitmapCallback_t callback) 738fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams{ 739fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams const Type * type = static_cast<const Type *>(vtype); 740fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams Allocation * alloc = new Allocation(rsc, type, bmp, callbackData, callback); 741fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams alloc->incUserRef(); 742fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams return alloc; 743fa84da2cbc271f855b3b1ec75bb688abdf1d1d01Jason Sams} 7446678e9b2568ad041429a2477177133fe4932159fJason Sams 74539f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchoukvoid rsi_AllocationUpdateFromBitmap(Context *rsc, RsAllocation va, RsElement _src, const void *data) 74639f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk{ 74739f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk Allocation *texAlloc = static_cast<Allocation *>(va); 74839f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk const Element *src = static_cast<const Element *>(_src); 74939f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk const Element *dst = texAlloc->getType()->getElement(); 75039f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk uint32_t w = texAlloc->getType()->getDimX(); 75139f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk uint32_t h = texAlloc->getType()->getDimY(); 75239f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk bool genMips = texAlloc->getType()->getDimLOD(); 75339f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk 75439f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk ElementConverter_t cvt = pickConverter(dst, src); 75539f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk if (cvt) { 75639f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk cvt(texAlloc->getPtr(), data, w * h); 75739f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk if (genMips) { 75839f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk Adapter2D adapt(rsc, texAlloc); 75939f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk Adapter2D adapt2(rsc, texAlloc); 76039f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk for(uint32_t lod=0; lod < (texAlloc->getType()->getLODCount() -1); lod++) { 76139f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk adapt.setLOD(lod); 76239f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk adapt2.setLOD(lod + 1); 76339f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk mip(adapt2, adapt); 76439f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } 76539f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } 76639f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } else { 76739f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk rsc->setError(RS_ERROR_BAD_VALUE, "Unsupported bitmap format"); 76839f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk } 76939f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk} 77039f2ef6fed00a99c5c389e12c4597884027d4858Alex Sakhartchouk 7719397e30ce5fe3f6af9212a93b490836b04fdfffaJason Samsvoid rsi_AllocationData(Context *rsc, RsAllocation va, const void *data, uint32_t sizeBytes) 772326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 773326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 7745f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams a->data(rsc, data, sizeBytes); 775326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 776326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 7779397e30ce5fe3f6af9212a93b490836b04fdfffaJason Samsvoid rsi_Allocation1DSubData(Context *rsc, RsAllocation va, uint32_t xoff, uint32_t count, const void *data, uint32_t sizeBytes) 778326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 779326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 7805f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams a->subData(rsc, xoff, count, data, sizeBytes); 7815f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams} 7825f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 7835f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid rsi_Allocation2DSubElementData(Context *rsc, RsAllocation va, uint32_t x, uint32_t y, const void *data, uint32_t eoff, uint32_t sizeBytes) 7845f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams{ 7855f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams Allocation *a = static_cast<Allocation *>(va); 7865f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams a->subElementData(rsc, x, y, data, eoff, sizeBytes); 7875f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams} 7885f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams 7895f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Samsvoid rsi_Allocation1DSubElementData(Context *rsc, RsAllocation va, uint32_t x, const void *data, uint32_t eoff, uint32_t sizeBytes) 7905f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams{ 7915f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams Allocation *a = static_cast<Allocation *>(va); 7925f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams a->subElementData(rsc, x, data, eoff, sizeBytes); 793326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 794326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 7959397e30ce5fe3f6af9212a93b490836b04fdfffaJason Samsvoid rsi_Allocation2DSubData(Context *rsc, RsAllocation va, uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h, const void *data, uint32_t sizeBytes) 796326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 797326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 7985f0c84cf464dda719cef65fdc9b4d0980e86b98fJason Sams a->subData(rsc, xoff, yoff, w, h, data, sizeBytes); 799326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 800326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 801e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Samsvoid rsi_AllocationRead(Context *rsc, RsAllocation va, void *data) 802e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams{ 803e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams Allocation *a = static_cast<Allocation *>(va); 804e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams a->read(data); 805e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams} 806e579df42e85d9e00f53c42ef1b78dbd209dba989Jason Sams 80796abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid rsi_AllocationResize1D(Context *rsc, RsAllocation va, uint32_t dimX) 80896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams{ 80996abf819e50b59ba8cf886c13f894633eb0a24baJason Sams Allocation *a = static_cast<Allocation *>(va); 81096abf819e50b59ba8cf886c13f894633eb0a24baJason Sams a->resize1D(rsc, dimX); 81196abf819e50b59ba8cf886c13f894633eb0a24baJason Sams} 81296abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 81396abf819e50b59ba8cf886c13f894633eb0a24baJason Samsvoid rsi_AllocationResize2D(Context *rsc, RsAllocation va, uint32_t dimX, uint32_t dimY) 81496abf819e50b59ba8cf886c13f894633eb0a24baJason Sams{ 81596abf819e50b59ba8cf886c13f894633eb0a24baJason Sams Allocation *a = static_cast<Allocation *>(va); 81696abf819e50b59ba8cf886c13f894633eb0a24baJason Sams a->resize2D(rsc, dimX, dimY); 81796abf819e50b59ba8cf886c13f894633eb0a24baJason Sams} 81896abf819e50b59ba8cf886c13f894633eb0a24baJason Sams 819d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchoukconst void* rsi_AllocationGetType(Context *rsc, RsAllocation va) 820d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk{ 821d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk Allocation *a = static_cast<Allocation *>(va); 822d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk a->getType()->incUserRef(); 823d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk 824d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk return a->getType(); 825d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk} 826d18c744a37441311c9b65254a35db456835adad3Alex Sakhartchouk 827fb6b614bcea88a587a7ea4530be45ff0ffa0210eAlex Sakhartchouk#endif //ANDROID_RS_BUILD_FOR_HOST 828326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 829326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 830326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 831f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 832f0c1df480304a72ce41e7d4b088319cbd7f0938aJason SamsRsAllocation rsaAllocationCreateTyped(RsContext con, RsType vtype) 833f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams{ 834f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Context *rsc = static_cast<Context *>(con); 835f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Allocation * alloc = new Allocation(rsc, static_cast<Type *>(vtype)); 836f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams alloc->incUserRef(); 837f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams return alloc; 838f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams} 839f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 840f0c1df480304a72ce41e7d4b088319cbd7f0938aJason SamsRsAllocation rsaAllocationCreateFromBitmap(RsContext con, uint32_t w, uint32_t h, RsElement _dst, RsElement _src, bool genMips, const void *data) 841f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams{ 842f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Context *rsc = static_cast<Context *>(con); 843f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams const Element *src = static_cast<const Element *>(_src); 844f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams const Element *dst = static_cast<const Element *>(_dst); 845f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 846f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams //LOGE("%p rsi_AllocationCreateFromBitmap %i %i %i", rsc, w, h, genMips); 847f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams RsDimension dims[] = {RS_DIMENSION_X, RS_DIMENSION_Y, RS_DIMENSION_LOD}; 848f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams uint32_t dimValues[] = {w, h, genMips}; 849f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams RsType type = rsaTypeCreate(rsc, _dst, 3, dims, dimValues); 850f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 851f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams RsAllocation vTexAlloc = rsaAllocationCreateTyped(rsc, type); 852f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Allocation *texAlloc = static_cast<Allocation *>(vTexAlloc); 853f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams if (texAlloc == NULL) { 854f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams LOGE("Memory allocation failure"); 855f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams return NULL; 856f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams } 857f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 858f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams ElementConverter_t cvt = pickConverter(dst, src); 859f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams if (cvt) { 860f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams cvt(texAlloc->getPtr(), data, w * h); 861f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams if (genMips) { 862f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Adapter2D adapt(rsc, texAlloc); 863f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams Adapter2D adapt2(rsc, texAlloc); 864f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams for(uint32_t lod=0; lod < (texAlloc->getType()->getLODCount() -1); lod++) { 865f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams adapt.setLOD(lod); 866f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams adapt2.setLOD(lod + 1); 867f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams mip(adapt2, adapt); 868f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams } 869f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams } 870f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams } else { 871f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams rsc->setError(RS_ERROR_BAD_VALUE, "Unsupported bitmap format"); 872f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams } 873f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 874f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams return texAlloc; 875f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams} 876f0c1df480304a72ce41e7d4b088319cbd7f0938aJason Sams 877