[PATCH v2] tests/intel/xe_vm: Check negative cases for vm_create/destroy ioctl

Zbigniew Kempczyński zbigniew.kempczynski at intel.com
Tue Dec 17 09:50:03 UTC 2024


On Sat, Dec 14, 2024 at 12:27:35AM +0530, Pravalika Gurram wrote:
> Negative test to check vm_create/destroy ioctl returns expected error when
> invalid flags, extensions, reserved, pad, vm_id  param is used.
> 
> Signed-off-by: Pravalika Gurram <pravalika.gurram at intel.com>
> ---
>  tests/intel/xe_vm.c | 131 ++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 131 insertions(+)
> 
> diff --git a/tests/intel/xe_vm.c b/tests/intel/xe_vm.c
> index e78ddd0e5..3535d48c7 100644
> --- a/tests/intel/xe_vm.c
> +++ b/tests/intel/xe_vm.c
> @@ -2242,6 +2242,102 @@ static void bind_flag_invalid(int fd)
>  	xe_vm_destroy(fd, vm);
>  }
>  
> +/**
> + * TEST: Negative test for vm create/destroy ioctl
> + * Category: Core
> + * Mega feature: General Core features
> + * Sub-category: Synchronization
> + * Functionality: vm create
> + * Test category: negative test
> + */
> +
> +/**
> + * SUBTEST: invalid-flag-%s
> + * Description:  function %arg[1] used in vm create IOCTL to make it fail
> + * Functionality: fault
> + *
> + * arg[1]:
> + * @xe_vm_create_fault:  xe_vm_create_fault
> + * @xe_vm_create_scratch_fault: xe_vm_create_scrach_fault
> + * @xe_vm_create_scratch_fault_lr:    xe_vm_create_scrach_fault_lr
> + */
> +
> +static void invalid_flag(int fd, __u32 flags)
> +{
> +	struct drm_xe_vm_create create = {
> +		.flags = flags,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_CREATE, &create, EINVAL);
> +

Unnecessary blank line.

> +}
> +
> +/**
> + * SUBTEST: invalid-extensions
> + * Description: Check query with invalid extensions returns expected error code
> + *
> + * SUBTEST: vm-create-invalid-reserved
> + * Description: Send query with invalid reserved value for vm_create ioctl
> + */
> +
> +static void invalid_extensions(int fd)
> +{
> +	struct drm_xe_vm_create create = {
> +		.extensions = -1,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_CREATE, &create, EINVAL);
> +

Ditto.

> +}
> +
> +static void vm_create_invalid_reserved(int fd)
> +{
> +	struct drm_xe_vm_create create = {
> +		.reserved[0] = 0xffff,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_CREATE, &create, EINVAL);
> +

Ditto.

See my comment about destroy and reserved[1].

> +}
> +
> +/**
> + * SUBTEST: vm-destroy-invalid-reserved
> + * Description: Send query with invalid reserved value for vm_destroy ioctl
> + *
> + * SUBTEST: invalid-pad
> + * Description: Check query with invalid pad returns expected error code
> + *
> + * SUBTEST: invalid-vm-id
> + * Description: Check query with invalid vm_id returns expected error code
> + */
> +
> +static void vm_destroy_invalid_reserved(int fd)
> +{
> +	struct drm_xe_vm_destroy destroy = {
> +		.reserved[0] = 0xffff,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_DESTROY, &destroy, EINVAL);

I think checking reserved[1] in this subtests also deserves for a check:

	destroy.reserved[0] = 0;
	destroy.reserved[1] = 0xffff;

	do_ioctl_err(fd, DRM_IOCTL_XE_VM_DESTROY, &destroy, EINVAL);

> +}
> +
> +static void invalid_pad(int fd)
> +{
> +	struct drm_xe_vm_destroy destroy = {
> +		.pad = 1,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_DESTROY, &destroy, EINVAL);
> +}
> +
> +static void invalid_vm_id(int fd)
> +{
> +	struct drm_xe_vm_destroy destroy = {
> +		.vm_id = 0xdeadbeef,
> +	};
> +
> +	do_ioctl_err(fd, DRM_IOCTL_XE_VM_DESTROY, &destroy, ENOENT);
> +}
> +
>  igt_main
>  {
>  	struct drm_xe_engine_class_instance *hwe, *hwe_non_copy = NULL;
> @@ -2339,6 +2435,21 @@ igt_main
>  		{ NULL },
>  	};
>  
> +        const struct vm_create_section {
> +                const char *name;
> +                __u32 flags;
> +        } vm_create_flags_fail_functions[] = {
> +                { "xe_vm_create_fault", DRM_XE_VM_CREATE_FLAG_FAULT_MODE },
> +                { "xe_vm_create_scratch_fault",
> +                        DRM_XE_VM_CREATE_FLAG_SCRATCH_PAGE |
> +                        DRM_XE_VM_CREATE_FLAG_FAULT_MODE },
> +                { "xe_vm_create_scratch_fault_lr",

I would call it "xe_vm_create_invalid_flags". This one will require
altering when someone will add a new flag.

With those nits fixed:

Reviewed-by: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>

--
Zbigniew


> +                        ~(DRM_XE_VM_CREATE_FLAG_LR_MODE |
> +                        DRM_XE_VM_CREATE_FLAG_SCRATCH_PAGE |
> +                        DRM_XE_VM_CREATE_FLAG_FAULT_MODE) },
> +                { }
> +        };
> +
>  	igt_fixture {
>  		fd = drm_open_driver(DRIVER_XE);
>  
> @@ -2598,6 +2709,26 @@ igt_main
>  		}
>  	}
>  
> +	for (const struct vm_create_section *s = vm_create_flags_fail_functions; s->name; s++) {
> +		igt_subtest_f("invalid-flag-%s", s->name)
> +			invalid_flag(fd, s->flags);
> +	}
> +
> +	igt_subtest("invalid-extensions")
> +		invalid_extensions(fd);
> +
> +	igt_subtest("vm-create-invalid-reserved")
> +		vm_create_invalid_reserved(fd);
> +
> +	igt_subtest("vm-destroy-invalid-reserved")
> +		vm_destroy_invalid_reserved(fd);
> +
> +	igt_subtest("invalid-pad")
> +		invalid_pad(fd);
> +
> +	igt_subtest("invalid-vm-id")
> +		invalid_vm_id(fd);
> +
>  	igt_fixture
>  		drm_close_driver(fd);
>  }
> -- 
> 2.34.1
> 


More information about the igt-dev mailing list