/* * Copyright (C) 2011 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** @file rs_allocation.rsh * \brief Allocation routines * * */ #ifndef __RS_ALLOCATION_RSH__ #define __RS_ALLOCATION_RSH__ /** * Returns the Allocation for a given pointer. The pointer should point within * a valid allocation. The results are undefined if the pointer is not from a * valid allocation. * * This function is deprecated and will be removed in the SDK from a future * release. */ extern rs_allocation __attribute__((overloadable)) rsGetAllocation(const void *); /** * Query the dimension of an allocation. * * @return uint32_t The X dimension of the allocation. */ extern uint32_t __attribute__((overloadable)) rsAllocationGetDimX(rs_allocation); /** * Query the dimension of an allocation. * * @return uint32_t The Y dimension of the allocation. */ extern uint32_t __attribute__((overloadable)) rsAllocationGetDimY(rs_allocation); /** * Query the dimension of an allocation. * * @return uint32_t The Z dimension of the allocation. */ extern uint32_t __attribute__((overloadable)) rsAllocationGetDimZ(rs_allocation); /** * Query an allocation for the presence of more than one LOD. * * @return uint32_t Returns 1 if more than one LOD is present, 0 otherwise. */ extern uint32_t __attribute__((overloadable)) rsAllocationGetDimLOD(rs_allocation); /** * Query an allocation for the presence of more than one face. * * @return uint32_t Returns 1 if more than one face is present, 0 otherwise. */ extern uint32_t __attribute__((overloadable)) rsAllocationGetDimFaces(rs_allocation); #if (defined(RS_VERSION) && (RS_VERSION >= 14)) /** * Copy part of an allocation from another allocation. * * @param dstAlloc Allocation to copy data into. * @param dstOff The offset of the first element to be copied in * the destination allocation. * @param dstMip Mip level in the destination allocation. * @param count The number of elements to be copied. * @param srcAlloc The source data allocation. * @param srcOff The offset of the first element in data to be * copied in the source allocation. * @param srcMip Mip level in the source allocation. */ extern void __attribute__((overloadable)) rsAllocationCopy1DRange(rs_allocation dstAlloc, uint32_t dstOff, uint32_t dstMip, uint32_t count, rs_allocation srcAlloc, uint32_t srcOff, uint32_t srcMip); /** * Copy a rectangular region into the allocation from another * allocation. * * @param dstAlloc allocation to copy data into. * @param dstXoff X offset of the region to update in the * destination allocation. * @param dstYoff Y offset of the region to update in the * destination allocation. * @param dstMip Mip level in the destination allocation. * @param dstFace Cubemap face of the destination allocation, * ignored for allocations that aren't cubemaps. * @param width Width of the incoming region to update. * @param height Height of the incoming region to update. * @param srcAlloc The source data allocation. * @param srcXoff X offset in data of the source allocation. * @param srcYoff Y offset in data of the source allocation. * @param srcMip Mip level in the source allocation. * @param srcFace Cubemap face of the source allocation, * ignored for allocations that aren't cubemaps. */ extern void __attribute__((overloadable)) rsAllocationCopy2DRange(rs_allocation dstAlloc, uint32_t dstXoff, uint32_t dstYoff, uint32_t dstMip, rs_allocation_cubemap_face dstFace, uint32_t width, uint32_t height, rs_allocation srcAlloc, uint32_t srcXoff, uint32_t srcYoff, uint32_t srcMip, rs_allocation_cubemap_face srcFace); #endif //defined(RS_VERSION) && (RS_VERSION >= 14) /** * Extract a single element from an allocation. */ extern const void * __attribute__((overloadable)) rsGetElementAt(rs_allocation, uint32_t x); /** * \overload */ extern const void * __attribute__((overloadable)) rsGetElementAt(rs_allocation, uint32_t x, uint32_t y); /** * \overload */ extern const void * __attribute__((overloadable)) rsGetElementAt(rs_allocation, uint32_t x, uint32_t y, uint32_t z); #define GET_ELEMENT_AT(T) \ static inline T __attribute__((overloadable)) \ rsGetElementAt_##T(rs_allocation a, uint32_t x) { \ return ((T *)rsGetElementAt(a, x))[0]; \ } \ static inline T __attribute__((overloadable)) \ rsGetElementAt_##T(rs_allocation a, uint32_t x, uint32_t y) { \ return ((T *)rsGetElementAt(a, x, y))[0]; \ } \ static inline T __attribute__((overloadable)) \ rsGetElementAt_##T(rs_allocation a, uint32_t x, uint32_t y, uint32_t z) { \ return ((T *)rsGetElementAt(a, x, y, z))[0]; \ } GET_ELEMENT_AT(char) GET_ELEMENT_AT(char2) GET_ELEMENT_AT(char3) GET_ELEMENT_AT(char4) GET_ELEMENT_AT(uchar) GET_ELEMENT_AT(uchar2) GET_ELEMENT_AT(uchar3) GET_ELEMENT_AT(uchar4) GET_ELEMENT_AT(short) GET_ELEMENT_AT(short2) GET_ELEMENT_AT(short3) GET_ELEMENT_AT(short4) GET_ELEMENT_AT(ushort) GET_ELEMENT_AT(ushort2) GET_ELEMENT_AT(ushort3) GET_ELEMENT_AT(ushort4) GET_ELEMENT_AT(int) GET_ELEMENT_AT(int2) GET_ELEMENT_AT(int3) GET_ELEMENT_AT(int4) GET_ELEMENT_AT(uint) GET_ELEMENT_AT(uint2) GET_ELEMENT_AT(uint3) GET_ELEMENT_AT(uint4) GET_ELEMENT_AT(long) GET_ELEMENT_AT(long2) GET_ELEMENT_AT(long3) GET_ELEMENT_AT(long4) GET_ELEMENT_AT(ulong) GET_ELEMENT_AT(ulong2) GET_ELEMENT_AT(ulong3) GET_ELEMENT_AT(ulong4) GET_ELEMENT_AT(float) GET_ELEMENT_AT(float2) GET_ELEMENT_AT(float3) GET_ELEMENT_AT(float4) GET_ELEMENT_AT(double) GET_ELEMENT_AT(double2) GET_ELEMENT_AT(double3) GET_ELEMENT_AT(double4) #undef GET_ELEMENT_AT // New API's #if (defined(RS_VERSION) && (RS_VERSION >= 16)) /** * Send the contents of the Allocation to the queue. * @param a allocation to work on */ extern const void __attribute__((overloadable)) rsAllocationIoSend(rs_allocation a); /** * Receive a new set of contents from the queue. * @param a allocation to work on */ extern const void __attribute__((overloadable)) rsAllocationIoReceive(rs_allocation a); /** * Get the element object describing the allocation's layout * @param a allocation to get data from * @return element describing allocation layout */ extern rs_element __attribute__((overloadable)) rsAllocationGetElement(rs_allocation a); /** * Fetch allocation in a way described by the sampler * @param a 1D allocation to sample from * @param s sampler state * @param location to sample from */ extern const float4 __attribute__((overloadable)) rsSample(rs_allocation a, rs_sampler s, float location); /** * Fetch allocation in a way described by the sampler * @param a 1D allocation to sample from * @param s sampler state * @param location to sample from * @param lod mip level to sample from, for fractional values * mip levels will be interpolated if * RS_SAMPLER_LINEAR_MIP_LINEAR is used */ extern const float4 __attribute__((overloadable)) rsSample(rs_allocation a, rs_sampler s, float location, float lod); /** * Fetch allocation in a way described by the sampler * @param a 2D allocation to sample from * @param s sampler state * @param location to sample from */ extern const float4 __attribute__((overloadable)) rsSample(rs_allocation a, rs_sampler s, float2 location); /** * Fetch allocation in a way described by the sampler * @param a 2D allocation to sample from * @param s sampler state * @param location to sample from * @param lod mip level to sample from, for fractional values * mip levels will be interpolated if * RS_SAMPLER_LINEAR_MIP_LINEAR is used */ extern const float4 __attribute__((overloadable)) rsSample(rs_allocation a, rs_sampler s, float2 location, float lod); #endif // (defined(RS_VERSION) && (RS_VERSION >= 16)) #endif