Commit 2a79c034 authored by Mikko Perttunen's avatar Mikko Perttunen Committed by Thierry Reding

gpu: host1x: Disassemble more instructions

The disassembler for debug dumps was missing some newer host1x opcodes.
Add disassembly support for these.
Signed-off-by: default avatarMikko Perttunen <mperttunen@nvidia.com>
Reviewed-by: default avatarDmitry Osipenko <digetx@gmail.com>
Tested-by: default avatarDmitry Osipenko <digetx@gmail.com>
Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
parent eb2ee1a2
...@@ -30,6 +30,13 @@ enum { ...@@ -30,6 +30,13 @@ enum {
HOST1X_OPCODE_IMM = 0x04, HOST1X_OPCODE_IMM = 0x04,
HOST1X_OPCODE_RESTART = 0x05, HOST1X_OPCODE_RESTART = 0x05,
HOST1X_OPCODE_GATHER = 0x06, HOST1X_OPCODE_GATHER = 0x06,
HOST1X_OPCODE_SETSTRMID = 0x07,
HOST1X_OPCODE_SETAPPID = 0x08,
HOST1X_OPCODE_SETPYLD = 0x09,
HOST1X_OPCODE_INCR_W = 0x0a,
HOST1X_OPCODE_NONINCR_W = 0x0b,
HOST1X_OPCODE_GATHER_W = 0x0c,
HOST1X_OPCODE_RESTART_W = 0x0d,
HOST1X_OPCODE_EXTEND = 0x0e, HOST1X_OPCODE_EXTEND = 0x0e,
}; };
...@@ -38,11 +45,16 @@ enum { ...@@ -38,11 +45,16 @@ enum {
HOST1X_OPCODE_EXTEND_RELEASE_MLOCK = 0x01, HOST1X_OPCODE_EXTEND_RELEASE_MLOCK = 0x01,
}; };
static unsigned int show_channel_command(struct output *o, u32 val) #define INVALID_PAYLOAD 0xffffffff
static unsigned int show_channel_command(struct output *o, u32 val,
u32 *payload)
{ {
unsigned int mask, subop, num; unsigned int mask, subop, num, opcode;
opcode = val >> 28;
switch (val >> 28) { switch (opcode) {
case HOST1X_OPCODE_SETCLASS: case HOST1X_OPCODE_SETCLASS:
mask = val & 0x3f; mask = val & 0x3f;
if (mask) { if (mask) {
...@@ -97,6 +109,44 @@ static unsigned int show_channel_command(struct output *o, u32 val) ...@@ -97,6 +109,44 @@ static unsigned int show_channel_command(struct output *o, u32 val)
val >> 14 & 0x1, val & 0x3fff); val >> 14 & 0x1, val & 0x3fff);
return 1; return 1;
#if HOST1X_HW >= 6
case HOST1X_OPCODE_SETSTRMID:
host1x_debug_cont(o, "SETSTRMID(offset=%06x)\n",
val & 0x3fffff);
return 0;
case HOST1X_OPCODE_SETAPPID:
host1x_debug_cont(o, "SETAPPID(appid=%02x)\n", val & 0xff);
return 0;
case HOST1X_OPCODE_SETPYLD:
*payload = val & 0xffff;
host1x_debug_cont(o, "SETPYLD(data=%04x)\n", *payload);
return 0;
case HOST1X_OPCODE_INCR_W:
case HOST1X_OPCODE_NONINCR_W:
host1x_debug_cont(o, "%s(offset=%06x, ",
opcode == HOST1X_OPCODE_INCR_W ?
"INCR_W" : "NONINCR_W",
val & 0x3fffff);
if (*payload == 0) {
host1x_debug_cont(o, "[])\n");
return 0;
} else if (*payload == INVALID_PAYLOAD) {
host1x_debug_cont(o, "unknown)\n");
return 0;
} else {
host1x_debug_cont(o, "[");
return *payload;
}
case HOST1X_OPCODE_GATHER_W:
host1x_debug_cont(o, "GATHER_W(count=%04x, addr=[",
val & 0x3fff);
return 2;
#endif
case HOST1X_OPCODE_EXTEND: case HOST1X_OPCODE_EXTEND:
subop = val >> 24 & 0xf; subop = val >> 24 & 0xf;
if (subop == HOST1X_OPCODE_EXTEND_ACQUIRE_MLOCK) if (subop == HOST1X_OPCODE_EXTEND_ACQUIRE_MLOCK)
...@@ -122,6 +172,7 @@ static void show_gather(struct output *o, phys_addr_t phys_addr, ...@@ -122,6 +172,7 @@ static void show_gather(struct output *o, phys_addr_t phys_addr,
/* Map dmaget cursor to corresponding mem handle */ /* Map dmaget cursor to corresponding mem handle */
u32 offset = phys_addr - pin_addr; u32 offset = phys_addr - pin_addr;
unsigned int data_count = 0, i; unsigned int data_count = 0, i;
u32 payload = INVALID_PAYLOAD;
/* /*
* Sometimes we're given different hardware address to the same * Sometimes we're given different hardware address to the same
...@@ -139,7 +190,7 @@ static void show_gather(struct output *o, phys_addr_t phys_addr, ...@@ -139,7 +190,7 @@ static void show_gather(struct output *o, phys_addr_t phys_addr,
if (!data_count) { if (!data_count) {
host1x_debug_output(o, "%08x: %08x: ", addr, val); host1x_debug_output(o, "%08x: %08x: ", addr, val);
data_count = show_channel_command(o, val); data_count = show_channel_command(o, val, &payload);
} else { } else {
host1x_debug_cont(o, "%08x%s", val, host1x_debug_cont(o, "%08x%s", val,
data_count > 1 ? ", " : "])\n"); data_count > 1 ? ", " : "])\n");
......
...@@ -112,7 +112,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host, ...@@ -112,7 +112,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host,
if (!data_count) { if (!data_count) {
host1x_debug_output(o, "%08x: ", val); host1x_debug_output(o, "%08x: ", val);
data_count = show_channel_command(o, val); data_count = show_channel_command(o, val, NULL);
} else { } else {
host1x_debug_cont(o, "%08x%s", val, host1x_debug_cont(o, "%08x%s", val,
data_count > 1 ? ", " : "])\n"); data_count > 1 ? ", " : "])\n");
......
...@@ -63,6 +63,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host, ...@@ -63,6 +63,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host,
struct output *o) struct output *o)
{ {
u32 val, rd_ptr, wr_ptr, start, end; u32 val, rd_ptr, wr_ptr, start, end;
u32 payload = INVALID_PAYLOAD;
unsigned int data_count = 0; unsigned int data_count = 0;
host1x_debug_output(o, "%u: fifo:\n", ch->id); host1x_debug_output(o, "%u: fifo:\n", ch->id);
...@@ -107,7 +108,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host, ...@@ -107,7 +108,7 @@ static void host1x_debug_show_channel_fifo(struct host1x *host,
if (!data_count) { if (!data_count) {
host1x_debug_output(o, "%03x 0x%08x: ", host1x_debug_output(o, "%03x 0x%08x: ",
rd_ptr - start, val); rd_ptr - start, val);
data_count = show_channel_command(o, val); data_count = show_channel_command(o, val, &payload);
} else { } else {
host1x_debug_cont(o, "%08x%s", val, host1x_debug_cont(o, "%08x%s", val,
data_count > 1 ? ", " : "])\n"); data_count > 1 ? ", " : "])\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment