6.26. Texture Object Management

This section describes the low level texture object management functions of the CUDA runtime application programming interface. The texture object API is only supported on devices of compute capability 3.0 or higher.

Functions

__host__cudaChannelFormatDesc cudaCreateChannelDesc ( int x, int y, int z, int w, cudaChannelFormatKind f )
Returns a channel descriptor using the specified format.
__host__cudaError_t cudaCreateTextureObject ( cudaTextureObject_t*pTexObject, const cudaResourceDesc*pResDesc, const cudaTextureDesc*pTexDesc, const cudaResourceViewDesc*pResViewDesc )
Creates a texture object.
__host__cudaError_t cudaDestroyTextureObject ( cudaTextureObject_t texObject )
Destroys a texture object.
__host__cudaError_t cudaGetChannelDesc ( cudaChannelFormatDesc*desc, cudaArray_const_t array )
Get the channel descriptor of an array.
__host__cudaError_t cudaGetTextureObjectResourceDesc ( cudaResourceDesc*pResDesc, cudaTextureObject_t texObject )
Returns a texture object's resource descriptor.
__host__cudaError_t cudaGetTextureObjectResourceViewDesc ( cudaResourceViewDesc*pResViewDesc, cudaTextureObject_t texObject )
Returns a texture object's resource view descriptor.
__host__cudaError_t cudaGetTextureObjectTextureDesc ( cudaTextureDesc*pTexDesc, cudaTextureObject_t texObject )
Returns a texture object's texture descriptor.

Functions

__host__cudaChannelFormatDesc cudaCreateChannelDesc ( int x, int y, int z, int w, cudaChannelFormatKind f )
Returns a channel descriptor using the specified format.
Parameters
x
- X component
y
- Y component
z
- Z component
w
- W component
f
- Channel format
Returns

Channel descriptor with format f

Description

Returns a channel descriptor with format f and number of bits of each component x, y, z, and w. The cudaChannelFormatDesc is defined as:

‎ struct cudaChannelFormatDesc {
 int x, y, z, w;
 enum cudaChannelFormatKind 
 f;
 };

where cudaChannelFormatKind is one of cudaChannelFormatKindSigned, cudaChannelFormatKindUnsigned, or cudaChannelFormatKindFloat.

See also:

cudaCreateChannelDesc ( C++ API), cudaGetChannelDesc, cudaCreateTextureObject, cudaCreateSurfaceObject

__host__cudaError_t cudaCreateTextureObject ( cudaTextureObject_t*pTexObject, const cudaResourceDesc*pResDesc, const cudaTextureDesc*pTexDesc, const cudaResourceViewDesc*pResViewDesc )
Creates a texture object.
Parameters
pTexObject
- Texture object to create
pResDesc
- Resource descriptor
pTexDesc
- Texture descriptor
pResViewDesc
- Resource view descriptor
Description

Creates a texture object and returns it in pTexObject. pResDesc describes the data to texture from. pTexDesc describes how the data should be sampled. pResViewDesc is an optional argument that specifies an alternate format for the data described by pResDesc, and also describes the subresource region to restrict access to when texturing. pResViewDesc can only be specified if the type of resource is a CUDA array or a CUDA mipmapped array not in a block compressed format.

Texture objects are only supported on devices of compute capability 3.0 or higher. Additionally, a texture object is an opaque value, and, as such, should only be accessed through CUDA API calls.

The cudaResourceDesc structure is defined as:

‎ struct cudaResourceDesc {
 enum cudaResourceType 
 resType;
 
 union {
 struct {
 cudaArray_t 
 array;
 } array;
 struct {
 cudaMipmappedArray_t 
 mipmap;
 } mipmap;
 struct {
 void *devPtr;
 struct cudaChannelFormatDesc 
 desc;
 size_t sizeInBytes;
 } linear;
 struct {
 void *devPtr;
 struct cudaChannelFormatDesc 
 desc;
 size_t width;
 size_t height;
 size_t pitchInBytes;
 } pitch2D;
 } res;
 };
where:

If cudaResourceDesc::resType is set to cudaResourceTypeArray, cudaResourceDesc::res::array::array must be set to a valid CUDA array handle.

If cudaResourceDesc::resType is set to cudaResourceTypeMipmappedArray, cudaResourceDesc::res::mipmap::mipmap must be set to a valid CUDA mipmapped array handle and cudaTextureDesc::normalizedCoords must be set to true.

If cudaResourceDesc::resType is set to cudaResourceTypeLinear, cudaResourceDesc::res::linear::devPtr must be set to a valid device pointer, that is aligned to cudaDeviceProp::textureAlignment. cudaResourceDesc::res::linear::desc describes the format and the number of components per array element. cudaResourceDesc::res::linear::sizeInBytes specifies the size of the array in bytes. The total number of elements in the linear address range cannot exceed cudaDeviceGetTexture1DLinearMaxWidth(). The number of elements is computed as (sizeInBytes / sizeof(desc)).

If cudaResourceDesc::resType is set to cudaResourceTypePitch2D, cudaResourceDesc::res::pitch2D::devPtr must be set to a valid device pointer, that is aligned to cudaDeviceProp::textureAlignment. cudaResourceDesc::res::pitch2D::desc describes the format and the number of components per array element. cudaResourceDesc::res::pitch2D::width and cudaResourceDesc::res::pitch2D::height specify the width and height of the array in elements, and cannot exceed cudaDeviceProp::maxTexture2DLinear[0] and cudaDeviceProp::maxTexture2DLinear[1] respectively. cudaResourceDesc::res::pitch2D::pitchInBytes specifies the pitch between two rows in bytes and has to be aligned to cudaDeviceProp::texturePitchAlignment. Pitch cannot exceed cudaDeviceProp::maxTexture2DLinear[2].

The cudaTextureDesc struct is defined as

‎ struct cudaTextureDesc {
 enum cudaTextureAddressMode 
 addressMode[3];
 enum cudaTextureFilterMode 
 filterMode;
 enum cudaTextureReadMode 
 readMode;
 int sRGB;
 float borderColor[4];
 int normalizedCoords;
 unsigned int maxAnisotropy;
 enum cudaTextureFilterMode 
 mipmapFilterMode;
 float mipmapLevelBias;
 float minMipmapLevelClamp;
 float maxMipmapLevelClamp;
 int disableTrilinearOptimization;
 int seamlessCubemap;
 };
where
  • cudaTextureDesc::sRGB specifies whether sRGB to linear conversion should be performed during texture fetch.

  • cudaTextureDesc::maxAnisotropy specifies the maximum anistropy ratio to be used when doing anisotropic filtering. This value will be clamped to the range [1,16].

The cudaResourceViewDesc struct is defined as

‎ struct cudaResourceViewDesc {
 enum cudaResourceViewFormat 
 format;
 size_t width;
 size_t height;
 size_t depth;
 unsigned int firstMipmapLevel;
 unsigned int lastMipmapLevel;
 unsigned int firstLayer;
 unsigned int lastLayer;
 };
where:
  • cudaResourceViewDesc::format specifies how the data contained in the CUDA array or CUDA mipmapped array should be interpreted. Note that this can incur a change in size of the texture data. If the resource view format is a block compressed format, then the underlying CUDA array or CUDA mipmapped array has to have a 32-bit unsigned integer format with 2 or 4 channels, depending on the block compressed format. For ex., BC1 and BC4 require the underlying CUDA array to have a 32-bit unsigned int with 2 channels. The other BC formats require the underlying resource to have the same 32-bit unsigned int format but with 4 channels.

  • cudaResourceViewDesc::width specifies the new width of the texture data. If the resource view format is a block compressed format, this value has to be 4 times the original width of the resource. For non block compressed formats, this value has to be equal to that of the original resource.

  • cudaResourceViewDesc::height specifies the new height of the texture data. If the resource view format is a block compressed format, this value has to be 4 times the original height of the resource. For non block compressed formats, this value has to be equal to that of the original resource.

  • cudaResourceViewDesc::depth specifies the new depth of the texture data. This value has to be equal to that of the original resource.

  • cudaResourceViewDesc::firstLayer specifies the first layer index for layered textures. This will be the new layer zero. For non-layered resources, this value has to be zero.

Note:

See also:

cudaDestroyTextureObject, cuTexObjectCreate

__host__cudaError_t cudaDestroyTextureObject ( cudaTextureObject_t texObject )
Destroys a texture object.
Parameters
texObject
- Texture object to destroy
Description

Destroys the texture object specified by texObject.

Note:

See also:

cudaCreateTextureObject, cuTexObjectDestroy

__host__cudaError_t cudaGetChannelDesc ( cudaChannelFormatDesc*desc, cudaArray_const_t array )
Get the channel descriptor of an array.
Parameters
desc
- Channel format
array
- Memory array on device
Description

Returns in *desc the channel descriptor of the CUDA array array.

Note:

See also:

cudaCreateChannelDesc ( C API), cudaCreateTextureObject, cudaCreateSurfaceObject

__host__cudaError_t cudaGetTextureObjectResourceDesc ( cudaResourceDesc*pResDesc, cudaTextureObject_t texObject )
Returns a texture object's resource descriptor.
Parameters
pResDesc
- Resource descriptor
texObject
- Texture object
Description

Returns the resource descriptor for the texture object specified by texObject.

Note:

See also:

cudaCreateTextureObject, cuTexObjectGetResourceDesc

__host__cudaError_t cudaGetTextureObjectResourceViewDesc ( cudaResourceViewDesc*pResViewDesc, cudaTextureObject_t texObject )
Returns a texture object's resource view descriptor.
Parameters
pResViewDesc
- Resource view descriptor
texObject
- Texture object
Description

Returns the resource view descriptor for the texture object specified by texObject. If no resource view was specified, cudaErrorInvalidValue is returned.

Note:

See also:

cudaCreateTextureObject, cuTexObjectGetResourceViewDesc

__host__cudaError_t cudaGetTextureObjectTextureDesc ( cudaTextureDesc*pTexDesc, cudaTextureObject_t texObject )
Returns a texture object's texture descriptor.
Parameters
pTexDesc
- Texture descriptor
texObject
- Texture object
Description

Returns the texture descriptor for the texture object specified by texObject.

Note:

See also:

cudaCreateTextureObject, cuTexObjectGetTextureDesc


AltStyle によって変換されたページ (->オリジナル) /