Skip to content

Commit 6c0e3ea

Browse files
committed
drm/msm/gem: Switch over to obj->resv for locking
This also converts the special msm_gem_get_vaddr_active() to expect the lock to already be held. There are two call-sites for this, one already has the lock held, so it is more straightforward to just open-code the locking for the other caller. Signed-off-by: Rob Clark <[email protected]> Reviewed-by: Kristian H. Kristensen <[email protected]> Signed-off-by: Rob Clark <[email protected]>
1 parent 9184b68 commit 6c0e3ea

File tree

5 files changed

+29
-28
lines changed

5 files changed

+29
-28
lines changed

drivers/gpu/drm/msm/msm_gem.c

Lines changed: 7 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -643,13 +643,7 @@ void *msm_gem_get_vaddr(struct drm_gem_object *obj)
643643
*/
644644
void *msm_gem_get_vaddr_active(struct drm_gem_object *obj)
645645
{
646-
void *ret;
647-
648-
msm_gem_lock(obj);
649-
ret = get_vaddr(obj, __MSM_MADV_PURGED);
650-
msm_gem_unlock(obj);
651-
652-
return ret;
646+
return get_vaddr(obj, __MSM_MADV_PURGED);
653647
}
654648

655649
void msm_gem_put_vaddr_locked(struct drm_gem_object *obj)
@@ -969,15 +963,20 @@ static void free_object(struct msm_gem_object *msm_obj)
969963
if (msm_obj->pages)
970964
kvfree(msm_obj->pages);
971965

966+
/* dma_buf_detach() grabs resv lock, so we need to unlock
967+
* prior to drm_prime_gem_destroy
968+
*/
969+
msm_gem_unlock(obj);
970+
972971
drm_prime_gem_destroy(obj, msm_obj->sgt);
973972
} else {
974973
msm_gem_vunmap(obj);
975974
put_pages(obj);
975+
msm_gem_unlock(obj);
976976
}
977977

978978
drm_gem_object_release(obj);
979979

980-
msm_gem_unlock(obj);
981980
kfree(msm_obj);
982981
}
983982

@@ -1049,8 +1048,6 @@ static int msm_gem_new_impl(struct drm_device *dev,
10491048
if (!msm_obj)
10501049
return -ENOMEM;
10511050

1052-
mutex_init(&msm_obj->lock);
1053-
10541051
msm_obj->flags = flags;
10551052
msm_obj->madv = MSM_MADV_WILLNEED;
10561053

drivers/gpu/drm/msm/msm_gem.h

Lines changed: 5 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -85,7 +85,6 @@ struct msm_gem_object {
8585
* an IOMMU. Also used for stolen/splashscreen buffer.
8686
*/
8787
struct drm_mm_node *vram_node;
88-
struct mutex lock; /* Protects resources associated with bo */
8988

9089
char name[32]; /* Identifier to print for the debugfs files */
9190

@@ -158,36 +157,31 @@ void msm_gem_describe_objects(struct list_head *list, struct seq_file *m);
158157
static inline void
159158
msm_gem_lock(struct drm_gem_object *obj)
160159
{
161-
struct msm_gem_object *msm_obj = to_msm_bo(obj);
162-
mutex_lock(&msm_obj->lock);
160+
dma_resv_lock(obj->resv, NULL);
163161
}
164162

165163
static inline bool __must_check
166164
msm_gem_trylock(struct drm_gem_object *obj)
167165
{
168-
struct msm_gem_object *msm_obj = to_msm_bo(obj);
169-
return mutex_trylock(&msm_obj->lock) == 1;
166+
return dma_resv_trylock(obj->resv);
170167
}
171168

172169
static inline int
173170
msm_gem_lock_interruptible(struct drm_gem_object *obj)
174171
{
175-
struct msm_gem_object *msm_obj = to_msm_bo(obj);
176-
return mutex_lock_interruptible(&msm_obj->lock);
172+
return dma_resv_lock_interruptible(obj->resv, NULL);
177173
}
178174

179175
static inline void
180176
msm_gem_unlock(struct drm_gem_object *obj)
181177
{
182-
struct msm_gem_object *msm_obj = to_msm_bo(obj);
183-
mutex_unlock(&msm_obj->lock);
178+
dma_resv_unlock(obj->resv);
184179
}
185180

186181
static inline bool
187182
msm_gem_is_locked(struct drm_gem_object *obj)
188183
{
189-
struct msm_gem_object *msm_obj = to_msm_bo(obj);
190-
return mutex_is_locked(&msm_obj->lock);
184+
return dma_resv_is_locked(obj->resv);
191185
}
192186

193187
static inline bool is_active(struct msm_gem_object *msm_obj)

drivers/gpu/drm/msm/msm_gem_submit.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -221,7 +221,7 @@ static void submit_unlock_unpin_bo(struct msm_gem_submit *submit,
221221
struct msm_gem_object *msm_obj = submit->bos[i].obj;
222222

223223
if (submit->bos[i].flags & BO_PINNED)
224-
msm_gem_unpin_iova(&msm_obj->base, submit->aspace);
224+
msm_gem_unpin_iova_locked(&msm_obj->base, submit->aspace);
225225

226226
if (submit->bos[i].flags & BO_LOCKED)
227227
dma_resv_unlock(msm_obj->base.resv);
@@ -324,7 +324,7 @@ static int submit_pin_objects(struct msm_gem_submit *submit)
324324
uint64_t iova;
325325

326326
/* if locking succeeded, pin bo: */
327-
ret = msm_gem_get_and_pin_iova(&msm_obj->base,
327+
ret = msm_gem_get_and_pin_iova_locked(&msm_obj->base,
328328
submit->aspace, &iova);
329329

330330
if (ret)
@@ -383,7 +383,7 @@ static int submit_reloc(struct msm_gem_submit *submit, struct msm_gem_object *ob
383383
/* For now, just map the entire thing. Eventually we probably
384384
* to do it page-by-page, w/ kmap() if not vmap()d..
385385
*/
386-
ptr = msm_gem_get_vaddr(&obj->base);
386+
ptr = msm_gem_get_vaddr_locked(&obj->base);
387387

388388
if (IS_ERR(ptr)) {
389389
ret = PTR_ERR(ptr);
@@ -434,7 +434,7 @@ static int submit_reloc(struct msm_gem_submit *submit, struct msm_gem_object *ob
434434
}
435435

436436
out:
437-
msm_gem_put_vaddr(&obj->base);
437+
msm_gem_put_vaddr_locked(&obj->base);
438438

439439
return ret;
440440
}

drivers/gpu/drm/msm/msm_gpu.c

Lines changed: 12 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -323,7 +323,9 @@ static void msm_gpu_crashstate_get_bo(struct msm_gpu_state *state,
323323
if (!state_bo->data)
324324
goto out;
325325

326+
msm_gem_lock(&obj->base);
326327
ptr = msm_gem_get_vaddr_active(&obj->base);
328+
msm_gem_unlock(&obj->base);
327329
if (IS_ERR(ptr)) {
328330
kvfree(state_bo->data);
329331
state_bo->data = NULL;
@@ -467,14 +469,22 @@ static void recover_worker(struct kthread_work *work)
467469
put_task_struct(task);
468470
}
469471

472+
/* msm_rd_dump_submit() needs bo locked to dump: */
473+
for (i = 0; i < submit->nr_bos; i++)
474+
msm_gem_lock(&submit->bos[i].obj->base);
475+
470476
if (comm && cmd) {
471477
DRM_DEV_ERROR(dev->dev, "%s: offending task: %s (%s)\n",
472478
gpu->name, comm, cmd);
473479

474480
msm_rd_dump_submit(priv->hangrd, submit,
475481
"offending task: %s (%s)", comm, cmd);
476-
} else
482+
} else {
477483
msm_rd_dump_submit(priv->hangrd, submit, NULL);
484+
}
485+
486+
for (i = 0; i < submit->nr_bos; i++)
487+
msm_gem_unlock(&submit->bos[i].obj->base);
478488
}
479489

480490
/* Record the crash state */
@@ -779,7 +789,7 @@ void msm_gpu_submit(struct msm_gpu *gpu, struct msm_gem_submit *submit)
779789

780790
/* submit takes a reference to the bo and iova until retired: */
781791
drm_gem_object_get(&msm_obj->base);
782-
msm_gem_get_and_pin_iova(&msm_obj->base, submit->aspace, &iova);
792+
msm_gem_get_and_pin_iova_locked(&msm_obj->base, submit->aspace, &iova);
783793

784794
if (submit->bos[i].flags & MSM_SUBMIT_BO_WRITE)
785795
dma_resv_add_excl_fence(drm_obj->resv, submit->fence);

drivers/gpu/drm/msm/msm_rd.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -333,7 +333,7 @@ static void snapshot_buf(struct msm_rd_state *rd,
333333

334334
rd_write_section(rd, RD_BUFFER_CONTENTS, buf, size);
335335

336-
msm_gem_put_vaddr(&obj->base);
336+
msm_gem_put_vaddr_locked(&obj->base);
337337
}
338338

339339
/* called under struct_mutex */

0 commit comments

Comments
 (0)