Instead of passing its constituent elements, pass the whole struct to
simplify the function prototype.

Reviewed-by: Steven Price <[email protected]>
Reviewed-by: Boris Brezillon <[email protected]>
Signed-off-by: Adrián Larumbe <[email protected]>
---
 drivers/gpu/drm/panthor/panthor_mmu.c | 27 ++++++++++++++-------------
 1 file changed, 14 insertions(+), 13 deletions(-)

diff --git a/drivers/gpu/drm/panthor/panthor_mmu.c 
b/drivers/gpu/drm/panthor/panthor_mmu.c
index 46fadb487679..f1afe4a3e296 100644
--- a/drivers/gpu/drm/panthor/panthor_mmu.c
+++ b/drivers/gpu/drm/panthor/panthor_mmu.c
@@ -1282,9 +1282,7 @@ static int panthor_vm_op_ctx_prealloc_pts(struct 
panthor_vm_op_ctx *op_ctx)
 static int panthor_vm_prepare_map_op_ctx(struct panthor_vm_op_ctx *op_ctx,
                                         struct panthor_vm *vm,
                                         struct panthor_gem_object *bo,
-                                        u64 offset,
-                                        u64 size, u64 va,
-                                        u32 flags)
+                                        const struct drm_panthor_vm_bind_op 
*op)
 {
        struct drm_gpuvm_bo *preallocated_vm_bo;
        struct sg_table *sgt = NULL;
@@ -1293,12 +1291,12 @@ static int panthor_vm_prepare_map_op_ctx(struct 
panthor_vm_op_ctx *op_ctx,
        if (!bo)
                return -EINVAL;
 
-       if ((flags & ~PANTHOR_VM_BIND_OP_MAP_FLAGS) ||
-           (flags & DRM_PANTHOR_VM_BIND_OP_TYPE_MASK) != 
DRM_PANTHOR_VM_BIND_OP_TYPE_MAP)
+       if ((op->flags & ~PANTHOR_VM_BIND_OP_MAP_FLAGS) ||
+           (op->flags & DRM_PANTHOR_VM_BIND_OP_TYPE_MASK) != 
DRM_PANTHOR_VM_BIND_OP_TYPE_MAP)
                return -EINVAL;
 
        /* Make sure the VA and size are in-bounds. */
-       if (size > bo->base.size || offset > bo->base.size - size)
+       if (op->size > bo->base.size || op->bo_offset > bo->base.size - 
op->size)
                return -EINVAL;
 
        /* If the BO has an exclusive VM attached, it can't be mapped to other 
VMs. */
@@ -1306,7 +1304,7 @@ static int panthor_vm_prepare_map_op_ctx(struct 
panthor_vm_op_ctx *op_ctx,
            bo->exclusive_vm_root_gem != panthor_vm_root_gem(vm))
                return -EINVAL;
 
-       panthor_vm_init_op_ctx(op_ctx, size, va, flags);
+       panthor_vm_init_op_ctx(op_ctx, op->size, op->va, op->flags);
 
        ret = panthor_vm_op_ctx_prealloc_vmas(op_ctx);
        if (ret)
@@ -1335,7 +1333,7 @@ static int panthor_vm_prepare_map_op_ctx(struct 
panthor_vm_op_ctx *op_ctx,
        }
 
        op_ctx->map.vm_bo = drm_gpuvm_bo_obtain_prealloc(preallocated_vm_bo);
-       op_ctx->map.bo_offset = offset;
+       op_ctx->map.bo_offset = op->bo_offset;
 
        ret = panthor_vm_op_ctx_prealloc_pts(op_ctx);
        if (ret)
@@ -2862,10 +2860,7 @@ panthor_vm_bind_prepare_op_ctx(struct drm_file *file,
                gem = drm_gem_object_lookup(file, op->bo_handle);
                ret = panthor_vm_prepare_map_op_ctx(op_ctx, vm,
                                                    gem ? to_panthor_bo(gem) : 
NULL,
-                                                   op->bo_offset,
-                                                   op->size,
-                                                   op->va,
-                                                   op->flags);
+                                                   op);
                drm_gem_object_put(gem);
                return ret;
 
@@ -3061,10 +3056,16 @@ int panthor_vm_bind_exec_sync_op(struct drm_file *file,
 int panthor_vm_map_bo_range(struct panthor_vm *vm, struct panthor_gem_object 
*bo,
                            u64 offset, u64 size, u64 va, u32 flags)
 {
+       struct drm_panthor_vm_bind_op op = {
+               .bo_offset = offset,
+               .size = size,
+               .va = va,
+               .flags = flags,
+       };
        struct panthor_vm_op_ctx op_ctx;
        int ret;
 
-       ret = panthor_vm_prepare_map_op_ctx(&op_ctx, vm, bo, offset, size, va, 
flags);
+       ret = panthor_vm_prepare_map_op_ctx(&op_ctx, vm, bo, &op);
        if (ret)
                return ret;
 
-- 
2.53.0

Reply via email to