rsAllocation.cpp revision 6678e9b2568ad041429a2477177133fe4932159f
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 */ 16326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 17326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include "rsContext.h" 18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 19326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android; 20326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsusing namespace android::renderscript; 21326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 22326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsAllocation::Allocation(const Type *type) 23326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 24326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mPtr = NULL; 25326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 26326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mCpuWrite = false; 27326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mCpuRead = false; 28326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mGpuWrite = false; 29326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mGpuRead = false; 30326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 31326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mReadWriteRatio = 0; 32326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mUpdateSize = 0; 33326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 34326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mIsTexture = false; 35326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mTextureID = 0; 36326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 37326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mIsVertexBuffer = false; 38326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mBufferID = 0; 39326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 40326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mType.set(type); 41326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mPtr = malloc(mType->getSizeBytes()); 42326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (!mPtr) { 43326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams LOGE("Allocation::Allocation, alloc failure"); 44326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 45326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 46326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 47326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 48326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsAllocation::~Allocation() 49326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 50326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 51326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 52326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setCpuWritable(bool) 53326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 54326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 55326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 56326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setGpuWritable(bool) 57326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 58326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 59326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 60326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setCpuReadable(bool) 61326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 62326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 63326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 64326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::setGpuReadable(bool) 65326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 66326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 67326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 68326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsbool Allocation::fixAllocation() 69326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 70326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return false; 71326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 72326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 73326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::uploadToTexture(uint32_t lodOffset) 74326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 75326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams //rsAssert(!mTextureId); 76326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(lodOffset < mType->getLODCount()); 77326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 78326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams //LOGE("uploadToTexture %i, lod %i", mTextureID, lodOffset); 79326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 80326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (!mTextureID) { 81326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glGenTextures(1, &mTextureID); 82326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 83326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindTexture(GL_TEXTURE_2D, mTextureID); 84326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 85326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Adapter2D adapt(this); 86326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for(uint32_t lod = 0; (lod + lodOffset) < mType->getLODCount(); lod++) { 87326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams adapt.setLOD(lod+lodOffset); 88326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 89326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t * ptr = static_cast<uint16_t *>(adapt.getElement(0,0)); 90326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glTexImage2D(GL_TEXTURE_2D, lod, GL_RGB, 91326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams adapt.getDimX(), adapt.getDimY(), 92326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 0, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, ptr); 93326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 94326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 95326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 96326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::uploadToBufferObject() 97326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 98326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(!mType->getDimY()); 99326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsAssert(!mType->getDimZ()); 100326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 101326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams //LOGE("uploadToTexture %i, lod %i", mTextureID, lodOffset); 102326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 103326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (!mBufferID) { 104326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glGenBuffers(1, &mBufferID); 105326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 106326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindBuffer(GL_ARRAY_BUFFER, mBufferID); 107326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBufferData(GL_ARRAY_BUFFER, mType->getSizeBytes(), getPtr(), GL_DYNAMIC_DRAW); 108326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams glBindBuffer(GL_ARRAY_BUFFER, 0); 109326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 110326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 111326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::data(const void *data) 112326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 113326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams memcpy(mPtr, data, mType->getSizeBytes()); 114326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 115326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 116326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::subData(uint32_t xoff, uint32_t count, const void *data) 117326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 118326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t eSize = mType->getElementSizeBytes(); 119326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t * ptr = static_cast<uint8_t *>(mPtr); 120326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams ptr += eSize * xoff; 121326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams memcpy(ptr, data, count * eSize); 122326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 123326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 124326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::subData(uint32_t xoff, uint32_t yoff, 125326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t w, uint32_t h, const void *data) 126326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 127326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t eSize = mType->getElementSizeBytes(); 128326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t lineSize = eSize * w; 129326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t destW = mType->getDimX(); 130326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 131326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint8_t *src = static_cast<const uint8_t *>(data); 132326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t *dst = static_cast<uint8_t *>(mPtr); 133326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams dst += eSize * (xoff + yoff * destW); 134326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for (uint32_t line=yoff; line < (yoff+h); line++) { 135326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t * ptr = static_cast<uint8_t *>(mPtr); 136326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams memcpy(dst, src, lineSize); 137326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams src += lineSize; 138326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams dst += destW * eSize; 139326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 140326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 141326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 142326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid Allocation::subData(uint32_t xoff, uint32_t yoff, uint32_t zoff, 143326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t w, uint32_t h, uint32_t d, const void *data) 144326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 145326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 146326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 147326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 148326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 149326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams///////////////// 150326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams// 151326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 152326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 153326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android { 154326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript { 155326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 156326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsRsAllocation rsi_AllocationCreateTyped(Context *rsc, RsType vtype) 157326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 158326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const Type * type = static_cast<const Type *>(vtype); 159326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 160326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation * alloc = new Allocation(type); 161326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return alloc; 162326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 163326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 164326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsRsAllocation rsi_AllocationCreatePredefSized(Context *rsc, RsElementPredefined t, size_t count) 165326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 166326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams RsElement e = rsi_ElementGetPredefined(rsc, t); 167326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return rsi_AllocationCreateSized(rsc, e, count); 168326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 169326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 170326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsRsAllocation rsi_AllocationCreateSized(Context *rsc, RsElement e, size_t count) 171326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 172326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Type * type = new Type(); 173326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams type->setDimX(count); 174326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams type->setElement(static_cast<Element *>(e)); 175326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams type->compute(); 176326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return rsi_AllocationCreateTyped(rsc, type); 177326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 178326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 179326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_AllocationUploadToTexture(Context *rsc, RsAllocation va, uint32_t baseMipLevel) 180326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 181326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *alloc = static_cast<Allocation *>(va); 182326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams alloc->uploadToTexture(baseMipLevel); 183326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 184326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 185326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_AllocationUploadToBufferObject(Context *rsc, RsAllocation va) 186326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 187326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *alloc = static_cast<Allocation *>(va); 188326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams alloc->uploadToBufferObject(); 189326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 190326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 191326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_AllocationDestroy(Context *rsc, RsAllocation) 192326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 193326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 194326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 195326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsstatic void mip(const Adapter2D &out, const Adapter2D &in) 196326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 197326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t w = out.getDimX(); 198326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t h = out.getDimY(); 199326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 200326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for (uint32_t y=0; y < w; y++) { 201326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t *oPtr = static_cast<uint16_t *>(out.getElement(0, y)); 202326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint16_t *i1 = static_cast<uint16_t *>(in.getElement(0, y*2)); 203326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams const uint16_t *i2 = static_cast<uint16_t *>(in.getElement(0, y*2+1)); 204326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 205326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for (uint32_t x=0; x < h; x++) { 206326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *oPtr = rsBoxFilter565(i1[0], i1[2], i2[0], i2[1]); 207326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams oPtr ++; 208326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams i1 += 2; 209326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams i2 += 2; 210326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 211326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 212326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 213326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 214326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 215326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 2166678e9b2568ad041429a2477177133fe4932159fJason Samstypedef void (*ElementConverter_t)(void *dst, const void *src, uint32_t count); 2176678e9b2568ad041429a2477177133fe4932159fJason Sams 2186678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_16(void *dst, const void *src, uint32_t count) 2196678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2206678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count * 2); 2216678e9b2568ad041429a2477177133fe4932159fJason Sams} 2226678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_8(void *dst, const void *src, uint32_t count) 2236678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2246678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count); 2256678e9b2568ad041429a2477177133fe4932159fJason Sams} 2266678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_cpy_32(void *dst, const void *src, uint32_t count) 2276678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2286678e9b2568ad041429a2477177133fe4932159fJason Sams memcpy(dst, src, count * 4); 2296678e9b2568ad041429a2477177133fe4932159fJason Sams} 2306678e9b2568ad041429a2477177133fe4932159fJason Sams 2316678e9b2568ad041429a2477177133fe4932159fJason Sams 2326678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_888_to_565(void *dst, const void *src, uint32_t count) 2336678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2346678e9b2568ad041429a2477177133fe4932159fJason Sams uint16_t *d = static_cast<uint16_t *>(dst); 2356678e9b2568ad041429a2477177133fe4932159fJason Sams const uint8_t *s = static_cast<const uint8_t *>(src); 2366678e9b2568ad041429a2477177133fe4932159fJason Sams 2376678e9b2568ad041429a2477177133fe4932159fJason Sams while(count--) { 2386678e9b2568ad041429a2477177133fe4932159fJason Sams *d = rs888to565(s[0], s[1], s[2]); 2396678e9b2568ad041429a2477177133fe4932159fJason Sams d++; 2406678e9b2568ad041429a2477177133fe4932159fJason Sams s+= 3; 2416678e9b2568ad041429a2477177133fe4932159fJason Sams } 2426678e9b2568ad041429a2477177133fe4932159fJason Sams} 2436678e9b2568ad041429a2477177133fe4932159fJason Sams 2446678e9b2568ad041429a2477177133fe4932159fJason Samsstatic void elementConverter_8888_to_565(void *dst, const void *src, uint32_t count) 2456678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2466678e9b2568ad041429a2477177133fe4932159fJason Sams uint16_t *d = static_cast<uint16_t *>(dst); 2476678e9b2568ad041429a2477177133fe4932159fJason Sams const uint8_t *s = static_cast<const uint8_t *>(src); 2486678e9b2568ad041429a2477177133fe4932159fJason Sams 2496678e9b2568ad041429a2477177133fe4932159fJason Sams while(count--) { 2506678e9b2568ad041429a2477177133fe4932159fJason Sams *d = rs888to565(s[0], s[1], s[2]); 2516678e9b2568ad041429a2477177133fe4932159fJason Sams d++; 2526678e9b2568ad041429a2477177133fe4932159fJason Sams s+= 4; 2536678e9b2568ad041429a2477177133fe4932159fJason Sams } 2546678e9b2568ad041429a2477177133fe4932159fJason Sams} 2556678e9b2568ad041429a2477177133fe4932159fJason Sams 2566678e9b2568ad041429a2477177133fe4932159fJason Samsstatic ElementConverter_t pickConverter(RsElementPredefined dstFmt, RsElementPredefined srcFmt) 2576678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2586678e9b2568ad041429a2477177133fe4932159fJason Sams if ((dstFmt == RS_ELEMENT_RGB_565) && 2596678e9b2568ad041429a2477177133fe4932159fJason Sams (srcFmt == RS_ELEMENT_RGB_565)) { 2606678e9b2568ad041429a2477177133fe4932159fJason Sams return elementConverter_cpy_16; 2616678e9b2568ad041429a2477177133fe4932159fJason Sams } 2626678e9b2568ad041429a2477177133fe4932159fJason Sams 2636678e9b2568ad041429a2477177133fe4932159fJason Sams if ((dstFmt == RS_ELEMENT_RGB_565) && 2646678e9b2568ad041429a2477177133fe4932159fJason Sams (srcFmt == RS_ELEMENT_RGB_888)) { 2656678e9b2568ad041429a2477177133fe4932159fJason Sams return elementConverter_888_to_565; 2666678e9b2568ad041429a2477177133fe4932159fJason Sams } 2676678e9b2568ad041429a2477177133fe4932159fJason Sams 2686678e9b2568ad041429a2477177133fe4932159fJason Sams if ((dstFmt == RS_ELEMENT_RGB_565) && 2696678e9b2568ad041429a2477177133fe4932159fJason Sams (srcFmt == RS_ELEMENT_RGBA_8888)) { 2706678e9b2568ad041429a2477177133fe4932159fJason Sams return elementConverter_8888_to_565; 2716678e9b2568ad041429a2477177133fe4932159fJason Sams } 2726678e9b2568ad041429a2477177133fe4932159fJason Sams 2736678e9b2568ad041429a2477177133fe4932159fJason Sams 2746678e9b2568ad041429a2477177133fe4932159fJason Sams LOGE("pickConverter, unsuported combo"); 2756678e9b2568ad041429a2477177133fe4932159fJason Sams return 0; 2766678e9b2568ad041429a2477177133fe4932159fJason Sams} 2776678e9b2568ad041429a2477177133fe4932159fJason Sams 2786678e9b2568ad041429a2477177133fe4932159fJason Sams 2796678e9b2568ad041429a2477177133fe4932159fJason SamsRsAllocation rsi_AllocationCreateFromBitmap(Context *rsc, uint32_t w, uint32_t h, RsElementPredefined dstFmt, RsElementPredefined srcFmt, bool genMips, const void *data) 2806678e9b2568ad041429a2477177133fe4932159fJason Sams{ 2816678e9b2568ad041429a2477177133fe4932159fJason Sams rsi_TypeBegin(rsc, rsi_ElementGetPredefined(rsc, RS_ELEMENT_RGB_565)); 2826678e9b2568ad041429a2477177133fe4932159fJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_X, w); 2836678e9b2568ad041429a2477177133fe4932159fJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_Y, h); 2846678e9b2568ad041429a2477177133fe4932159fJason Sams if (genMips) { 2856678e9b2568ad041429a2477177133fe4932159fJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_LOD, 1); 2866678e9b2568ad041429a2477177133fe4932159fJason Sams } 2876678e9b2568ad041429a2477177133fe4932159fJason Sams RsType type = rsi_TypeCreate(rsc); 2886678e9b2568ad041429a2477177133fe4932159fJason Sams 2896678e9b2568ad041429a2477177133fe4932159fJason Sams RsAllocation vTexAlloc = rsi_AllocationCreateTyped(rsc, type); 2906678e9b2568ad041429a2477177133fe4932159fJason Sams Allocation *texAlloc = static_cast<Allocation *>(vTexAlloc); 2916678e9b2568ad041429a2477177133fe4932159fJason Sams if (texAlloc == NULL) { 2926678e9b2568ad041429a2477177133fe4932159fJason Sams LOGE("Memory allocation failure"); 2936678e9b2568ad041429a2477177133fe4932159fJason Sams return NULL; 2946678e9b2568ad041429a2477177133fe4932159fJason Sams } 2956678e9b2568ad041429a2477177133fe4932159fJason Sams texAlloc->incRef(); 2966678e9b2568ad041429a2477177133fe4932159fJason Sams 2976678e9b2568ad041429a2477177133fe4932159fJason Sams ElementConverter_t cvt = pickConverter(dstFmt, srcFmt); 2986678e9b2568ad041429a2477177133fe4932159fJason Sams cvt(texAlloc->getPtr(), data, w * h); 2996678e9b2568ad041429a2477177133fe4932159fJason Sams 3006678e9b2568ad041429a2477177133fe4932159fJason Sams if (genMips) { 3016678e9b2568ad041429a2477177133fe4932159fJason Sams Adapter2D adapt(texAlloc); 3026678e9b2568ad041429a2477177133fe4932159fJason Sams Adapter2D adapt2(texAlloc); 3036678e9b2568ad041429a2477177133fe4932159fJason Sams for(uint32_t lod=0; lod < (texAlloc->getType()->getLODCount() -1); lod++) { 3046678e9b2568ad041429a2477177133fe4932159fJason Sams adapt.setLOD(lod); 3056678e9b2568ad041429a2477177133fe4932159fJason Sams adapt2.setLOD(lod + 1); 3066678e9b2568ad041429a2477177133fe4932159fJason Sams mip(adapt2, adapt); 3076678e9b2568ad041429a2477177133fe4932159fJason Sams } 3086678e9b2568ad041429a2477177133fe4932159fJason Sams } 3096678e9b2568ad041429a2477177133fe4932159fJason Sams 3106678e9b2568ad041429a2477177133fe4932159fJason Sams return texAlloc; 3116678e9b2568ad041429a2477177133fe4932159fJason Sams} 3126678e9b2568ad041429a2477177133fe4932159fJason Sams 3136678e9b2568ad041429a2477177133fe4932159fJason SamsRsAllocation rsi_AllocationCreateFromFile(Context *rsc, const char *file, bool genMips) 314326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 315326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams typedef struct _Win3xBitmapHeader 316326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams { 317326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t type; 318326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t totalSize; 319326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t reserved; 320326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t offset; 321326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t hdrSize; /* Size of this header in bytes */ 322326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t width; /* Image width in pixels */ 323326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t height; /* Image height in pixels */ 324326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int16_t planes; /* Number of color planes */ 325326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int16_t bpp; /* Number of bits per pixel */ 326326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams /* Fields added for Windows 3.x follow this line */ 327326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t compression; /* Compression methods used */ 328326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t sizeOfBitmap; /* Size of bitmap in bytes */ 329326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t horzResolution; /* Horizontal resolution in pixels per meter */ 330326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t vertResolution; /* Vertical resolution in pixels per meter */ 331326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t colorsUsed; /* Number of colors in the image */ 332326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t colorsImportant; /* Minimum number of important colors */ 333326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } __attribute__((__packed__)) WIN3XBITMAPHEADER; 334326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 335326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams _Win3xBitmapHeader hdr; 336326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 337326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams FILE *f = fopen(file, "rb"); 338326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (f == NULL) { 339326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams LOGE("rsAllocationCreateFromBitmap failed to open file %s", file); 340326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return NULL; 341326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 342326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams memset(&hdr, 0, sizeof(hdr)); 343326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fread(&hdr, sizeof(hdr), 1, f); 344326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 345326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (hdr.bpp != 24) { 346326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams LOGE("Unsuported BMP type"); 347326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fclose(f); 348326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return NULL; 349326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 350326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 351326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t texWidth = rsHigherPow2(hdr.width); 352326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams int32_t texHeight = rsHigherPow2(hdr.height); 353326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 354326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsi_TypeBegin(rsc, rsi_ElementGetPredefined(rsc, RS_ELEMENT_RGB_565)); 355326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_X, texWidth); 356326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_Y, texHeight); 357326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (genMips) { 358326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams rsi_TypeAdd(rsc, RS_DIMENSION_LOD, 1); 359326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 360326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams RsType type = rsi_TypeCreate(rsc); 361326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 362326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams RsAllocation vTexAlloc = rsi_AllocationCreateTyped(rsc, type); 363326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *texAlloc = static_cast<Allocation *>(vTexAlloc); 364326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams texAlloc->incRef(); 365326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (texAlloc == NULL) { 366326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams LOGE("Memory allocation failure"); 367326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fclose(f); 368326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return NULL; 369326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 370326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 371326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams // offset to letterbox if height is not pow2 372326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Adapter2D adapt(texAlloc); 373326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint8_t * fileInBuf = new uint8_t[texWidth * 3]; 374326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t yOffset = (hdr.width - hdr.height) / 2; 375326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t *tmp = static_cast<uint16_t *>(adapt.getElement(0, yOffset)); 376326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 377326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for (int y=0; y < hdr.height; y++) { 378326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fseek(f, hdr.offset + (y*hdr.width*3), SEEK_SET); 379326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fread(fileInBuf, 1, hdr.width * 3, f); 380326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for(int x=0; x < hdr.width; x++) { 381326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams *tmp = rs888to565(fileInBuf[x*3], fileInBuf[x*3 + 1], fileInBuf[x*3 + 2]); 382326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams tmp++; 383326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 384326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 385326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 386326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams fclose(f); 387326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams delete [] fileInBuf; 388326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 389326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (genMips) { 390326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Adapter2D adapt2(texAlloc); 391326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams for(uint32_t lod=0; lod < (texAlloc->getType()->getLODCount() -1); lod++) { 392326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams adapt.setLOD(lod); 393326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams adapt2.setLOD(lod + 1); 394326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams mip(adapt2, adapt); 395326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 396326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 397326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 398326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return texAlloc; 399326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 400326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 401326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 402326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_AllocationData(Context *rsc, RsAllocation va, const void *data) 403326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 404326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 405326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams a->data(data); 406326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 407326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 408326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_Allocation1DSubData(Context *rsc, RsAllocation va, uint32_t xoff, uint32_t count, const void *data) 409326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 410326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 411326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams a->subData(xoff, count, data); 412326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 413326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 414326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsvoid rsi_Allocation2DSubData(Context *rsc, RsAllocation va, uint32_t xoff, uint32_t yoff, uint32_t w, uint32_t h, const void *data) 415326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 416326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams Allocation *a = static_cast<Allocation *>(va); 417326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams a->subData(xoff, yoff, w, h, data); 418326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 419326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 420326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 421326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 422326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 423