Skip to content

Commit a3dec9c

Browse files
committed
drm/msm/gem: Remove "valid" tracking
This was a small optimization for pre-soft-pin userspace. But mesa switched to soft-pin nearly 5yrs ago. So lets drop the optimization and simplify the code. Signed-off-by: Rob Clark <robdclark@chromium.org> Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Patchwork: https://patchwork.freedesktop.org/patch/568328/
1 parent 3e6688f commit a3dec9c

File tree

2 files changed

+8
-38
lines changed

2 files changed

+8
-38
lines changed

drivers/gpu/drm/msm/msm_gem.h

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -275,7 +275,6 @@ struct msm_gem_submit {
275275
struct msm_gpu_submitqueue *queue;
276276
struct pid *pid; /* submitting process */
277277
bool fault_dumped; /* Limit devcoredump dumping to one per submit */
278-
bool valid; /* true if no cmdstream patching needed */
279278
bool in_rb; /* "sudo" mode, copy cmds into RB */
280279
struct msm_ringbuffer *ring;
281280
unsigned int nr_cmds;
@@ -292,7 +291,6 @@ struct msm_gem_submit {
292291
} *cmd; /* array of size nr_cmds */
293292
struct {
294293
/* make sure these don't conflict w/ MSM_SUBMIT_BO_x */
295-
#define BO_VALID 0x8000 /* is current addr in cmdstream correct/valid? */
296294
#define BO_LOCKED 0x4000 /* obj lock is held */
297295
#define BO_PINNED 0x2000 /* obj (pages) is pinned and on active list */
298296
uint32_t flags;

drivers/gpu/drm/msm/msm_gem_submit.c

Lines changed: 8 additions & 36 deletions
Original file line numberDiff line numberDiff line change
@@ -150,8 +150,6 @@ static int submit_lookup_objects(struct msm_gem_submit *submit,
150150

151151
submit->bos[i].handle = submit_bo.handle;
152152
submit->bos[i].flags = submit_bo.flags;
153-
/* in validate_objects() we figure out if this is true: */
154-
submit->bos[i].iova = submit_bo.presumed;
155153
}
156154

157155
spin_lock(&file->table_lock);
@@ -278,9 +276,6 @@ static void submit_unlock_unpin_bo(struct msm_gem_submit *submit, int i)
278276
{
279277
unsigned cleanup_flags = BO_PINNED | BO_LOCKED;
280278
submit_cleanup_bo(submit, i, cleanup_flags);
281-
282-
if (!(submit->bos[i].flags & BO_VALID))
283-
submit->bos[i].iova = 0;
284279
}
285280

286281
/* This is where we make sure all the bo's are reserved and pin'd: */
@@ -390,8 +385,6 @@ static int submit_pin_objects(struct msm_gem_submit *submit)
390385
struct msm_drm_private *priv = submit->dev->dev_private;
391386
int i, ret = 0;
392387

393-
submit->valid = true;
394-
395388
for (i = 0; i < submit->nr_bos; i++) {
396389
struct drm_gem_object *obj = submit->bos[i].obj;
397390
struct msm_gem_vma *vma;
@@ -407,14 +400,7 @@ static int submit_pin_objects(struct msm_gem_submit *submit)
407400
if (ret)
408401
break;
409402

410-
if (vma->iova == submit->bos[i].iova) {
411-
submit->bos[i].flags |= BO_VALID;
412-
} else {
413-
submit->bos[i].iova = vma->iova;
414-
/* iova changed, so address in cmdstream is not valid: */
415-
submit->bos[i].flags &= ~BO_VALID;
416-
submit->valid = false;
417-
}
403+
submit->bos[i].iova = vma->iova;
418404
}
419405

420406
/*
@@ -451,7 +437,7 @@ static void submit_attach_object_fences(struct msm_gem_submit *submit)
451437
}
452438

453439
static int submit_bo(struct msm_gem_submit *submit, uint32_t idx,
454-
struct drm_gem_object **obj, uint64_t *iova, bool *valid)
440+
struct drm_gem_object **obj, uint64_t *iova)
455441
{
456442
if (idx >= submit->nr_bos) {
457443
SUBMIT_ERROR(submit, "invalid buffer index: %u (out of %u)\n",
@@ -463,8 +449,6 @@ static int submit_bo(struct msm_gem_submit *submit, uint32_t idx,
463449
*obj = submit->bos[idx].obj;
464450
if (iova)
465451
*iova = submit->bos[idx].iova;
466-
if (valid)
467-
*valid = !!(submit->bos[idx].flags & BO_VALID);
468452

469453
return 0;
470454
}
@@ -477,9 +461,6 @@ static int submit_reloc(struct msm_gem_submit *submit, struct drm_gem_object *ob
477461
uint32_t *ptr;
478462
int ret = 0;
479463

480-
if (!nr_relocs)
481-
return 0;
482-
483464
if (offset % 4) {
484465
SUBMIT_ERROR(submit, "non-aligned cmdstream buffer: %u\n", offset);
485466
return -EINVAL;
@@ -500,7 +481,6 @@ static int submit_reloc(struct msm_gem_submit *submit, struct drm_gem_object *ob
500481
struct drm_msm_gem_submit_reloc submit_reloc = relocs[i];
501482
uint32_t off;
502483
uint64_t iova;
503-
bool valid;
504484

505485
if (submit_reloc.submit_offset % 4) {
506486
SUBMIT_ERROR(submit, "non-aligned reloc offset: %u\n",
@@ -519,13 +499,10 @@ static int submit_reloc(struct msm_gem_submit *submit, struct drm_gem_object *ob
519499
goto out;
520500
}
521501

522-
ret = submit_bo(submit, submit_reloc.reloc_idx, NULL, &iova, &valid);
502+
ret = submit_bo(submit, submit_reloc.reloc_idx, NULL, &iova);
523503
if (ret)
524504
goto out;
525505

526-
if (valid)
527-
continue;
528-
529506
iova += submit_reloc.reloc_offset;
530507

531508
if (submit_reloc.shift < 0)
@@ -879,8 +856,7 @@ int msm_ioctl_gem_submit(struct drm_device *dev, void *data,
879856
struct drm_gem_object *obj;
880857
uint64_t iova;
881858

882-
ret = submit_bo(submit, submit->cmd[i].idx,
883-
&obj, &iova, NULL);
859+
ret = submit_bo(submit, submit->cmd[i].idx, &obj, &iova);
884860
if (ret)
885861
goto out;
886862

@@ -894,17 +870,13 @@ int msm_ioctl_gem_submit(struct drm_device *dev, void *data,
894870

895871
submit->cmd[i].iova = iova + (submit->cmd[i].offset * 4);
896872

897-
if (submit->valid)
873+
if (likely(!submit->cmd[i].nr_relocs))
898874
continue;
899875

900876
if (!gpu->allow_relocs) {
901-
if (submit->cmd[i].nr_relocs) {
902-
SUBMIT_ERROR(submit, "relocs not allowed\n");
903-
ret = -EINVAL;
904-
goto out;
905-
}
906-
907-
continue;
877+
SUBMIT_ERROR(submit, "relocs not allowed\n");
878+
ret = -EINVAL;
879+
goto out;
908880
}
909881

910882
ret = submit_reloc(submit, obj, submit->cmd[i].offset * 4,

0 commit comments

Comments
 (0)