1 /* 2 * Copyright 2013 Advanced Micro Devices, Inc. 3 * Authors: Marek Olšák <[email protected]> 4 * SPDX-License-Identifier: MIT 5 */ 6 7 #ifndef R600D_COMMON_H 8 #define R600D_COMMON_H 9 10 #define R600_CONFIG_REG_OFFSET 0x08000 11 #define R600_CONTEXT_REG_OFFSET 0x28000 12 #define SI_SH_REG_OFFSET 0x0000B000 13 #define SI_SH_REG_END 0x0000C000 14 #define CIK_UCONFIG_REG_OFFSET 0x00030000 15 #define CIK_UCONFIG_REG_END 0x00038000 16 17 #define PKT_TYPE_S(x) (((unsigned)(x) & 0x3) << 30) 18 #define PKT_COUNT_S(x) (((unsigned)(x) & 0x3FFF) << 16) 19 #define PKT3_IT_OPCODE_S(x) (((unsigned)(x) & 0xFF) << 8) 20 #define PKT3_PREDICATE(x) (((x) >> 0) & 0x1) 21 #define PKT3(op, count, predicate) (PKT_TYPE_S(3) | PKT_COUNT_S(count) | PKT3_IT_OPCODE_S(op) | PKT3_PREDICATE(predicate)) 22 23 #define PKT3_NOP 0x10 24 #define PKT3_SET_PREDICATION 0x20 25 #define PKT3_STRMOUT_BUFFER_UPDATE 0x34 26 #define STRMOUT_STORE_BUFFER_FILLED_SIZE 1 27 #define STRMOUT_OFFSET_SOURCE(x) (((unsigned)(x) & 0x3) << 1) 28 #define STRMOUT_OFFSET_FROM_PACKET 0 29 #define STRMOUT_OFFSET_FROM_VGT_FILLED_SIZE 1 30 #define STRMOUT_OFFSET_FROM_MEM 2 31 #define STRMOUT_OFFSET_NONE 3 32 #define STRMOUT_SELECT_BUFFER(x) (((unsigned)(x) & 0x3) << 8) 33 #define PKT3_WAIT_REG_MEM 0x3C 34 #define WAIT_REG_MEM_EQUAL 3 35 #define WAIT_REG_MEM_GEQUAL 5 36 #define WAIT_REG_MEM_MEMORY (1 << 4) 37 #define WAIT_REG_MEM_MEM_SPACE(x) (((unsigned)(x) & 0x3) << 4) 38 #define PKT3_COPY_DATA 0x40 39 #define COPY_DATA_SRC_SEL(x) ((x) & 0xf) 40 #define COPY_DATA_REG 0 41 #define COPY_DATA_MEM 1 42 #define COPY_DATA_PERF 4 43 #define COPY_DATA_IMM 5 44 #define COPY_DATA_TIMESTAMP 9 45 #define COPY_DATA_DST_SEL(x) (((unsigned)(x) & 0xf) << 8) 46 #define COPY_DATA_MEM_ASYNC 5 47 #define COPY_DATA_COUNT_SEL (1 << 16) 48 #define COPY_DATA_WR_CONFIRM (1 << 20) 49 #define PKT3_EVENT_WRITE 0x46 50 #define PKT3_EVENT_WRITE_EOP 0x47 51 #define EOP_INT_SEL(x) ((x) << 24) 52 #define EOP_INT_SEL_NONE 0 53 #define EOP_INT_SEL_SEND_DATA_AFTER_WR_CONFIRM 3 54 #define EOP_DATA_SEL(x) ((x) << 29) 55 #define EOP_DATA_SEL_DISCARD 0 56 #define EOP_DATA_SEL_VALUE_32BIT 1 57 #define EOP_DATA_SEL_VALUE_64BIT 2 58 #define EOP_DATA_SEL_TIMESTAMP 3 59 #define PKT3_RELEASE_MEM 0x49 /* GFX9+ */ 60 #define PKT3_SET_CONFIG_REG 0x68 61 #define PKT3_SET_CONTEXT_REG 0x69 62 #define PKT3_STRMOUT_BASE_UPDATE 0x72 /* r700 only */ 63 #define PKT3_SURFACE_BASE_UPDATE 0x73 /* r600 only */ 64 #define SURFACE_BASE_UPDATE_DEPTH (1 << 0) 65 #define SURFACE_BASE_UPDATE_COLOR(x) (2 << (x)) 66 #define SURFACE_BASE_UPDATE_COLOR_NUM(x) (((1 << x) - 1) << 1) 67 #define SURFACE_BASE_UPDATE_STRMOUT(x) (0x200 << (x)) 68 #define PKT3_SET_SH_REG 0x76 /* SI and later */ 69 #define PKT3_SET_UCONFIG_REG 0x79 /* GFX7 and later */ 70 71 #define EVENT_TYPE_SAMPLE_STREAMOUTSTATS1 0x1 /* EG and later */ 72 #define EVENT_TYPE_SAMPLE_STREAMOUTSTATS2 0x2 /* EG and later */ 73 #define EVENT_TYPE_SAMPLE_STREAMOUTSTATS3 0x3 /* EG and later */ 74 #define EVENT_TYPE_PS_PARTIAL_FLUSH 0x10 75 #define EVENT_TYPE_CACHE_FLUSH_AND_INV_TS_EVENT 0x14 76 #define EVENT_TYPE_ZPASS_DONE 0x15 77 #define EVENT_TYPE_CACHE_FLUSH_AND_INV_EVENT 0x16 78 #define EVENT_TYPE_PERFCOUNTER_START 0x17 79 #define EVENT_TYPE_PERFCOUNTER_STOP 0x18 80 #define EVENT_TYPE_PIPELINESTAT_START 25 81 #define EVENT_TYPE_PIPELINESTAT_STOP 26 82 #define EVENT_TYPE_PERFCOUNTER_SAMPLE 0x1B 83 #define EVENT_TYPE_SAMPLE_PIPELINESTAT 30 84 #define EVENT_TYPE_SO_VGTSTREAMOUT_FLUSH 0x1f 85 #define EVENT_TYPE_SAMPLE_STREAMOUTSTATS 0x20 86 #define EVENT_TYPE_BOTTOM_OF_PIPE_TS 40 87 #define EVENT_TYPE_FLUSH_AND_INV_DB_META 0x2c /* supported on r700+ */ 88 #define EVENT_TYPE_FLUSH_AND_INV_CB_META 46 /* supported on r700+ */ 89 #define EVENT_TYPE(x) ((x) << 0) 90 #define EVENT_INDEX(x) ((x) << 8) 91 /* 0 - any non-TS event 92 * 1 - ZPASS_DONE 93 * 2 - SAMPLE_PIPELINESTAT 94 * 3 - SAMPLE_STREAMOUTSTAT* 95 * 4 - *S_PARTIAL_FLUSH 96 * 5 - TS events 97 */ 98 99 #define PREDICATION_OP_CLEAR 0x0 100 #define PREDICATION_OP_ZPASS 0x1 101 #define PREDICATION_OP_PRIMCOUNT 0x2 102 #define PREDICATION_OP_BOOL64 0x3 103 #define PRED_OP(x) ((x) << 16) 104 #define PREDICATION_CONTINUE (1 << 31) 105 #define PREDICATION_HINT_WAIT (0 << 12) 106 #define PREDICATION_HINT_NOWAIT_DRAW (1 << 12) 107 #define PREDICATION_DRAW_NOT_VISIBLE (0 << 8) 108 #define PREDICATION_DRAW_VISIBLE (1 << 8) 109 110 #define V_0280A0_SWAP_STD 0x00000000 111 #define V_0280A0_SWAP_ALT 0x00000001 112 #define V_0280A0_SWAP_STD_REV 0x00000002 113 #define V_0280A0_SWAP_ALT_REV 0x00000003 114 115 #define EG_S_028C70_FAST_CLEAR(x) (((unsigned)(x) & 0x1) << 17) 116 #define SI_S_028C70_FAST_CLEAR(x) (((unsigned)(x) & 0x1) << 13) 117 118 #define R600_MAX_ALU_CONST_BUFFERS 16 119 120 #endif 121