[igt-dev] [PATCH i-g-t] tests/prime_udl: Remove intel-libdrm dependency
Zbigniew Kempczyński
zbigniew.kempczynski at intel.com
Mon Nov 28 08:25:16 UTC 2022
To remove all intel-libdrm code in intel_batchbuffer we need to rewrite
and drop it in all dependent code. Currently CI doesn't exercise this
test and I don't have DisplayLink hardware so this is blind rewrite
(instead of removing the test). Common xf86drmMode calls are left
intact as igt likely won't remove libdrm totally.
Signed-off-by: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>
Cc: Petri Latvala <petri.latvala at intel.com>
---
tests/prime_udl.c | 61 +++++++++++++++++------------------------------
1 file changed, 22 insertions(+), 39 deletions(-)
diff --git a/tests/prime_udl.c b/tests/prime_udl.c
index 582e31f5df..4898694f5f 100644
--- a/tests/prime_udl.c
+++ b/tests/prime_udl.c
@@ -12,6 +12,7 @@
#include <xf86drmMode.h>
#include "intel_bufmgr.h"
+#include "i915/gem_create.h"
IGT_TEST_DESCRIPTION("Basic set of prime tests between Intel and DisplayLink");
@@ -30,6 +31,7 @@ static int find_and_open_devices(void)
FILE *fl;
char vendor_id[8];
int venid;
+
for (i = 0; i < 9; i++) {
sprintf(path, "/sys/class/drm/card%d/device/vendor", i);
if (stat(path, &buf)) {
@@ -78,57 +80,50 @@ static int dumb_bo_destroy(int fd, uint32_t handle)
/*
* simple share and import
*/
-static int test1(void)
+static void test1(void)
{
- drm_intel_bo *test_intel_bo;
+ uint32_t intel_handle, udl_handle;
int prime_fd;
- int ret;
- uint32_t udl_handle;
- test_intel_bo = drm_intel_bo_alloc(bufmgr, "test bo", BO_SIZE, 4096);
+ intel_handle = gem_create(intel_fd, BO_SIZE);
- drm_intel_bo_gem_export_to_prime(test_intel_bo, &prime_fd);
+ prime_fd = prime_handle_to_fd(intel_fd, intel_handle);
+ igt_assert(prime_fd >= 0);
- ret = drmPrimeFDToHandle(udl_fd, prime_fd, &udl_handle);
+ udl_handle = prime_fd_to_handle(udl_fd, prime_fd);
+ igt_assert(udl_handle > 0);
dumb_bo_destroy(udl_fd, udl_handle);
- drm_intel_bo_unreference(test_intel_bo);
- return ret;
+ gem_close(intel_fd, intel_handle);
}
-static int test2(void)
+static void test2(void)
{
- drm_intel_bo *test_intel_bo;
+ uint32_t intel_handle, udl_handle;
uint32_t fb_id;
drmModeClip clip;
int prime_fd;
- uint32_t udl_handle;
int ret;
- test_intel_bo = drm_intel_bo_alloc(bufmgr, "test bo", BO_SIZE, 4096);
+ intel_handle = gem_create(intel_fd, BO_SIZE);
- drm_intel_bo_gem_export_to_prime(test_intel_bo, &prime_fd);
+ prime_fd = prime_handle_to_fd(intel_fd, intel_handle);
+ igt_assert(prime_fd >= 0);
- ret = drmPrimeFDToHandle(udl_fd, prime_fd, &udl_handle);
- if (ret)
- goto out;
+ udl_handle = prime_fd_to_handle(udl_fd, prime_fd);
ret = drmModeAddFB(udl_fd, 640, 480, 16, 16, 640, udl_handle, &fb_id);
- if (ret)
- goto out;
+ igt_assert(ret == 0);
clip.x1 = 0;
clip.y1 = 0;
clip.x2 = 10;
clip.y2 = 10;
ret = drmModeDirtyFB(udl_fd, fb_id, &clip, 1);
- if (ret) {
- return ret;
- }
-out:
+ igt_assert(ret == 0);
+
dumb_bo_destroy(udl_fd, udl_handle);
- drm_intel_bo_unreference(test_intel_bo);
- return ret;
+ gem_close(intel_fd, intel_handle);
}
igt_simple_main
@@ -138,22 +133,10 @@ igt_simple_main
igt_skip_on(udl_fd == -1);
igt_skip_on(intel_fd == -1);
- /* set up intel bufmgr */
- bufmgr = drm_intel_bufmgr_gem_init(intel_fd, 4096);
- drm_intel_bufmgr_gem_enable_reuse(bufmgr);
-
- /* set up an intel batch buffer */
- devid = intel_get_drm_devid(intel_fd);
- intel_batch = intel_batchbuffer_alloc(bufmgr, devid);
-
/* create an object on the i915 */
- igt_assert(test1() == 0);
-
- igt_assert(test2() == 0);
-
- intel_batchbuffer_free(intel_batch);
+ test1();
- drm_intel_bufmgr_destroy(bufmgr);
+ test2();
close(intel_fd);
close(udl_fd);
--
2.34.1
More information about the igt-dev
mailing list