nvc0: fix retrieving query results into buffer for timestamps

The timestamps are stored in a funny place, and even though they are a
64-bit result, are not stored with is64bit. Account for that when
retrieving the query result into a resource.

Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu>
Cc: "11.2" <mesa-stable@lists.freedesktop.org>
(cherry picked from commit 88ca4a43a2)
This commit is contained in:
Ilia Mirkin 2016-04-22 00:01:56 -04:00 committed by Emil Velikov
parent d2298c2495
commit 69bfd3b543

View file

@ -370,7 +370,7 @@ nvc0_hw_get_query_result_resource(struct nvc0_context *nvc0,
struct nouveau_pushbuf *push = nvc0->base.pushbuf;
struct nvc0_hw_query *hq = nvc0_hw_query(q);
struct nv04_resource *buf = nv04_resource(resource);
unsigned stride;
unsigned qoffset = 0, stride;
assert(!hq->funcs || !hq->funcs->get_query_result);
@ -426,17 +426,27 @@ nvc0_hw_get_query_result_resource(struct nvc0_context *nvc0,
case PIPE_QUERY_PIPELINE_STATISTICS:
stride = 12;
break;
case PIPE_QUERY_TIME_ELAPSED:
case PIPE_QUERY_TIMESTAMP:
qoffset = 8;
/* fallthrough */
default:
assert(index == 0);
stride = 1;
break;
}
if (hq->is64bit) {
nouveau_pushbuf_data(push, hq->bo, hq->offset + 16 * index,
8 | NVC0_IB_ENTRY_1_NO_PREFETCH);
nouveau_pushbuf_data(push, hq->bo, hq->offset + 16 * (index + stride),
if (hq->is64bit || qoffset) {
nouveau_pushbuf_data(push, hq->bo, hq->offset + qoffset + 16 * index,
8 | NVC0_IB_ENTRY_1_NO_PREFETCH);
if (q->type == PIPE_QUERY_TIMESTAMP) {
PUSH_DATA(push, 0);
PUSH_DATA(push, 0);
} else {
nouveau_pushbuf_data(push, hq->bo, hq->offset + qoffset +
16 * (index + stride),
8 | NVC0_IB_ENTRY_1_NO_PREFETCH);
}
} else {
nouveau_pushbuf_data(push, hq->bo, hq->offset + 4,
4 | NVC0_IB_ENTRY_1_NO_PREFETCH);