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