summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrancisco Jerez <[email protected]>2016-07-19 11:52:23 -0700
committerFrancisco Jerez <[email protected]>2016-08-25 18:36:08 -0700
commit71d639f69ee868fbeadd0a1b8bbdd76e17398b43 (patch)
tree0ba0a9a2d859b428a75385f9ee4211b1894ff8a5
parent26ac16fe2f73507041062f63646286dea60053da (diff)
i965/disasm: Fix RC message type strings on Gen7+.
Reviewed-by: Kenneth Graunke <[email protected]>
-rw-r--r--src/mesa/drivers/dri/i965/brw_disasm.c28
1 files changed, 25 insertions, 3 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_disasm.c b/src/mesa/drivers/dri/i965/brw_disasm.c
index d74d5d575f6..cca4c8ba8b9 100644
--- a/src/mesa/drivers/dri/i965/brw_disasm.c
+++ b/src/mesa/drivers/dri/i965/brw_disasm.c
@@ -388,6 +388,30 @@ static const char *const dp_rc_msg_type_gen6[16] = {
[GEN6_DATAPORT_WRITE_MESSAGE_RENDER_TARGET_UNORM_WRITE] = "RT UNORM write",
};
+static const char *const dp_rc_msg_type_gen7[16] = {
+ [GEN7_DATAPORT_RC_MEDIA_BLOCK_READ] = "media block read",
+ [GEN7_DATAPORT_RC_TYPED_SURFACE_READ] = "typed surface read",
+ [GEN7_DATAPORT_RC_TYPED_ATOMIC_OP] = "typed atomic op",
+ [GEN7_DATAPORT_RC_MEMORY_FENCE] = "memory fence",
+ [GEN7_DATAPORT_RC_MEDIA_BLOCK_WRITE] = "media block write",
+ [GEN7_DATAPORT_RC_RENDER_TARGET_WRITE] = "RT write",
+ [GEN7_DATAPORT_RC_TYPED_SURFACE_WRITE] = "typed surface write"
+};
+
+static const char *const dp_rc_msg_type_gen9[16] = {
+ [GEN9_DATAPORT_RC_RENDER_TARGET_WRITE] = "RT write",
+ [GEN9_DATAPORT_RC_RENDER_TARGET_READ] = "RT read"
+};
+
+static const char *const *
+dp_rc_msg_type(const struct brw_device_info *devinfo)
+{
+ return (devinfo->gen >= 9 ? dp_rc_msg_type_gen9 :
+ devinfo->gen >= 7 ? dp_rc_msg_type_gen7 :
+ devinfo->gen >= 6 ? dp_rc_msg_type_gen6 :
+ dp_write_port_msg_type);
+}
+
static const char *const m_rt_write_subtype[] = {
[0b000] = "SIMD16",
[0b001] = "SIMD16/RepData",
@@ -1413,9 +1437,7 @@ brw_disassemble_inst(FILE *file, const struct brw_device_info *devinfo,
unsigned msg_type = brw_inst_dp_write_msg_type(devinfo, inst);
err |= control(file, "DP rc message type",
- devinfo->gen >= 6 ? dp_rc_msg_type_gen6
- : dp_write_port_msg_type,
- msg_type, &space);
+ dp_rc_msg_type(devinfo), msg_type, &space);
bool is_rt_write = msg_type ==
(devinfo->gen >= 6 ? GEN6_DATAPORT_WRITE_MESSAGE_RENDER_TARGET_WRITE