drm/msm/rd: split out snapshot_buf helper
authorRob Clark <robdclark@gmail.com>
Thu, 16 Jun 2016 15:49:09 +0000 (11:49 -0400)
committerRob Clark <robdclark@gmail.com>
Sat, 16 Jul 2016 14:09:09 +0000 (10:09 -0400)
(reduce the noise in next patch)

Signed-off-by: Rob Clark <robdclark@gmail.com>
drivers/gpu/drm/msm/msm_rd.c

index 3eeb8af0c855c2bda76bd3333b90a2a7b6b122ef..fa02b5a50f3154fac257d00cc5502b5619d2f23c 100644 (file)
@@ -277,6 +277,26 @@ void msm_rd_debugfs_cleanup(struct drm_minor *minor)
        kfree(rd);
 }
 
+static void snapshot_buf(struct msm_rd_state *rd,
+               struct msm_gem_submit *submit, int idx,
+               uint32_t iova, uint32_t size)
+{
+       struct msm_gem_object *obj = submit->bos[idx].obj;
+       const char *buf;
+
+       buf = msm_gem_get_vaddr_locked(&obj->base);
+       if (IS_ERR(buf))
+               return;
+
+       buf += iova - submit->bos[idx].iova;
+
+       rd_write_section(rd, RD_GPUADDR,
+                       (uint32_t[2]){ iova, size }, 8);
+       rd_write_section(rd, RD_BUFFER_CONTENTS, buf, size);
+
+       msm_gem_put_vaddr_locked(&obj->base);
+}
+
 /* called under struct_mutex */
 void msm_rd_dump_submit(struct msm_gem_submit *submit)
 {
@@ -306,21 +326,11 @@ void msm_rd_dump_submit(struct msm_gem_submit *submit)
         */
 
        for (i = 0; i < submit->nr_cmds; i++) {
-               uint32_t idx  = submit->cmd[i].idx;
                uint32_t iova = submit->cmd[i].iova;
                uint32_t szd  = submit->cmd[i].size; /* in dwords */
-               struct msm_gem_object *obj = submit->bos[idx].obj;
-               const char *buf = msm_gem_get_vaddr_locked(&obj->base);
-
-               if (IS_ERR(buf))
-                       continue;
 
-               buf += iova - submit->bos[idx].iova;
-
-               rd_write_section(rd, RD_GPUADDR,
-                               (uint32_t[2]){ iova, szd * 4 }, 8);
-               rd_write_section(rd, RD_BUFFER_CONTENTS,
-                               buf, szd * 4);
+               snapshot_buf(rd, submit, submit->cmd[i].idx,
+                               submit->cmd[i].iova, szd * 4);
 
                switch (submit->cmd[i].type) {
                case MSM_SUBMIT_CMD_IB_TARGET_BUF:
@@ -335,8 +345,6 @@ void msm_rd_dump_submit(struct msm_gem_submit *submit)
                                        (uint32_t[2]){ iova, szd }, 8);
                        break;
                }
-
-               msm_gem_put_vaddr_locked(&obj->base);
        }
 }
 #endif