freedreno: some msm-ring reset/flush fixes
authorRob Clark <robclark@freedesktop.org>
Wed, 19 Feb 2014 16:01:23 +0000 (11:01 -0500)
committerRob Clark <robclark@freedesktop.org>
Wed, 19 Feb 2014 16:47:40 +0000 (11:47 -0500)
Need to update timestamp on all ring's associated with a submit (ie.
both the binning pass and main ring).  Also, make sure nr_reloc's
in particular gets cleared if the rb is reset.

Signed-off-by: Rob Clark <robclark@freedesktop.org>
freedreno/freedreno_priv.h
freedreno/freedreno_ringbuffer.c
freedreno/msm/msm_ringbuffer.c

index d5cf9f976495228d4ada7d583094e85202a389cd..74384858a6f56ef783de117f7fe9dd52c676de45 100644 (file)
@@ -114,6 +114,7 @@ struct fd_ringmarker {
 struct fd_ringbuffer_funcs {
        void * (*hostptr)(struct fd_ringbuffer *ring);
        int (*flush)(struct fd_ringbuffer *ring, uint32_t *last_start);
+       void (*reset)(struct fd_ringbuffer *ring);
        void (*emit_reloc)(struct fd_ringbuffer *ring,
                        const struct fd_reloc *reloc);
        void (*emit_reloc_ring)(struct fd_ringbuffer *ring,
index 444379067ea81bc27e0e76f3c6841fc5223a79dc..b9849c5f507f10af0c536f5e8ccb0838ba14381f 100644 (file)
@@ -72,6 +72,8 @@ void fd_ringbuffer_reset(struct fd_ringbuffer *ring)
        if (ring->pipe->id == FD_PIPE_2D)
                start = &ring->start[0x140];
        ring->cur = ring->last_start = start;
+       if (ring->funcs->reset)
+               ring->funcs->reset(ring);
 }
 
 /* maybe get rid of this and use fd_ringmarker_flush() from DDX too? */
index f3e951f9076e948fb82422f958bce0b45bc51903..c9c92561734eff69d17b8b348db4842d21c68c36 100644 (file)
@@ -169,6 +169,22 @@ static uint32_t find_next_reloc_idx(struct msm_ringbuffer *msm_ring,
        return i;
 }
 
+static void flush_reset(struct fd_ringbuffer *ring)
+{
+       struct msm_ringbuffer *msm_ring = to_msm_ringbuffer(ring);
+       unsigned i;
+
+       /* for each of the cmd buffers, clear their reloc's: */
+       for (i = 0; i < msm_ring->nr_cmds; i++) {
+               struct msm_ringbuffer *target_ring = to_msm_ringbuffer(msm_ring->rings[i]);
+               target_ring->nr_relocs = 0;
+       }
+
+       msm_ring->nr_relocs = 0;
+       msm_ring->nr_cmds = 0;
+       msm_ring->nr_bos = 0;
+}
+
 static int msm_ringbuffer_flush(struct fd_ringbuffer *ring, uint32_t *last_start)
 {
        struct msm_ringbuffer *msm_ring = to_msm_ringbuffer(ring);
@@ -205,8 +221,16 @@ static int msm_ringbuffer_flush(struct fd_ringbuffer *ring, uint32_t *last_start
 
        ret = drmCommandWriteRead(ring->pipe->dev->fd, DRM_MSM_GEM_SUBMIT,
                        &req, sizeof(req));
-       if (ret)
+       if (ret) {
                ERROR_MSG("submit failed: %d (%s)", ret, strerror(errno));
+       } else {
+               /* update timestamp on all rings associated with submit: */
+               for (i = 0; i < msm_ring->nr_cmds; i++) {
+                       struct fd_ringbuffer *target_ring = msm_ring->rings[i];
+                       if (!ret)
+                               target_ring->last_timestamp = req.fence;
+               }
+       }
 
        LIST_FOR_EACH_ENTRY_SAFE(msm_bo, tmp, &msm_ring->submit_list, list[id]) {
                struct list_head *list = &msm_bo->list[id];
@@ -215,18 +239,16 @@ static int msm_ringbuffer_flush(struct fd_ringbuffer *ring, uint32_t *last_start
                fd_bo_del(&msm_bo->base);
        }
 
-       /* for each of the cmd buffers, clear their reloc's: */
-       for (i = 0; i < msm_ring->nr_cmds; i++) {
-               struct msm_ringbuffer *target_ring = to_msm_ringbuffer(msm_ring->rings[i]);
-               target_ring->nr_relocs = 0;
-       }
-
-       msm_ring->nr_cmds = 0;
-       msm_ring->nr_bos = 0;
+       flush_reset(ring);
 
        return ret;
 }
 
+static void msm_ringbuffer_reset(struct fd_ringbuffer *ring)
+{
+       flush_reset(ring);
+}
+
 static void msm_ringbuffer_emit_reloc(struct fd_ringbuffer *ring,
                const struct fd_reloc *r)
 {
@@ -285,6 +307,7 @@ static void msm_ringbuffer_destroy(struct fd_ringbuffer *ring)
 static struct fd_ringbuffer_funcs funcs = {
                .hostptr = msm_ringbuffer_hostptr,
                .flush = msm_ringbuffer_flush,
+               .reset = msm_ringbuffer_reset,
                .emit_reloc = msm_ringbuffer_emit_reloc,
                .emit_reloc_ring = msm_ringbuffer_emit_reloc_ring,
                .destroy = msm_ringbuffer_destroy,