diff options
Diffstat (limited to 'lib/Target/R600/SIDefines.h')
-rw-r--r-- | lib/Target/R600/SIDefines.h | 41 |
1 files changed, 37 insertions, 4 deletions
diff --git a/lib/Target/R600/SIDefines.h b/lib/Target/R600/SIDefines.h index 4d31a11..2e7dab6 100644 --- a/lib/Target/R600/SIDefines.h +++ b/lib/Target/R600/SIDefines.h @@ -8,10 +8,11 @@ /// \file //===----------------------------------------------------------------------===// -#ifndef SIDEFINES_H_ -#define SIDEFINES_H_ +#ifndef LLVM_LIB_TARGET_R600_SIDEFINES_H +#define LLVM_LIB_TARGET_R600_SIDEFINES_H namespace SIInstrFlags { +// This needs to be kept in sync with the field bits in InstSI. enum { MIMG = 1 << 3, SMRD = 1 << 4, @@ -19,10 +20,38 @@ enum { VOP2 = 1 << 6, VOP3 = 1 << 7, VOPC = 1 << 8, - SALU = 1 << 9 + SALU = 1 << 9, + MUBUF = 1 << 10, + MTBUF = 1 << 11, + FLAT = 1 << 12 }; } +namespace SIInstrFlags { + enum Flags { + // First 4 bits are the instruction encoding + VM_CNT = 1 << 0, + EXP_CNT = 1 << 1, + LGKM_CNT = 1 << 2 + }; +} + +namespace SISrcMods { + enum { + NEG = 1 << 0, + ABS = 1 << 1 + }; +} + +namespace SIOutMods { + enum { + NONE = 0, + MUL2 = 1, + MUL4 = 2, + DIV2 = 3 + }; +} + #define R_00B028_SPI_SHADER_PGM_RSRC1_PS 0x00B028 #define R_00B02C_SPI_SHADER_PGM_RSRC2_PS 0x00B02C #define S_00B02C_EXTRA_LDS_SIZE(x) (((x) & 0xFF) << 8) @@ -32,6 +61,7 @@ enum { #define S_00B028_VGPRS(x) (((x) & 0x3F) << 0) #define S_00B028_SGPRS(x) (((x) & 0x0F) << 6) #define R_00B84C_COMPUTE_PGM_RSRC2 0x00B84C +#define S_00B02C_SCRATCH_EN(x) (((x) & 0x1) << 0) #define S_00B84C_LDS_SIZE(x) (((x) & 0x1FF) << 15) #define R_0286CC_SPI_PS_INPUT_ENA 0x0286CC @@ -85,4 +115,7 @@ enum { #define FP_DENORM_MODE_SP(x) (((x) & 0x3) << 4) #define FP_DENORM_MODE_DP(x) (((x) & 0x3) << 6) -#endif // SIDEFINES_H_ +#define R_00B860_COMPUTE_TMPRING_SIZE 0x00B860 +#define S_00B860_WAVESIZE(x) (((x) & 0x1FFF) << 12) + +#endif |