Added/Updated header files for AddrLib support (GFX12)

Updated struct definitions, field size changes and new fields in
registers.h.

Added resource_gfx12.h and updated fields in BUF/IMG/SAMP descriptor
structs based on documentation.

Signed-off-by: David Belanger <david.belanger@amd.com>
Change-Id: I08f05ba30f54c40e7b823a6a105829a1e8590b3d
Signed-off-by: Chris Freehill <cfreehil@amd.com>


[ROCm/ROCR-Runtime commit: 8165da63cc]
Этот коммит содержится в:
David Belanger
2024-01-23 12:48:50 -05:00
коммит произвёл Chris Freehill
родитель 8423772acb
Коммит bb7dcbc38b
2 изменённых файлов: 869 добавлений и 0 удалений
+55
Просмотреть файл
@@ -134,6 +134,23 @@ SQ_SEL_W = 0x00000007,
float f32All;
};
union COMPUTE_TMPRING_SIZE_GFX12 {
struct {
#if defined(LITTLEENDIAN_CPU)
unsigned int WAVES : 12;
unsigned int WAVESIZE : 18;
unsigned int : 2;
#elif defined(BIGENDIAN_CPU)
unsigned int : 2;
unsigned int WAVESIZE : 18;
unsigned int WAVES : 12;
#endif
} bitfields, bits;
unsigned int u32All;
signed int i32All;
float f32All;
};
union SQ_BUF_RSRC_WORD0 {
struct {
@@ -301,6 +318,44 @@ SQ_SEL_W = 0x00000007,
unsigned int DST_SEL_Z : 3;
unsigned int DST_SEL_Y : 3;
unsigned int DST_SEL_X : 3;
#endif
} bitfields, bits;
unsigned int u32All;
signed int i32All;
float f32All;
};
// From V# Table
union SQ_BUF_RSRC_WORD3_GFX12 {
struct {
#if defined(LITTLEENDIAN_CPU)
unsigned int DST_SEL_X : 3;
unsigned int DST_SEL_Y : 3;
unsigned int DST_SEL_Z : 3;
unsigned int DST_SEL_W : 3;
unsigned int FORMAT : 6;
unsigned int RESERVED1 : 3;
unsigned int INDEX_STRIDE : 2;
unsigned int ADD_TID_ENABLE : 1;
unsigned int WRITE_COMPRESS_ENABLE : 1;
unsigned int COMPRESSION_EN : 1;
unsigned int COMPRESSION_ACCESS_MODE : 2;
unsigned int OOB_SELECT : 2;
unsigned int TYPE : 2;
#elif defined(BIGENDIAN_CPU)
unsigned int TYPE : 2;
unsigned int OOB_SELECT : 2;
unsigned int COMPRESSION_ACCESS_MODE : 2;
unsigned int COMPRESSION_EN : 1;
unsigned int WRITE_COMPRESS_ENABLE : 1;
unsigned int ADD_TID_ENABLE : 1;
unsigned int INDEX_STRIDE : 2;
unsigned int RESERVED1 : 3;
unsigned int FORMAT : 6;
unsigned int DST_SEL_W : 3;
unsigned int DST_SEL_Z : 3;
unsigned int DST_SEL_Y : 3;
unsigned int DST_SEL_X : 3;
#endif
} bitfields, bits;
unsigned int u32All;
+814
Просмотреть файл
@@ -0,0 +1,814 @@
////////////////////////////////////////////////////////////////////////////////
//
// The University of Illinois/NCSA
// Open Source License (NCSA)
//
// Copyright (c) 2014-2024, Advanced Micro Devices, Inc. All rights reserved.
//
// Developed by:
//
// AMD Research and AMD HSA Software Development
//
// Advanced Micro Devices, Inc.
//
// www.amd.com
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal with the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// - Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimers.
// - Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimers in
// the documentation and/or other materials provided with the distribution.
// - Neither the names of Advanced Micro Devices, Inc,
// nor the names of its contributors may be used to endorse or promote
// products derived from this Software without specific prior written
// permission.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
// OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS WITH THE SOFTWARE.
//
////////////////////////////////////////////////////////////////////////////////
#ifndef EXT_IMAGE_RESOURCE_GFX12_H_
#define EXT_IMAGE_RESOURCE_GFX12_H_
#if defined(LITTLEENDIAN_CPU)
#elif defined(BIGENDIAN_CPU)
#else
#error "BIGENDIAN_CPU or LITTLEENDIAN_CPU must be defined"
#endif
namespace rocr {
namespace image {
/**********************************************************/
/**********************************************************/
#define SQ_BUF_RSC_WRD0_REG_SZ 32
#define SQ_BUF_RSC_WRD0_BASE_ADDRESS_SZ 32
struct sq_buf_rsrc_word0_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int BASE_ADDRESS : SQ_BUF_RSC_WRD0_BASE_ADDRESS_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int BASE_ADDRESS : SQ_BUF_RSC_WRD0_BASE_ADDRESS_SZ;
#endif
};
union SQ_BUF_RSRC_WORD0 {
sq_buf_rsrc_word0_t bitfields, bits, f;
uint32_t val : SQ_BUF_RSC_WRD0_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
/* Note: These registers are also defined/used in registers.h
* in SQ_BUF_RSRC_WORD*_GFX12
*/
#define SQ_BUF_RSC_WRD1_REG_SZ 32
#define SQ_BUF_RSC_WRD1_BASE_ADDRESS_HI_SZ 16
#define SQ_BUF_RSC_WRD1_STRIDE_SZ 14
#define SQ_BUF_RSC_WRD1_SWIZZLE_ENABLE_SZ 2
struct sq_buf_rsrc_word1_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int BASE_ADDRESS_HI : SQ_BUF_RSC_WRD1_BASE_ADDRESS_HI_SZ;
unsigned int STRIDE : SQ_BUF_RSC_WRD1_STRIDE_SZ;
unsigned int SWIZZLE_ENABLE : SQ_BUF_RSC_WRD1_SWIZZLE_ENABLE_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int SWIZZLE_ENABLE : SQ_BUF_RSC_WRD1_SWIZZLE_ENABLE_SZ;
unsigned int STRIDE : SQ_BUF_RSC_WRD1_STRIDE_SZ;
unsigned int BASE_ADDRESS_HI : SQ_BUF_RSC_WRD1_BASE_ADDRESS_HI_SZ;
#endif
};
union SQ_BUF_RSRC_WORD1 {
sq_buf_rsrc_word1_t bitfields, bits, f;
uint32_t val : SQ_BUF_RSC_WRD1_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_BUF_RSC_WRD2_REG_SZ 32
#define SQ_BUF_RSC_WRD2_NUM_RECORDS_SZ 32
struct sq_buf_rsrc_word2_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int NUM_RECORDS : SQ_BUF_RSC_WRD2_NUM_RECORDS_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int NUM_RECORDS : SQ_BUF_RSC_WRD2_NUM_RECORDS_SZ;
#endif
};
union SQ_BUF_RSRC_WORD2 {
sq_buf_rsrc_word2_t bitfields, bits, f;
uint32_t val : SQ_BUF_RSC_WRD2_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_BUF_RSC_WRD3_REG_SZ 32
#define SQ_BUF_RSC_WRD3_DST_SEL_X_SZ 3
#define SQ_BUF_RSC_WRD3_DST_SEL_Y_SZ 3
#define SQ_BUF_RSC_WRD3_DST_SEL_Z_SZ 3
#define SQ_BUF_RSC_WRD3_DST_SEL_W_SZ 3
#define SQ_BUF_RSC_WRD3_FORMAT_SZ 6
#define SQ_BUF_RSC_WRD3_INDEX_STRIDE_SZ 2
#define SQ_BUF_RSC_WRD3_ADD_TID_ENABLE_SZ 1
#define SQ_BUF_RSC_WRD3_WRITE_COMPRESS_ENABLE_SZ 1
#define SQ_BUF_RSC_WRD3_COMPRESSION_EN_SZ 1
#define SQ_BUF_RSC_WRD3_COMPRESSION_ACCESS_MODE_SZ 2
#define SQ_BUF_RSC_WORD3_OOB_SELECT_SZ 2
#define SQ_BUF_RSC_WRD3_TYPE_SZ 2
struct sq_buf_rsrc_word3_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int DST_SEL_X : SQ_BUF_RSC_WRD3_DST_SEL_X_SZ;
unsigned int DST_SEL_Y : SQ_BUF_RSC_WRD3_DST_SEL_Y_SZ;
unsigned int DST_SEL_Z : SQ_BUF_RSC_WRD3_DST_SEL_Z_SZ;
unsigned int DST_SEL_W : SQ_BUF_RSC_WRD3_DST_SEL_W_SZ;
unsigned int FORMAT : SQ_BUF_RSC_WRD3_FORMAT_SZ;
unsigned int : 3;
unsigned int INDEX_STRIDE : SQ_BUF_RSC_WRD3_INDEX_STRIDE_SZ;
unsigned int ADD_TID_ENABLE : SQ_BUF_RSC_WRD3_ADD_TID_ENABLE_SZ;
unsigned int WRITE_COMPRESS_ENABLE : SQ_BUF_RSC_WRD3_WRITE_COMPRESS_ENABLE_SZ;
unsigned int COMPRESSION_EN : SQ_BUF_RSC_WRD3_COMPRESSION_EN_SZ;
unsigned int COMPRESSION_ACCESS_MODE : SQ_BUF_RSC_WRD3_COMPRESSION_ACCESS_MODE_SZ;
unsigned int OOB_SELECT : SQ_BUF_RSC_WORD3_OOB_SELECT_SZ;
unsigned int TYPE : SQ_BUF_RSC_WRD3_TYPE_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int TYPE : SQ_BUF_RSC_WRD3_TYPE_SZ;
unsigned int OOB_SELECT : SQ_BUF_RSC_WORD3_OOB_SELECT_SZ;
unsigned int COMPRESSION_ACCESS_MODE : SQ_BUF_RSC_WRD3_COMPRESSION_ACCESS_MODE_SZ;
unsigned int COMPRESSION_EN : SQ_BUF_RSC_WRD3_COMPRESSION_EN_SZ;
unsigned int WRITE_COMPRESS_ENABLE : SQ_BUF_RSC_WRD3_WRITE_COMPRESS_ENABLE_SZ;
unsigned int ADD_TID_ENABLE : SQ_BUF_RSC_WRD3_ADD_TID_ENABLE_SZ;
unsigned int INDEX_STRIDE : SQ_BUF_RSC_WRD3_INDEX_STRIDE_SZ;
unsigned int : 3;
unsigned int FORMAT : SQ_BUF_RSC_WRD3_FORMAT_SZ;
unsigned int DST_SEL_W : SQ_BUF_RSC_WRD3_DST_SEL_W_SZ;
unsigned int DST_SEL_Z : SQ_BUF_RSC_WRD3_DST_SEL_Z_SZ;
unsigned int DST_SEL_Y : SQ_BUF_RSC_WRD3_DST_SEL_Y_SZ;
unsigned int DST_SEL_X : SQ_BUF_RSC_WRD3_DST_SEL_X_SZ;
#endif
};
union SQ_BUF_RSRC_WORD3 {
sq_buf_rsrc_word3_t bitfields, bits, f;
uint32_t val : SQ_BUF_RSC_WRD3_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
/**********************************************************/
/**********************************************************/
#define SQ_IMG_RSC_WRD0_REG_SZ 32
#define SQ_IMG_RSC_WRD0_BASE_ADDRESS_SZ 32
struct sq_img_rsrc_word0_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int BASE_ADDRESS : SQ_IMG_RSC_WRD0_BASE_ADDRESS_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int BASE_ADDRESS : SQ_IMG_RSC_WRD0_BASE_ADDRESS_SZ;
#endif
};
union SQ_IMG_RSRC_WORD0 {
sq_img_rsrc_word0_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD0_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD1_REG_SZ 32
#define SQ_IMG_RSC_WRD1_BASE_ADDRESS_HI_SZ 8
#define SQ_IMG_RSC_WRD1_MAX_MIP_SZ 5
#define SQ_IMG_RSC_WRD1_FORMAT_SZ 8
#define SQ_IMG_RSC_WRD1_BASE_LEVEL_SZ 5
#define SQ_IMG_RSC_WRD1_WIDTH_LO 2
struct sq_img_rsrc_word1_t{
#if defined(LITTLEENDIAN_CPU)
unsigned int BASE_ADDRESS_HI : SQ_IMG_RSC_WRD1_BASE_ADDRESS_HI_SZ;
unsigned int : 4;
unsigned int MAX_MIP : SQ_IMG_RSC_WRD1_MAX_MIP_SZ;
unsigned int FORMAT : SQ_IMG_RSC_WRD1_FORMAT_SZ;
unsigned int BASE_LEVEL : SQ_IMG_RSC_WRD1_BASE_LEVEL_SZ;
unsigned int WIDTH : SQ_IMG_RSC_WRD1_WIDTH_LO;
#elif defined(BIGENDIAN_CPU)
unsigned int WIDTH : SQ_IMG_RSC_WRD1_WIDTH_LO;
unsigned int BASE_LEVEL : SQ_IMG_RSC_WRD1_BASE_LEVEL_SZ;
unsigned int FORMAT : SQ_IMG_RSC_WRD1_FORMAT_SZ;
unsigned int MAX_MIP : SQ_IMG_RSC_WRD1_MAX_MIP_SZ;
unsigned int : 4;
unsigned int BASE_ADDRESS_HI : SQ_IMG_RSC_WRD1_BASE_ADDRESS_HI_SZ;
#endif
};
union SQ_IMG_RSRC_WORD1 {
sq_img_rsrc_word1_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD1_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD2_REG_SZ 32
#define SQ_IMG_RSC_WRD2_WIDTH_HI_SZ 14
#define SQ_IMG_RSC_WRD2_HEIGHT_SZ 16
struct sq_img_rsrc_word2_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int WIDTH_HI : SQ_IMG_RSC_WRD2_WIDTH_HI_SZ;
unsigned int HEIGHT : SQ_IMG_RSC_WRD2_HEIGHT_SZ;
unsigned int : 2;
#elif defined(BIGENDIAN_CPU)
unsigned int : 2;
unsigned int HEIGHT : SQ_IMG_RSC_WRD2_HEIGHT_SZ;
unsigned int WIDTH_HI : SQ_IMG_RSC_WRD2_WIDTH_HI_SZ;
#endif
};
union SQ_IMG_RSRC_WORD2 {
sq_img_rsrc_word2_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD2_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD3_REG_SZ 32
#define SQ_IMG_RSC_WRD3_DST_SEL_X_SZ 3
#define SQ_IMG_RSC_WRD3_DST_SEL_Y_SZ 3
#define SQ_IMG_RSC_WRD3_DST_SEL_Z_SZ 3
#define SQ_IMG_RSC_WRD3_DST_SEL_W_SZ 3
#define SQ_IMG_RSC_WRD3_NO_EDGE_CLAMP_SZ 1
#define SQ_IMG_RSC_WRD3_LAST_LEVEL_SZ 5
#define SQ_IMG_RSC_WRD3_SW_MODE_SZ 5
#define SQ_IMG_RSC_WRD3_BC_SWIZZLE_SZ 3
#define SQ_IMG_RSC_WRD3_TYPE_SZ 4
struct sq_img_rsrc_word3_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int DST_SEL_X : SQ_IMG_RSC_WRD3_DST_SEL_X_SZ;
unsigned int DST_SEL_Y : SQ_IMG_RSC_WRD3_DST_SEL_Y_SZ;
unsigned int DST_SEL_Z : SQ_IMG_RSC_WRD3_DST_SEL_Z_SZ;
unsigned int DST_SEL_W : SQ_IMG_RSC_WRD3_DST_SEL_W_SZ;
unsigned int NO_EDGE_CLAMP : SQ_IMG_RSC_WRD3_NO_EDGE_CLAMP_SZ;
unsigned int : 2;
unsigned int LAST_LEVEL : SQ_IMG_RSC_WRD3_LAST_LEVEL_SZ;
unsigned int SW_MODE : SQ_IMG_RSC_WRD3_SW_MODE_SZ;
unsigned int BC_SWIZZLE : SQ_IMG_RSC_WRD3_BC_SWIZZLE_SZ;
unsigned int TYPE : SQ_IMG_RSC_WRD3_TYPE_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int TYPE : SQ_IMG_RSC_WRD3_TYPE_SZ;
unsigned int BC_SWIZZLE : SQ_IMG_RSC_WRD3_BC_SWIZZLE_SZ;
unsigned int SW_MODE : SQ_IMG_RSC_WRD3_SW_MODE_SZ;
unsigned int LAST_LEVEL : SQ_IMG_RSC_WRD3_LAST_LEVEL_SZ;
unsigned int : 2;
unsigned int NO_EDGE_CLAMP : SQ_IMG_RSC_WRD3_NO_EDGE_CLAMP_SZ;
unsigned int DST_SEL_W : SQ_IMG_RSC_WRD3_DST_SEL_W_SZ;
unsigned int DST_SEL_Z : SQ_IMG_RSC_WRD3_DST_SEL_Z_SZ;
unsigned int DST_SEL_Y : SQ_IMG_RSC_WRD3_DST_SEL_Y_SZ;
unsigned int DST_SEL_X : SQ_IMG_RSC_WRD3_DST_SEL_X_SZ;
#endif
};
union SQ_IMG_RSRC_WORD3 {
sq_img_rsrc_word3_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD3_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD4_REG_SZ 32
#define SQ_IMG_RSC_WRD4_DEPTH_SZ 14
#define SQ_IMG_RSC_WRD4_PITCH_MSB_SZ 2
#define SQ_IMG_RSC_WRD4_BASE_ARR_SZ 13
#define SQ_IMG_RSC_WRD4_BASE_ARRAY_MSB_SZ 1
struct sq_img_rsrc_word4_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int DEPTH : SQ_IMG_RSC_WRD4_DEPTH_SZ;
unsigned int PITCH_MSB : SQ_IMG_RSC_WRD4_PITCH_MSB_SZ;
unsigned int BASE_ARRAY : SQ_IMG_RSC_WRD4_BASE_ARR_SZ;
unsigned int BASE_ARRAY_MSB : SQ_IMG_RSC_WRD4_BASE_ARRAY_MSB_SZ;
unsigned int : 2;
#elif defined(BIGENDIAN_CPU)
unsigned int : 2;
unsigned int BASE_ARRAY_MSB : SQ_IMG_RSC_WRD4_BASE_ARRAY_MSB_SZ;
unsigned int BASE_ARRAY : SQ_IMG_RSC_WRD4_BASE_ARR_SZ;
unsigned int PITCH_MSB : SQ_IMG_RSC_WRD4_PITCH_MSB_SZ;
unsigned int DEPTH : SQ_IMG_RSC_WRD4_DEPTH_SZ;
#endif
};
union SQ_IMG_RSRC_WORD4 {
sq_img_rsrc_word4_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD4_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD5_REG_SZ 32
#define SQ_IMG_RSC_WRD5_UAV3D_SZ 1
#define SQ_IMG_RSC_WRD5_DEPTH_SCALE_SZ 5
#define SQ_IMG_RSC_WRD5_HEIGHT_SCALE_SZ 5
#define SQ_IMG_RSC_WRD5_WIDTH_SCALE_SZ 5 // Combined two consecutive separate fields width[0:2] and width[3:4].
#define SQ_IMG_RSC_WRD5_PERF_MOD_SZ 3
#define SQ_IMG_RSC_WRD5_CORNER_SAMPLES_SZ 1
#define SQ_IMG_RSC_WRD5_LINKED_RESOURCE_SZ 1
#define SQ_IMG_RSC_WRD5_LOD_HWD_CNT_EN_SZ 1
#define SQ_IMG_RSC_WRD5_MIN_LOD_LO_SZ 6 // lowest 6 bits of MIN_LOD (13 bit total)
struct sq_img_rsrc_word5_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int : 4;
unsigned int UAV3D : SQ_IMG_RSC_WRD5_UAV3D_SZ;
unsigned int DEPTH_SCALE : SQ_IMG_RSC_WRD5_DEPTH_SCALE_SZ;
unsigned int HEIGHT_SCALE : SQ_IMG_RSC_WRD5_HEIGHT_SCALE_SZ;
unsigned int WIDTH_SCALE : SQ_IMG_RSC_WRD5_WIDTH_SCALE_SZ;
unsigned int PERF_MOD : SQ_IMG_RSC_WRD5_PERF_MOD_SZ;
unsigned int CORNER_SAMPLES : SQ_IMG_RSC_WRD5_CORNER_SAMPLES_SZ;
unsigned int LINKED_RESOURCE : SQ_IMG_RSC_WRD5_LINKED_RESOURCE_SZ;
unsigned int LOD_HWD_CNT_EN : SQ_IMG_RSC_WRD5_LOD_HWD_CNT_EN_SZ;
unsigned int MIN_LOD_LO : SQ_IMG_RSC_WRD5_MIN_LOD_LO_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int MIN_LOD_LO : SQ_IMG_RSC_WRD5_MIN_LOD_LO_SZ;
unsigned int LOD_HWD_CNT_EN : SQ_IMG_RSC_WRD5_LOD_HWD_CNT_EN_SZ;
unsigned int LINKED_RESOURCE : SQ_IMG_RSC_WRD5_LINKED_RESOURCE_SZ;
unsigned int CORNER_SAMPLES : SQ_IMG_RSC_WRD5_CORNER_SAMPLES_SZ;
unsigned int PERF_MOD : SQ_IMG_RSC_WRD5_PERF_MOD_SZ;
unsigned int WIDTH_SCALE : SQ_IMG_RSC_WRD5_WIDTH_SCALE_SZ;
unsigned int HEIGHT_SCALE : SQ_IMG_RSC_WRD5_HEIGHT_SCALE_SZ;
unsigned int DEPTH_SCALE : SQ_IMG_RSC_WRD5_DEPTH_SCALE_SZ;
unsigned int UAV3D : SQ_IMG_RSC_WRD5_UAV3D_SZ;
unsigned int : 4;
#endif
};
union SQ_IMG_RSRC_WORD5 {
sq_img_rsrc_word5_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD5_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD6_REG_SZ 32
#define SQ_IMG_RSC_WRD6_MIN_LOD_HI_SZ 7
#define SQ_IMG_RSC_WRD5_COUNTER_BANK_ID_SZ 8 // 3 fields combined into bank_id
#define SQ_IMG_RSC_WRD6_MAX_UNCOMP_BLK_SZ_SZ 1
#define SQ_IMG_RSC_WRD6_MAX_COMP_BLK_SZ_SZ 2
#define SQ_IMG_RSC_WRD6_WRITE_COMPRESS_EN_SZ 1
#define SQ_IMG_RSC_WRD6_COMPRESSION_ENABLE_SZ 1
#define SQ_IMG_RSC_WRD6_COMPRESSION_ACCESS_MODE_SZ 2
#define SQ_IMG_RSC_WRD6_SPECULATIVE_READ_SZ 2
struct sq_img_rsrc_word6_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int MIN_LOD_HI : SQ_IMG_RSC_WRD6_MIN_LOD_HI_SZ;
unsigned int COUNTER_BANK_ID : SQ_IMG_RSC_WRD5_COUNTER_BANK_ID_SZ;
unsigned int MAX_UNCOMP_BLK_SZ : SQ_IMG_RSC_WRD6_MAX_UNCOMP_BLK_SZ_SZ;
unsigned int : 1;
unsigned int MAX_COMP_BLK_SZ : SQ_IMG_RSC_WRD6_MAX_COMP_BLK_SZ_SZ;
unsigned int : 1;
unsigned int WRITE_COMPRESS_ENABLE : SQ_IMG_RSC_WRD6_WRITE_COMPRESS_EN_SZ;
unsigned int COMPRESSION_ENABLE : SQ_IMG_RSC_WRD6_COMPRESSION_ENABLE_SZ;
unsigned int COMPRESSION_ACCESS_MODE : SQ_IMG_RSC_WRD6_COMPRESSION_ACCESS_MODE_SZ;
unsigned int SPECULATIVE_READ : SQ_IMG_RSC_WRD6_SPECULATIVE_READ_SZ;
unsigned int : 6;
#elif defined(BIGENDIAN_CPU)
unsigned int : 6;
unsigned int SPECULATIVE_READ : SQ_IMG_RSC_WRD6_SPECULATIVE_READ_SZ;
unsigned int COMPRESSION_ACCESS_MODE : SQ_IMG_RSC_WRD6_COMPRESSION_ACCESS_MODE_SZ;
unsigned int COMPRESSION_ENABLE : SQ_IMG_RSC_WRD6_COMPRESSION_ENABLE_SZ;
unsigned int WRITE_COMPRESS_ENABLE : SQ_IMG_RSC_WRD6_WRITE_COMPRESS_EN_SZ;
unsigned int : 1;
unsigned int MAX_COMP_BLK_SZ : SQ_IMG_RSC_WRD6_MAX_COMP_BLK_SZ_SZ;
unsigned int : 1;
unsigned int MAX_UNCOMP_BLK_SZ : SQ_IMG_RSC_WRD6_MAX_UNCOMP_BLK_SZ_SZ;
unsigned int COUNTER_BANK_ID : SQ_IMG_RSC_WRD5_COUNTER_BANK_ID_SZ;
unsigned int MIN_LOD_HI : SQ_IMG_RSC_WRD6_MIN_LOD_HI_SZ;
#endif
};
union SQ_IMG_RSRC_WORD6 {
sq_img_rsrc_word6_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD6_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_RSC_WRD7_REG_SZ 32
struct sq_img_rsrc_word7_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int : 32;
#elif defined(BIGENDIAN_CPU)
unsigned int : 32;
#endif
};
union SQ_IMG_RSRC_WORD7 {
sq_img_rsrc_word7_t bitfields, bits, f;
uint32_t val : SQ_IMG_RSC_WRD7_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
/**********************************************************/
/**********************************************************/
#define SQ_IMG_SAMP_WORD0_REG_SZ 32
#define SQ_IMG_SAMP_WORD0_CLAMP_X_SZ 3
#define SQ_IMG_SAMP_WORD0_CLAMP_Y_SZ 3
#define SQ_IMG_SAMP_WORD0_CLAMP_Z_SZ 3
#define SQ_IMG_SAMP_WORD0_MAX_ANISO_RATIO_SZ 3
#define SQ_IMG_SAMP_WORD0_DEPTH_COMPARE_FUNC_SZ 3
#define SQ_IMG_SAMP_WORD0_FORCE_UNNORMALIZED_SZ 1
#define SQ_IMG_SAMP_WORD0_ANISO_THRESHOLD_SZ 3
#define SQ_IMG_SAMP_WORD0_MC_COORD_TRUNC_SZ 1
#define SQ_IMG_SAMP_WORD0_FORCE_DEGAMMA_SZ 1
#define SQ_IMG_SAMP_WORD0_ANISO_BIAS_SZ 6
#define SQ_IMG_SAMP_WORD0_TRUNC_COORD_SZ 1
#define SQ_IMG_SAMP_WORD0_DISABLE_CUBE_WRAP_SZ 1
#define SQ_IMG_SAMP_WORD0_FILTER_MODE_SZ 2
#define SQ_IMG_SAMP_WORD0_SKIP_DEGAMMA_SZ 1
struct sq_img_samp_word0_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int CLAMP_X : SQ_IMG_SAMP_WORD0_CLAMP_X_SZ;
unsigned int CLAMP_Y : SQ_IMG_SAMP_WORD0_CLAMP_Y_SZ;
unsigned int CLAMP_Z : SQ_IMG_SAMP_WORD0_CLAMP_Z_SZ;
unsigned int MAX_ANISO_RATIO : SQ_IMG_SAMP_WORD0_MAX_ANISO_RATIO_SZ;
unsigned int DEPTH_COMPARE_FUNC : SQ_IMG_SAMP_WORD0_DEPTH_COMPARE_FUNC_SZ;
unsigned int FORCE_UNNORMALIZED : SQ_IMG_SAMP_WORD0_FORCE_UNNORMALIZED_SZ;
unsigned int ANISO_THRESHOLD : SQ_IMG_SAMP_WORD0_ANISO_THRESHOLD_SZ;
unsigned int MC_COORD_TRUNC : SQ_IMG_SAMP_WORD0_MC_COORD_TRUNC_SZ;
unsigned int FORCE_DEGAMMA : SQ_IMG_SAMP_WORD0_FORCE_DEGAMMA_SZ;
unsigned int ANISO_BIAS : SQ_IMG_SAMP_WORD0_ANISO_BIAS_SZ;
unsigned int TRUNC_COORD : SQ_IMG_SAMP_WORD0_TRUNC_COORD_SZ;
unsigned int DISABLE_CUBE_WRAP : SQ_IMG_SAMP_WORD0_DISABLE_CUBE_WRAP_SZ;
unsigned int FILTER_MODE : SQ_IMG_SAMP_WORD0_FILTER_MODE_SZ;
unsigned int SKIP_DEGAMMA : SQ_IMG_SAMP_WORD0_SKIP_DEGAMMA_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int SKIP_DEGAMMA : SQ_IMG_SAMP_WORD0_SKIP_DEGAMMA_SZ;
unsigned int FILTER_MODE : SQ_IMG_SAMP_WORD0_FILTER_MODE_SZ;
unsigned int DISABLE_CUBE_WRAP : SQ_IMG_SAMP_WORD0_DISABLE_CUBE_WRAP_SZ;
unsigned int TRUNC_COORD : SQ_IMG_SAMP_WORD0_TRUNC_COORD_SZ;
unsigned int ANISO_BIAS : SQ_IMG_SAMP_WORD0_ANISO_BIAS_SZ;
unsigned int FORCE_DEGAMMA : SQ_IMG_SAMP_WORD0_FORCE_DEGAMMA_SZ;
unsigned int MC_COORD_TRUNC : SQ_IMG_SAMP_WORD0_MC_COORD_TRUNC_SZ;
unsigned int ANISO_THRESHOLD : SQ_IMG_SAMP_WORD0_ANISO_THRESHOLD_SZ;
unsigned int FORCE_UNNORMALIZED : SQ_IMG_SAMP_WORD0_FORCE_UNNORMALIZED_SZ;
unsigned int DEPTH_COMPARE_FUNC : SQ_IMG_SAMP_WORD0_DEPTH_COMPARE_FUNC_SZ;
unsigned int MAX_ANISO_RATIO : SQ_IMG_SAMP_WORD0_MAX_ANISO_RATIO_SZ;
unsigned int CLAMP_Z : SQ_IMG_SAMP_WORD0_CLAMP_Z_SZ;
unsigned int CLAMP_Y : SQ_IMG_SAMP_WORD0_CLAMP_Y_SZ;
unsigned int CLAMP_X : SQ_IMG_SAMP_WORD0_CLAMP_X_SZ;
#endif
};
union SQ_IMG_SAMP_WORD0 {
sq_img_samp_word0_t bitfields, bits, f;
uint32_t val : SQ_IMG_SAMP_WORD0_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_SAMP_WORD1_REG_SZ 32
#define SQ_IMG_SAMP_WORD1_MIN_LOD_SZ 13
#define SQ_IMG_SAMP_WORD1_MAX_LOD_SZ 13
#define SQ_IMG_SAMP_WORD1_PERF_Z_SZ 4
struct sq_img_samp_word1_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int MIN_LOD : SQ_IMG_SAMP_WORD1_MIN_LOD_SZ;
unsigned int MAX_LOD : SQ_IMG_SAMP_WORD1_MAX_LOD_SZ;
unsigned int : 2;
unsigned int PERF_Z : SQ_IMG_SAMP_WORD1_PERF_Z_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int PERF_Z : SQ_IMG_SAMP_WORD1_PERF_Z_SZ;
unsigned int : 2;
unsigned int MAX_LOD : SQ_IMG_SAMP_WORD1_MAX_LOD_SZ;
unsigned int MIN_LOD : SQ_IMG_SAMP_WORD1_MIN_LOD_SZ;
#endif
};
union SQ_IMG_SAMP_WORD1 {
sq_img_samp_word1_t bitfields, bits, f;
uint32_t val : SQ_IMG_SAMP_WORD1_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_SAMP_WORD2_REG_SZ 32
#define SQ_IMG_SAMP_WORD2_LOD_BIAS_SZ 14
#define SQ_IMG_SAMP_WORD2_LOD_BIAS_SEC_SZ 6
#define SQ_IMG_SAMP_WORD2_XY_MAG_FILTER_SZ 2
#define SQ_IMG_SAMP_WORD2_XY_MIN_FILTER_SZ 2
#define SQ_IMG_SAMP_WORD2_Z_FILTER_SZ 2
#define SQ_IMG_SAMP_WORD2_MIP_FILTER_SZ 2
#define SQ_IMG_SAMP_WORD2_ANISO_OVERRIDE_SZ 1
#define SQ_IMG_SAMP_WORD2_PERF_MIP_LO_SZ 2
struct sq_img_samp_word2_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int LOD_BIAS : SQ_IMG_SAMP_WORD2_LOD_BIAS_SZ;
unsigned int LOD_BIAS_SEC : SQ_IMG_SAMP_WORD2_LOD_BIAS_SEC_SZ;
unsigned int XY_MAG_FILTER : SQ_IMG_SAMP_WORD2_XY_MAG_FILTER_SZ;
unsigned int XY_MIN_FILTER : SQ_IMG_SAMP_WORD2_XY_MIN_FILTER_SZ;
unsigned int Z_FILTER : SQ_IMG_SAMP_WORD2_Z_FILTER_SZ;
unsigned int MIP_FILTER : SQ_IMG_SAMP_WORD2_MIP_FILTER_SZ;
unsigned int : 1;
unsigned int ANISO_OVERRIDE : SQ_IMG_SAMP_WORD2_ANISO_OVERRIDE_SZ;
unsigned int PERF_MIP_LO : SQ_IMG_SAMP_WORD2_PERF_MIP_LO_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int PERF_MIP_LO : SQ_IMG_SAMP_WORD2_PERF_MIP_LO_SZ;
unsigned int ANISO_OVERRIDE : SQ_IMG_SAMP_WORD2_ANISO_OVERRIDE_SZ;
unsigned int : 1;
unsigned int MIP_FILTER : SQ_IMG_SAMP_WORD2_MIP_FILTER_SZ;
unsigned int Z_FILTER : SQ_IMG_SAMP_WORD2_Z_FILTER_SZ;
unsigned int XY_MIN_FILTER : SQ_IMG_SAMP_WORD2_XY_MIN_FILTER_SZ;
unsigned int XY_MAG_FILTER : SQ_IMG_SAMP_WORD2_XY_MAG_FILTER_SZ;
unsigned int LOD_BIAS_SEC : SQ_IMG_SAMP_WORD2_LOD_BIAS_SEC_SZ;
unsigned int LOD_BIAS : SQ_IMG_SAMP_WORD2_LOD_BIAS_SZ;
#endif
};
union SQ_IMG_SAMP_WORD2 {
sq_img_samp_word2_t bitfields, bits, f;
uint32_t val : SQ_IMG_SAMP_WORD2_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
#define SQ_IMG_SAMP_WORD3_REG_SZ 32
#define SQ_IMG_SAMP_WORD3_PERF_MIP_HI_SZ 2
#define SQ_IMG_SAMP_WORD3_BORDER_COLOR_PTR_SZ 12
#define SQ_IMG_SAMP_WORD3_BORD_COLOR_TYPE_SZ 2
struct sq_img_samp_word3_t {
#if defined(LITTLEENDIAN_CPU)
unsigned int PERF_MIP_HI : SQ_IMG_SAMP_WORD3_PERF_MIP_HI_SZ;
unsigned int : 16;
unsigned int BORDER_COLOR_PTR : SQ_IMG_SAMP_WORD3_BORDER_COLOR_PTR_SZ;
unsigned int BORDER_COLOR_TYPE : SQ_IMG_SAMP_WORD3_BORD_COLOR_TYPE_SZ;
#elif defined(BIGENDIAN_CPU)
unsigned int BORDER_COLOR_TYPE : SQ_IMG_SAMP_WORD3_BORD_COLOR_TYPE_SZ;
unsigned int BORDER_COLOR_PTR : SQ_IMG_SAMP_WORD3_BORDER_COLOR_PTR_SZ;
unsigned int : 16;
unsigned int PERF_MIP_HI : SQ_IMG_SAMP_WORD3_PERF_MIP_HI_SZ;
#endif
};
union SQ_IMG_SAMP_WORD3 {
sq_img_samp_word3_t bitfields, bits, f;
uint32_t val : SQ_IMG_SAMP_WORD3_REG_SZ;
uint32_t u32All;
int32_t i32All;
float f32All;
};
/***********/
/**************************************************************/
/**************************************************************/
/**************************************************************/
typedef enum FMT {
FMT_INVALID = 0x00000000,
FMT_8 = 0x00000001,
FMT_16 = 0x00000002,
FMT_8_8 = 0x00000003,
FMT_32 = 0x00000004,
FMT_16_16 = 0x00000005,
FMT_10_11_11 = 0x00000006,
FMT_11_11_10 = 0x00000007,
FMT_10_10_10_2 = 0x00000008,
FMT_2_10_10_10 = 0x00000009,
FMT_8_8_8_8 = 0x0000000a,
FMT_32_32 = 0x0000000b,
FMT_16_16_16_16 = 0x0000000c,
FMT_32_32_32 = 0x0000000d,
FMT_32_32_32_32 = 0x0000000e,
FMT_RESERVED_78 = 0x0000000f,
FMT_5_6_5 = 0x00000010,
FMT_1_5_5_5 = 0x00000011,
FMT_5_5_5_1 = 0x00000012,
FMT_4_4_4_4 = 0x00000013,
FMT_8_24 = 0x00000014,
FMT_24_8 = 0x00000015,
FMT_X24_8_32 = 0x00000016,
FMT_RESERVED_155 = 0x00000017,
} FMT;
typedef enum type {
TYPE_UNORM = 0x00000000,
TYPE_SNORM = 0x00000001,
TYPE_USCALED = 0x00000002,
TYPE_SSCALED = 0x00000003,
TYPE_UINT = 0x00000004,
TYPE_SINT = 0x00000005,
TYPE_SRGB = 0x00000006,
TYPE_FLOAT = 0x00000007,
TYPE_RESERVED_8 = 0x00000008,
TYPE_RESERVED_9 = 0x00000009,
TYPE_UNORM_UINT = 0x0000000a,
TYPE_REVERSED_UNORM = 0x0000000b,
TYPE_FLOAT_CLAMP = 0x0000000c,
} type;
enum FORMAT {
CFMT_INVALID = 0,
CFMT_8_UNORM = 1,
CFMT_8_SNORM = 2,
CFMT_8_USCALED = 3,
CFMT_8_SSCALED = 4,
CFMT_8_UINT = 5,
CFMT_8_SINT = 6,
CFMT_16_UNORM = 7,
CFMT_16_SNORM = 8,
CFMT_16_USCALED = 9,
CFMT_16_SSCALED = 10,
CFMT_16_UINT = 11,
CFMT_16_SINT = 12,
CFMT_16_FLOAT = 13,
CFMT_8_8_UNORM = 14,
CFMT_8_8_SNORM = 15,
CFMT_8_8_USCALED = 16,
CFMT_8_8_SSCALED = 17,
CFMT_8_8_UINT = 18,
CFMT_8_8_SINT = 19,
CFMT_32_UINT = 20,
CFMT_32_SINT = 21,
CFMT_32_FLOAT = 22,
CFMT_16_16_UNORM = 23,
CFMT_16_16_SNORM = 24,
CFMT_16_16_USCALED = 25,
CFMT_16_16_SSCALED = 26,
CFMT_16_16_UINT = 27,
CFMT_16_16_SINT = 28,
CFMT_16_16_FLOAT = 29,
CFMT_10_11_11_FLOAT = 30,
CFMT_11_11_10_FLOAT = 31,
CFMT_10_10_10_2_UNORM = 32,
CFMT_10_10_10_2_SNORM = 33,
CFMT_10_10_10_2_UINT = 34,
CFMT_10_10_10_2_SINT = 35,
CFMT_2_10_10_10_UNORM = 36,
CFMT_2_10_10_10_SNORM = 37,
CFMT_2_10_10_10_USCALED = 38,
CFMT_2_10_10_10_SSCALED = 39,
CFMT_2_10_10_10_UINT = 40,
CFMT_2_10_10_10_SINT = 41,
CFMT_8_8_8_8_UNORM = 42,
CFMT_8_8_8_8_SNORM = 43,
CFMT_8_8_8_8_USCALED = 44,
CFMT_8_8_8_8_SSCALED = 45,
CFMT_8_8_8_8_UINT = 46,
CFMT_8_8_8_8_SINT = 47,
CFMT_32_32_UINT = 48,
CFMT_32_32_SINT = 49,
CFMT_32_32_FLOAT = 50,
CFMT_16_16_16_16_UNORM = 51,
CFMT_16_16_16_16_SNORM = 52,
CFMT_16_16_16_16_USCALED = 53,
CFMT_16_16_16_16_SSCALED = 54,
CFMT_16_16_16_16_UINT = 55,
CFMT_16_16_16_16_SINT = 56,
CFMT_16_16_16_16_FLOAT = 57,
CFMT_32_32_32_UINT = 58,
CFMT_32_32_32_SINT = 59,
CFMT_32_32_32_FLOAT = 60,
CFMT_32_32_32_32_UINT = 61,
CFMT_32_32_32_32_SINT = 62,
CFMT_32_32_32_32_FLOAT = 63,
CFMT_8_SRGB = 64,
CFMT_8_8_SRGB = 65,
CFMT_8_8_8_8_SRGB = 66,
CFMT_5_9_9_9_FLOAT = 67,
CFMT_5_6_5_UNORM = 68,
CFMT_1_5_5_5_UNORM = 69,
CFMT_5_5_5_1_UNORM = 70,
CFMT_4_4_4_4_UNORM = 71,
CFMT_4_4_UNORM = 72,
CFMT_1_UNORM = 73,
CFMT_1_REVERSED_UNORM = 74,
CFMT_32_FLOAT_CLAMP = 75,
CFMT_8_24_UNORM = 76,
CFMT_8_24_UINT = 77,
CFMT_24_8_UNORM = 78,
CFMT_24_8_UINT = 79,
CFMT_X24_8_32_UINT = 80,
CFMT_X24_8_32_FLOAT = 81,
};
typedef enum SEL {
SEL_0 = 0x00000000,
SEL_1 = 0x00000001,
SEL_X = 0x00000004,
SEL_Y = 0x00000005,
SEL_Z = 0x00000006,
SEL_W = 0x00000007,
} SEL;
typedef enum SQ_RSRC_IMG_TYPE {
SQ_RSRC_IMG_1D = 0x00000008,
SQ_RSRC_IMG_2D = 0x00000009,
SQ_RSRC_IMG_3D = 0x0000000a,
SQ_RSRC_IMG_CUBE_ARRAY = 0x0000000b,
SQ_RSRC_IMG_1D_ARRAY = 0x0000000c,
SQ_RSRC_IMG_2D_ARRAY = 0x0000000d,
SQ_RSRC_IMG_2D_MSAA = 0x0000000e,
SQ_RSRC_IMG_2D_MSAA_ARRAY = 0x0000000f,
} SQ_RSRC_IMG_TYPE;
typedef enum SQ_TEX_XY_FILTER {
SQ_TEX_XY_FILTER_POINT = 0x00000000,
SQ_TEX_XY_FILTER_BILINEAR = 0x00000001,
SQ_TEX_XY_FILTER_ANISO_POINT = 0x00000002,
SQ_TEX_XY_FILTER_ANISO_BILINEAR = 0x00000003,
} SQ_TEX_XY_FILTER;
typedef enum SQ_TEX_Z_FILTER {
SQ_TEX_Z_FILTER_NONE = 0x00000000,
SQ_TEX_Z_FILTER_POINT = 0x00000001,
SQ_TEX_Z_FILTER_LINEAR = 0x00000002,
} SQ_TEX_Z_FILTER;
typedef enum SQ_TEX_MIP_FILTER {
SQ_TEX_MIP_FILTER_NONE = 0x00000000,
SQ_TEX_MIP_FILTER_POINT = 0x00000001,
SQ_TEX_MIP_FILTER_LINEAR = 0x00000002,
SQ_TEX_MIP_FILTER_POINT_ANISO_ADJ__VI = 0x00000003,
} SQ_TEX_MIP_FILTER;
typedef enum SQ_TEX_CLAMP {
SQ_TEX_WRAP = 0x00000000,
SQ_TEX_MIRROR = 0x00000001,
SQ_TEX_CLAMP_LAST_TEXEL = 0x00000002,
SQ_TEX_MIRROR_ONCE_LAST_TEXEL = 0x00000003,
SQ_TEX_CLAMP_HALF_BORDER = 0x00000004,
SQ_TEX_MIRROR_ONCE_HALF_BORDER = 0x00000005,
SQ_TEX_CLAMP_BORDER = 0x00000006,
SQ_TEX_MIRROR_ONCE_BORDER = 0x00000007,
} SQ_TEX_CLAMP;
typedef enum SQ_TEX_BORDER_COLOR {
SQ_TEX_BORDER_COLOR_TRANS_BLACK = 0x00000000,
SQ_TEX_BORDER_COLOR_OPAQUE_BLACK = 0x00000001,
SQ_TEX_BORDER_COLOR_OPAQUE_WHITE = 0x00000002,
SQ_TEX_BORDER_COLOR_REGISTER = 0x00000003,
} SQ_TEX_BORDER_COLOR;
typedef enum TEX_BC_SWIZZLE {
TEX_BC_Swizzle_XYZW = 0x00000000,
TEX_BC_Swizzle_XWYZ = 0x00000001,
TEX_BC_Swizzle_WZYX = 0x00000002,
TEX_BC_Swizzle_WXYZ = 0x00000003,
TEX_BC_Swizzle_ZYXW = 0x00000004,
TEX_BC_Swizzle_YXWZ = 0x00000005,
} TEX_BC_SWIZZLE;
typedef struct metadata_amd_gfx12_s {
uint32_t version; // Must be 1
uint32_t vendorID; // AMD
SQ_IMG_RSRC_WORD0 word0;
SQ_IMG_RSRC_WORD1 word1;
SQ_IMG_RSRC_WORD2 word2;
SQ_IMG_RSRC_WORD3 word3;
SQ_IMG_RSRC_WORD4 word4;
SQ_IMG_RSRC_WORD5 word5;
SQ_IMG_RSRC_WORD6 word6;
SQ_IMG_RSRC_WORD7 word7;
uint32_t mip_offsets[0];
} metadata_amd_gfx12_t;
} // namespace image
} // namespace rocr
#endif // EXT_IMAGE_RESOURCE_GFX12_H_