rsUtils.h revision 326e0ddf89e8df2837752fbfd7a014814b32082c
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#ifndef ANDROID_RS_UTILS_H 18326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#define ANDROID_RS_UTILS_H 19326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 20326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include <stdint.h> 21326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include <sys/types.h> 22326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#include <stdlib.h> 23326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 24326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace android { 25326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsnamespace renderscript { 26326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 27326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#if 1 28326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#define rsAssert(v) do {if(!(v)) LOGE("rsAssert failed: %s, in %s at %i", #v, __FILE__, __LINE__);} while(0) 29326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#else 30326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#define rsAssert(v) while(0) 31326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#endif 32326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 33326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 34326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsT rsMin(T in1, T in2) 35326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 36326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (in1 > in2) { 37326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return in2; 38326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 39326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return in1; 40326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 41326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 42326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 43326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsT rsMax(T in1, T in2) 44326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 45326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (in1 < in2) { 46326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return in2; 47326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 48326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return in1; 49326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 50326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 51326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 52326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsT rsFindHighBit(T val) 53326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 54326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t bit = 0; 55326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams while(val > 1) { 56326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams bit++; 57326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams val>>=1; 58326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 59326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return bit; 60326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 61326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 62326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 63326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsbool rsIsPow2(T val) 64326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 65326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return (val & (val-1)) == 0; 66326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 67326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 68326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 69326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsT rsHigherPow2(T v) 70326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 71326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (rsIsPow2(v)) { 72326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return v; 73326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 74326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return 1 << (rsFindHighBit(v) + 1); 75326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 76326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 77326e0ddf89e8df2837752fbfd7a014814b32082cJason Samstemplate<typename T> 78326e0ddf89e8df2837752fbfd7a014814b32082cJason SamsT rsLowerPow2(T v) 79326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 80326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams if (rsIsPow2(v)) { 81326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return v; 82326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams } 83326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return 1 << rsFindHighBit(v); 84326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 85326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 86326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 87326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsstatic inline uint16_t rs888to565(uint32_t r, uint32_t g, uint32_t b) 88326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 89326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint16_t t = 0; 90326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams t |= r >> 3; 91326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams t |= (g >> 2) << 5; 92326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams t |= (b >> 3) << 11; 93326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return t; 94326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 95326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 96326e0ddf89e8df2837752fbfd7a014814b32082cJason Samsstatic inline uint16_t rsBoxFilter565(uint16_t i1, uint16_t i2, uint16_t i3, uint16_t i4) 97326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams{ 98326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t r = ((i1 & 0x1f) + (i2 & 0x1f) + (i3 & 0x1f) + (i4 & 0x1f)); 99326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t g = ((i1 >> 5) & 0x3f) + ((i2 >> 5) & 0x3f) + ((i3 >> 5) & 0x3f) + ((i1 >> 5) & 0x3f); 100326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams uint32_t b = ((i1 >> 11) + (i2 >> 11) + (i3 >> 11) + (i4 >> 11)); 101326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams return (r >> 2) | ((g >> 2) << 5) | ((b >> 2) << 11); 102326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 103326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 104326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 105326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 106326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 107326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 108326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 109326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 110326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams} 111326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 112326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams#endif //ANDROID_RS_OBJECT_BASE_H 113326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 114326e0ddf89e8df2837752fbfd7a014814b32082cJason Sams 115