Lines Matching +full:device +full:- +full:width
1 // SPDX-License-Identifier: GPL-2.0
8 #include <kunit/device.h>
36 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_ABGR8888,
41 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
46 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
51 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
52 .handles = { 1, 0, 0 }, .pitches = { 4 * MAX_WIDTH - 1, 0, 0 },
55 { .buffer_created = 0, .name = "ABGR8888 Invalid width",
56 .cmd = { .width = MAX_WIDTH + 1, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
61 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
66 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = 0,
70 { .buffer_created = 0, .name = "ABGR8888 Width 0",
71 .cmd = { .width = 0, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
76 .cmd = { .width = MAX_WIDTH, .height = 0, .pixel_format = DRM_FORMAT_ABGR8888,
81 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
82 .handles = { 1, 0, 0 }, .offsets = { UINT_MAX - 1, 0, 0 },
87 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
94 * All entries in members that represents per-plane values (@modifier, @handles,
98 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
105 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
111 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
117 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
125 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
132 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
138 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_ABGR8888,
144 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_NV12,
149 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
154 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
155 .handles = { 1, 1, 0 }, .pitches = { MAX_WIDTH, MAX_WIDTH - 1, 0 },
159 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
164 { .buffer_created = 0, .name = "NV12 different modifier per-plane",
165 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
172 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
180 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
187 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
195 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_NV12,
201 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_NV12,
206 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_YVU420,
212 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_YVU420,
217 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
223 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
224 .handles = { 1, 1, 1 }, .pitches = { MAX_WIDTH, DIV_ROUND_UP(MAX_WIDTH, 2) - 1,
229 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
235 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
244 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
251 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
259 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
266 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
274 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
282 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YVU420,
290 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_YUV420_10BIT,
297 .cmd = { .width = 600, .height = 600, .pixel_format = DRM_FORMAT_X0L2,
302 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
307 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
308 .handles = { 1, 0, 0 }, .pitches = { 2 * MAX_WIDTH - 1, 0, 0 }
312 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
317 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
324 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
330 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
336 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT, .pixel_format = DRM_FORMAT_X0L2,
342 .cmd = { .width = MAX_WIDTH, .height = MAX_HEIGHT,
371 priv->buffer_created = true; in fb_create_mock()
372 return ERR_PTR(-EINVAL); in fb_create_mock()
381 struct device *parent; in drm_framebuffer_test_init()
391 dev = &priv->dev; in drm_framebuffer_test_init()
393 dev->mode_config.min_width = MIN_WIDTH; in drm_framebuffer_test_init()
394 dev->mode_config.max_width = MAX_WIDTH; in drm_framebuffer_test_init()
395 dev->mode_config.min_height = MIN_HEIGHT; in drm_framebuffer_test_init()
396 dev->mode_config.max_height = MAX_HEIGHT; in drm_framebuffer_test_init()
397 dev->mode_config.funcs = &mock_config_funcs; in drm_framebuffer_test_init()
399 test->priv = priv; in drm_framebuffer_test_init()
405 const struct drm_framebuffer_test *params = test->param_value; in drm_test_framebuffer_create()
406 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_create()
407 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_create()
409 priv->buffer_created = false; in drm_test_framebuffer_create()
410 drm_internal_framebuffer_create(dev, ¶ms->cmd, NULL); in drm_test_framebuffer_create()
411 KUNIT_EXPECT_EQ(test, params->buffer_created, priv->buffer_created); in drm_test_framebuffer_create()
416 strscpy(desc, t->name, KUNIT_PARAM_DESC_SIZE); in drm_framebuffer_test_to_desc()
425 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_modifiers_not_supported()
426 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_modifiers_not_supported()
431 .width = MAX_WIDTH, .height = MAX_HEIGHT, in drm_test_framebuffer_modifiers_not_supported()
437 priv->buffer_created = false; in drm_test_framebuffer_modifiers_not_supported()
438 dev->mode_config.fb_modifiers_not_supported = 1; in drm_test_framebuffer_modifiers_not_supported()
441 KUNIT_EXPECT_EQ(test, priv->buffer_created, false); in drm_test_framebuffer_modifiers_not_supported()
442 KUNIT_EXPECT_EQ(test, PTR_ERR(fb), -EINVAL); in drm_test_framebuffer_modifiers_not_supported()
463 { .name = "Fail: overflowing fb with x-axis coordinate",
464 .expect = -ENOSPC, .src_x = 1, .fb_size = UINT_MAX,
466 { .name = "Fail: overflowing fb with y-axis coordinate",
467 .expect = -ENOSPC, .src_y = 1, .fb_size = UINT_MAX,
469 { .name = "Fail: overflowing fb with source width",
470 .expect = -ENOSPC, .dsrc_w = 1, .fb_size = UINT_MAX - 1,
473 .expect = -ENOSPC, .dsrc_h = 1, .fb_size = UINT_MAX - 1,
479 const struct drm_framebuffer_check_src_coords_case *params = test->param_value; in drm_test_framebuffer_check_src_coords()
480 const uint32_t src_x = params->src_x; in drm_test_framebuffer_check_src_coords()
481 const uint32_t src_y = params->src_y; in drm_test_framebuffer_check_src_coords()
482 const uint32_t src_w = (params->fb_size << 16) + params->dsrc_w; in drm_test_framebuffer_check_src_coords()
483 const uint32_t src_h = (params->fb_size << 16) + params->dsrc_h; in drm_test_framebuffer_check_src_coords()
485 .width = params->fb_size, in drm_test_framebuffer_check_src_coords()
486 .height = params->fb_size in drm_test_framebuffer_check_src_coords()
491 KUNIT_EXPECT_EQ(test, ret, params->expect); in drm_test_framebuffer_check_src_coords()
498 strscpy(desc, t->name, KUNIT_PARAM_DESC_SIZE); in check_src_coords_test_to_desc()
506 * from device's fb_list and decrement the number of framebuffers for that
507 * device, which is the only things it does.
511 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_cleanup()
512 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_cleanup()
513 struct list_head *fb_list = &dev->mode_config.fb_list; in drm_test_framebuffer_cleanup()
518 /* This will result on [fb_list] -> fb2 -> fb1 */ in drm_test_framebuffer_cleanup()
526 KUNIT_ASSERT_EQ(test, dev->mode_config.num_fb, 1); in drm_test_framebuffer_cleanup()
532 KUNIT_ASSERT_EQ(test, dev->mode_config.num_fb, 0); in drm_test_framebuffer_cleanup()
541 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_lookup()
542 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_lookup()
564 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_lookup_inexistent()
565 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_lookup_inexistent()
581 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_init()
582 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_init()
591 /* Check if fb->funcs is actually set to the drm_framebuffer_funcs passed on */ in drm_test_framebuffer_init()
594 /* The fb->comm must be set to the current running process */ in drm_test_framebuffer_init()
595 KUNIT_EXPECT_STREQ(test, fb1.comm, current->comm); in drm_test_framebuffer_init()
597 /* The fb->base must be successfully initialized */ in drm_test_framebuffer_init()
604 KUNIT_EXPECT_EQ(test, dev->mode_config.num_fb, 1); in drm_test_framebuffer_init()
605 KUNIT_EXPECT_PTR_EQ(test, dev->mode_config.fb_list.prev, &fb1.head); in drm_test_framebuffer_init()
606 KUNIT_EXPECT_PTR_EQ(test, dev->mode_config.fb_list.next, &fb1.head); in drm_test_framebuffer_init()
614 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_init_bad_format()
615 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_init_bad_format()
622 KUNIT_EXPECT_EQ(test, ret, -EINVAL); in drm_test_framebuffer_init_bad_format()
632 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_init_dev_mismatch()
633 struct drm_device *right_dev = &priv->dev; in drm_test_framebuffer_init_dev_mismatch()
635 struct device *wrong_dev_parent; in drm_test_framebuffer_init_dev_mismatch()
641 wrong_dev_parent = kunit_device_register(test, "drm-kunit-wrong-device-mock"); in drm_test_framebuffer_init_dev_mismatch()
649 /* Fails if fb->dev doesn't point to the drm_device passed on first arg */ in drm_test_framebuffer_init_dev_mismatch()
651 KUNIT_EXPECT_EQ(test, ret, -EINVAL); in drm_test_framebuffer_init_dev_mismatch()
656 struct drm_framebuffer_test_priv *priv = container_of(fb->dev, typeof(*priv), dev); in destroy_free_mock()
658 priv->buffer_freed = true; in destroy_free_mock()
667 * fb->funcs->destroy() and garantee that the framebufer object is unregistered
672 struct drm_framebuffer_test_priv *priv = test->priv; in drm_test_framebuffer_free()
673 struct drm_device *dev = &priv->dev; in drm_test_framebuffer_free()
681 priv->buffer_freed = false; in drm_test_framebuffer_free()
698 /* Test if fb->funcs->destroy() was called */ in drm_test_framebuffer_free()
699 KUNIT_EXPECT_EQ(test, priv->buffer_freed, true); in drm_test_framebuffer_free()