* [PATCH v2 01/10] drm/xe/fbdev: use the same 64-byte stride alignment as i915
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:38 ` Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 02/10] drm/i915/fbdev: make intel_framebuffer_create() error return handling explicit Jani Nikula
` (11 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
For reasons unknown, xe uses XE_PAGE_SIZE alignment for
stride. Presumably it's just a confusion between stride alignment and bo
allocation size alignment. Switch to 64 byte alignment to, uh, align
with i915.
This will also be helpful in deduplicating and unifying the xe and i915
framebuffer allocation.
Link: https://lore.kernel.org/r/aLqsC87Ol_zCXOkN@intel.com
Suggested-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index 8ea9a472113c..bce4cb16f682 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -33,7 +33,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
mode_cmd.height = sizes->surface_height;
mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
- DIV_ROUND_UP(sizes->surface_bpp, 8), XE_PAGE_SIZE);
+ DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
sizes->surface_depth);
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 01/10] drm/xe/fbdev: use the same 64-byte stride alignment as i915
2025-09-18 8:40 ` [PATCH v2 01/10] drm/xe/fbdev: use the same 64-byte stride alignment as i915 Jani Nikula
@ 2025-09-18 17:38 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:38 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:51AM +0300, Jani Nikula wrote:
> For reasons unknown, xe uses XE_PAGE_SIZE alignment for
> stride. Presumably it's just a confusion between stride alignment and bo
> allocation size alignment. Switch to 64 byte alignment to, uh, align
> with i915.
>
> This will also be helpful in deduplicating and unifying the xe and i915
> framebuffer allocation.
>
> Link: https://lore.kernel.org/r/aLqsC87Ol_zCXOkN@intel.com
> Suggested-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index 8ea9a472113c..bce4cb16f682 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -33,7 +33,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> mode_cmd.height = sizes->surface_height;
>
> mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
> - DIV_ROUND_UP(sizes->surface_bpp, 8), XE_PAGE_SIZE);
> + DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
> mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
> sizes->surface_depth);
>
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 02/10] drm/i915/fbdev: make intel_framebuffer_create() error return handling explicit
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
2025-09-18 8:40 ` [PATCH v2 01/10] drm/xe/fbdev: use the same 64-byte stride alignment as i915 Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:38 ` Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 03/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_alloc() Jani Nikula
` (10 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
It's sketchy to pass error pointers via to_intel_framebuffer(). It
probably works as long as struct intel_framebuffer embeds struct
drm_framebuffer at offset 0, but be explicit about it.
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index 210aee9ae88b..b9dfd00a7d05 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -67,9 +67,16 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
mode_cmd.pixel_format,
mode_cmd.modifier[0]),
&mode_cmd);
+ if (IS_ERR(fb)) {
+ i915_gem_object_put(obj);
+ goto err;
+ }
+
i915_gem_object_put(obj);
return to_intel_framebuffer(fb);
+err:
+ return ERR_CAST(fb);
}
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 02/10] drm/i915/fbdev: make intel_framebuffer_create() error return handling explicit
2025-09-18 8:40 ` [PATCH v2 02/10] drm/i915/fbdev: make intel_framebuffer_create() error return handling explicit Jani Nikula
@ 2025-09-18 17:38 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:38 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:52AM +0300, Jani Nikula wrote:
> It's sketchy to pass error pointers via to_intel_framebuffer(). It
> probably works as long as struct intel_framebuffer embeds struct
> drm_framebuffer at offset 0, but be explicit about it.
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 7 +++++++
> 1 file changed, 7 insertions(+)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index 210aee9ae88b..b9dfd00a7d05 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -67,9 +67,16 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> mode_cmd.pixel_format,
> mode_cmd.modifier[0]),
> &mode_cmd);
> + if (IS_ERR(fb)) {
> + i915_gem_object_put(obj);
> + goto err;
> + }
> +
> i915_gem_object_put(obj);
>
> return to_intel_framebuffer(fb);
> +err:
> + return ERR_CAST(fb);
> }
>
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 03/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_alloc()
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
2025-09-18 8:40 ` [PATCH v2 01/10] drm/xe/fbdev: use the same 64-byte stride alignment as i915 Jani Nikula
2025-09-18 8:40 ` [PATCH v2 02/10] drm/i915/fbdev: make intel_framebuffer_create() error return handling explicit Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:39 ` [PATCH v2 03/10] drm/{i915,xe}/fbdev: " Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 04/10] drm/{i915, xe}/fbdev: deduplicate struct drm_mode_fb_cmd2 init Jani Nikula
` (9 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
The function doesn't actually need struct drm_fb_helper for anything,
just pass struct drm_device.
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev.c | 2 +-
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 10 +++++-----
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 4 ++--
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 7 +++----
4 files changed, 11 insertions(+), 12 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
index 7c4709d58aa3..46c6de5f6088 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
@@ -237,7 +237,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
if (!fb || drm_WARN_ON(display->drm, !intel_fb_bo(&fb->base))) {
drm_dbg_kms(display->drm,
"no BIOS fb, allocating a new one\n");
- fb = intel_fbdev_fb_alloc(helper, sizes);
+ fb = intel_fbdev_fb_alloc(display->drm, sizes);
if (IS_ERR(fb))
return PTR_ERR(fb);
} else {
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index b9dfd00a7d05..4de13d1a4c7a 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -13,11 +13,11 @@
#include "intel_fb.h"
#include "intel_fbdev_fb.h"
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
+struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_fb_helper_surface_size *sizes)
{
- struct intel_display *display = to_intel_display(helper->dev);
- struct drm_i915_private *dev_priv = to_i915(display->drm);
+ struct intel_display *display = to_intel_display(drm);
+ struct drm_i915_private *dev_priv = to_i915(drm);
struct drm_framebuffer *fb;
struct drm_mode_fb_cmd2 mode_cmd = {};
struct drm_i915_gem_object *obj;
@@ -58,12 +58,12 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
}
if (IS_ERR(obj)) {
- drm_err(display->drm, "failed to allocate framebuffer (%pe)\n", obj);
+ drm_err(drm, "failed to allocate framebuffer (%pe)\n", obj);
return ERR_PTR(-ENOMEM);
}
fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
- drm_get_format_info(display->drm,
+ drm_get_format_info(drm,
mode_cmd.pixel_format,
mode_cmd.modifier[0]),
&mode_cmd);
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index cb7957272715..668ae355f5e5 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -6,14 +6,14 @@
#ifndef __INTEL_FBDEV_FB_H__
#define __INTEL_FBDEV_FB_H__
-struct drm_fb_helper;
+struct drm_device;
struct drm_fb_helper_surface_size;
struct drm_gem_object;
struct fb_info;
struct i915_vma;
struct intel_display;
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
+struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_fb_helper_surface_size *sizes);
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
struct drm_gem_object *obj, struct i915_vma *vma);
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index bce4cb16f682..5c0874bfa6ab 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -15,12 +15,11 @@
#include <generated/xe_wa_oob.h>
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
+struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_fb_helper_surface_size *sizes)
{
struct drm_framebuffer *fb;
- struct drm_device *dev = helper->dev;
- struct xe_device *xe = to_xe_device(dev);
+ struct xe_device *xe = to_xe_device(drm);
struct drm_mode_fb_cmd2 mode_cmd = {};
struct xe_bo *obj;
int size;
@@ -67,7 +66,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
}
fb = intel_framebuffer_create(&obj->ttm.base,
- drm_get_format_info(dev,
+ drm_get_format_info(drm,
mode_cmd.pixel_format,
mode_cmd.modifier[0]),
&mode_cmd);
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 03/10] drm/{i915,xe}/fbdev: pass struct drm_device to intel_fbdev_fb_alloc()
2025-09-18 8:40 ` [PATCH v2 03/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_alloc() Jani Nikula
@ 2025-09-18 17:39 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:39 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:53AM +0300, Jani Nikula wrote:
> The function doesn't actually need struct drm_fb_helper for anything,
> just pass struct drm_device.
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev.c | 2 +-
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 10 +++++-----
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 4 ++--
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 7 +++----
> 4 files changed, 11 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
> index 7c4709d58aa3..46c6de5f6088 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
> @@ -237,7 +237,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
> if (!fb || drm_WARN_ON(display->drm, !intel_fb_bo(&fb->base))) {
> drm_dbg_kms(display->drm,
> "no BIOS fb, allocating a new one\n");
> - fb = intel_fbdev_fb_alloc(helper, sizes);
> + fb = intel_fbdev_fb_alloc(display->drm, sizes);
> if (IS_ERR(fb))
> return PTR_ERR(fb);
> } else {
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index b9dfd00a7d05..4de13d1a4c7a 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -13,11 +13,11 @@
> #include "intel_fb.h"
> #include "intel_fbdev_fb.h"
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> +struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_fb_helper_surface_size *sizes)
> {
> - struct intel_display *display = to_intel_display(helper->dev);
> - struct drm_i915_private *dev_priv = to_i915(display->drm);
> + struct intel_display *display = to_intel_display(drm);
> + struct drm_i915_private *dev_priv = to_i915(drm);
> struct drm_framebuffer *fb;
> struct drm_mode_fb_cmd2 mode_cmd = {};
> struct drm_i915_gem_object *obj;
> @@ -58,12 +58,12 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> }
>
> if (IS_ERR(obj)) {
> - drm_err(display->drm, "failed to allocate framebuffer (%pe)\n", obj);
> + drm_err(drm, "failed to allocate framebuffer (%pe)\n", obj);
> return ERR_PTR(-ENOMEM);
> }
>
> fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
> - drm_get_format_info(display->drm,
> + drm_get_format_info(drm,
> mode_cmd.pixel_format,
> mode_cmd.modifier[0]),
> &mode_cmd);
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index cb7957272715..668ae355f5e5 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -6,14 +6,14 @@
> #ifndef __INTEL_FBDEV_FB_H__
> #define __INTEL_FBDEV_FB_H__
>
> -struct drm_fb_helper;
> +struct drm_device;
> struct drm_fb_helper_surface_size;
> struct drm_gem_object;
> struct fb_info;
> struct i915_vma;
> struct intel_display;
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> +struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_fb_helper_surface_size *sizes);
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> struct drm_gem_object *obj, struct i915_vma *vma);
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index bce4cb16f682..5c0874bfa6ab 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -15,12 +15,11 @@
>
> #include <generated/xe_wa_oob.h>
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> +struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_fb_helper_surface_size *sizes)
> {
> struct drm_framebuffer *fb;
> - struct drm_device *dev = helper->dev;
> - struct xe_device *xe = to_xe_device(dev);
> + struct xe_device *xe = to_xe_device(drm);
> struct drm_mode_fb_cmd2 mode_cmd = {};
> struct xe_bo *obj;
> int size;
> @@ -67,7 +66,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_fb_helper *helper,
> }
>
> fb = intel_framebuffer_create(&obj->ttm.base,
> - drm_get_format_info(dev,
> + drm_get_format_info(drm,
> mode_cmd.pixel_format,
> mode_cmd.modifier[0]),
> &mode_cmd);
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 04/10] drm/{i915, xe}/fbdev: deduplicate struct drm_mode_fb_cmd2 init
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (2 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 03/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_alloc() Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:40 ` [PATCH v2 04/10] drm/{i915,xe}/fbdev: " Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 05/10] drm/i915/fbdev: abstract bo creation Jani Nikula
` (8 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
Pull struct drm_mode_fb_cmd2 initialization out of the driver dependent
code into shared display code.
v2: Rebase on xe stride alignment change
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev.c | 32 ++++++++++++++++++-
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 25 ++++-----------
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 4 +--
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 25 ++++-----------
4 files changed, 45 insertions(+), 41 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
index 46c6de5f6088..e46c08762b84 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
@@ -207,6 +207,35 @@ static const struct drm_fb_helper_funcs intel_fb_helper_funcs = {
.fb_set_suspend = intelfb_set_suspend,
};
+static void intel_fbdev_fill_mode_cmd(struct drm_fb_helper_surface_size *sizes,
+ struct drm_mode_fb_cmd2 *mode_cmd)
+{
+ /* we don't do packed 24bpp */
+ if (sizes->surface_bpp == 24)
+ sizes->surface_bpp = 32;
+
+ mode_cmd->width = sizes->surface_width;
+ mode_cmd->height = sizes->surface_height;
+
+ mode_cmd->pitches[0] = ALIGN(mode_cmd->width * DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
+ mode_cmd->pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
+ sizes->surface_depth);
+}
+
+static struct intel_framebuffer *
+__intel_fbdev_fb_alloc(struct intel_display *display,
+ struct drm_fb_helper_surface_size *sizes)
+{
+ struct drm_mode_fb_cmd2 mode_cmd = {};
+ struct intel_framebuffer *fb;
+
+ intel_fbdev_fill_mode_cmd(sizes, &mode_cmd);
+
+ fb = intel_fbdev_fb_alloc(display->drm, &mode_cmd);
+
+ return fb;
+}
+
int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
struct drm_fb_helper_surface_size *sizes)
{
@@ -237,7 +266,8 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
if (!fb || drm_WARN_ON(display->drm, !intel_fb_bo(&fb->base))) {
drm_dbg_kms(display->drm,
"no BIOS fb, allocating a new one\n");
- fb = intel_fbdev_fb_alloc(display->drm, sizes);
+
+ fb = __intel_fbdev_fb_alloc(display, sizes);
if (IS_ERR(fb))
return PTR_ERR(fb);
} else {
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index 4de13d1a4c7a..685612e6afc5 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -3,7 +3,7 @@
* Copyright © 2023 Intel Corporation
*/
-#include <drm/drm_fb_helper.h>
+#include <linux/fb.h>
#include "gem/i915_gem_lmem.h"
@@ -14,28 +14,15 @@
#include "intel_fbdev_fb.h"
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_fb_helper_surface_size *sizes)
+ struct drm_mode_fb_cmd2 *mode_cmd)
{
struct intel_display *display = to_intel_display(drm);
struct drm_i915_private *dev_priv = to_i915(drm);
struct drm_framebuffer *fb;
- struct drm_mode_fb_cmd2 mode_cmd = {};
struct drm_i915_gem_object *obj;
int size;
- /* we don't do packed 24bpp */
- if (sizes->surface_bpp == 24)
- sizes->surface_bpp = 32;
-
- mode_cmd.width = sizes->surface_width;
- mode_cmd.height = sizes->surface_height;
-
- mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
- DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
- mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
- sizes->surface_depth);
-
- size = mode_cmd.pitches[0] * mode_cmd.height;
+ size = mode_cmd->pitches[0] * mode_cmd->height;
size = PAGE_ALIGN(size);
obj = ERR_PTR(-ENODEV);
@@ -64,9 +51,9 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
drm_get_format_info(drm,
- mode_cmd.pixel_format,
- mode_cmd.modifier[0]),
- &mode_cmd);
+ mode_cmd->pixel_format,
+ mode_cmd->modifier[0]),
+ mode_cmd);
if (IS_ERR(fb)) {
i915_gem_object_put(obj);
goto err;
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index 668ae355f5e5..83454ffbf79c 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -7,14 +7,14 @@
#define __INTEL_FBDEV_FB_H__
struct drm_device;
-struct drm_fb_helper_surface_size;
struct drm_gem_object;
+struct drm_mode_fb_cmd2;
struct fb_info;
struct i915_vma;
struct intel_display;
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_fb_helper_surface_size *sizes);
+ struct drm_mode_fb_cmd2 *mode_cmd);
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
struct drm_gem_object *obj, struct i915_vma *vma);
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index 5c0874bfa6ab..8eaf1cc7fdf9 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -3,7 +3,7 @@
* Copyright © 2023 Intel Corporation
*/
-#include <drm/drm_fb_helper.h>
+#include <linux/fb.h>
#include "intel_display_core.h"
#include "intel_display_types.h"
@@ -16,27 +16,14 @@
#include <generated/xe_wa_oob.h>
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_fb_helper_surface_size *sizes)
+ struct drm_mode_fb_cmd2 *mode_cmd)
{
struct drm_framebuffer *fb;
struct xe_device *xe = to_xe_device(drm);
- struct drm_mode_fb_cmd2 mode_cmd = {};
struct xe_bo *obj;
int size;
- /* we don't do packed 24bpp */
- if (sizes->surface_bpp == 24)
- sizes->surface_bpp = 32;
-
- mode_cmd.width = sizes->surface_width;
- mode_cmd.height = sizes->surface_height;
-
- mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
- DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
- mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
- sizes->surface_depth);
-
- size = mode_cmd.pitches[0] * mode_cmd.height;
+ size = mode_cmd->pitches[0] * mode_cmd->height;
size = PAGE_ALIGN(size);
obj = ERR_PTR(-ENODEV);
@@ -67,9 +54,9 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
fb = intel_framebuffer_create(&obj->ttm.base,
drm_get_format_info(drm,
- mode_cmd.pixel_format,
- mode_cmd.modifier[0]),
- &mode_cmd);
+ mode_cmd->pixel_format,
+ mode_cmd->modifier[0]),
+ mode_cmd);
if (IS_ERR(fb)) {
xe_bo_unpin_map_no_vm(obj);
goto err;
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 04/10] drm/{i915,xe}/fbdev: deduplicate struct drm_mode_fb_cmd2 init
2025-09-18 8:40 ` [PATCH v2 04/10] drm/{i915, xe}/fbdev: deduplicate struct drm_mode_fb_cmd2 init Jani Nikula
@ 2025-09-18 17:40 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:40 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:54AM +0300, Jani Nikula wrote:
> Pull struct drm_mode_fb_cmd2 initialization out of the driver dependent
> code into shared display code.
>
> v2: Rebase on xe stride alignment change
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev.c | 32 ++++++++++++++++++-
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 25 ++++-----------
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 4 +--
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 25 ++++-----------
> 4 files changed, 45 insertions(+), 41 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
> index 46c6de5f6088..e46c08762b84 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
> @@ -207,6 +207,35 @@ static const struct drm_fb_helper_funcs intel_fb_helper_funcs = {
> .fb_set_suspend = intelfb_set_suspend,
> };
>
> +static void intel_fbdev_fill_mode_cmd(struct drm_fb_helper_surface_size *sizes,
> + struct drm_mode_fb_cmd2 *mode_cmd)
> +{
> + /* we don't do packed 24bpp */
> + if (sizes->surface_bpp == 24)
> + sizes->surface_bpp = 32;
> +
> + mode_cmd->width = sizes->surface_width;
> + mode_cmd->height = sizes->surface_height;
> +
> + mode_cmd->pitches[0] = ALIGN(mode_cmd->width * DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
> + mode_cmd->pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
> + sizes->surface_depth);
> +}
> +
> +static struct intel_framebuffer *
> +__intel_fbdev_fb_alloc(struct intel_display *display,
> + struct drm_fb_helper_surface_size *sizes)
> +{
> + struct drm_mode_fb_cmd2 mode_cmd = {};
> + struct intel_framebuffer *fb;
> +
> + intel_fbdev_fill_mode_cmd(sizes, &mode_cmd);
> +
> + fb = intel_fbdev_fb_alloc(display->drm, &mode_cmd);
> +
> + return fb;
> +}
> +
> int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
> struct drm_fb_helper_surface_size *sizes)
> {
> @@ -237,7 +266,8 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
> if (!fb || drm_WARN_ON(display->drm, !intel_fb_bo(&fb->base))) {
> drm_dbg_kms(display->drm,
> "no BIOS fb, allocating a new one\n");
> - fb = intel_fbdev_fb_alloc(display->drm, sizes);
> +
> + fb = __intel_fbdev_fb_alloc(display, sizes);
> if (IS_ERR(fb))
> return PTR_ERR(fb);
> } else {
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index 4de13d1a4c7a..685612e6afc5 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -3,7 +3,7 @@
> * Copyright © 2023 Intel Corporation
> */
>
> -#include <drm/drm_fb_helper.h>
> +#include <linux/fb.h>
>
> #include "gem/i915_gem_lmem.h"
>
> @@ -14,28 +14,15 @@
> #include "intel_fbdev_fb.h"
>
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_fb_helper_surface_size *sizes)
> + struct drm_mode_fb_cmd2 *mode_cmd)
> {
> struct intel_display *display = to_intel_display(drm);
> struct drm_i915_private *dev_priv = to_i915(drm);
> struct drm_framebuffer *fb;
> - struct drm_mode_fb_cmd2 mode_cmd = {};
> struct drm_i915_gem_object *obj;
> int size;
>
> - /* we don't do packed 24bpp */
> - if (sizes->surface_bpp == 24)
> - sizes->surface_bpp = 32;
> -
> - mode_cmd.width = sizes->surface_width;
> - mode_cmd.height = sizes->surface_height;
> -
> - mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
> - DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
> - mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
> - sizes->surface_depth);
> -
> - size = mode_cmd.pitches[0] * mode_cmd.height;
> + size = mode_cmd->pitches[0] * mode_cmd->height;
> size = PAGE_ALIGN(size);
>
> obj = ERR_PTR(-ENODEV);
> @@ -64,9 +51,9 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
>
> fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
> drm_get_format_info(drm,
> - mode_cmd.pixel_format,
> - mode_cmd.modifier[0]),
> - &mode_cmd);
> + mode_cmd->pixel_format,
> + mode_cmd->modifier[0]),
> + mode_cmd);
> if (IS_ERR(fb)) {
> i915_gem_object_put(obj);
> goto err;
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index 668ae355f5e5..83454ffbf79c 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -7,14 +7,14 @@
> #define __INTEL_FBDEV_FB_H__
>
> struct drm_device;
> -struct drm_fb_helper_surface_size;
> struct drm_gem_object;
> +struct drm_mode_fb_cmd2;
> struct fb_info;
> struct i915_vma;
> struct intel_display;
>
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_fb_helper_surface_size *sizes);
> + struct drm_mode_fb_cmd2 *mode_cmd);
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> struct drm_gem_object *obj, struct i915_vma *vma);
>
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index 5c0874bfa6ab..8eaf1cc7fdf9 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -3,7 +3,7 @@
> * Copyright © 2023 Intel Corporation
> */
>
> -#include <drm/drm_fb_helper.h>
> +#include <linux/fb.h>
>
> #include "intel_display_core.h"
> #include "intel_display_types.h"
> @@ -16,27 +16,14 @@
> #include <generated/xe_wa_oob.h>
>
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_fb_helper_surface_size *sizes)
> + struct drm_mode_fb_cmd2 *mode_cmd)
> {
> struct drm_framebuffer *fb;
> struct xe_device *xe = to_xe_device(drm);
> - struct drm_mode_fb_cmd2 mode_cmd = {};
> struct xe_bo *obj;
> int size;
>
> - /* we don't do packed 24bpp */
> - if (sizes->surface_bpp == 24)
> - sizes->surface_bpp = 32;
> -
> - mode_cmd.width = sizes->surface_width;
> - mode_cmd.height = sizes->surface_height;
> -
> - mode_cmd.pitches[0] = ALIGN(mode_cmd.width *
> - DIV_ROUND_UP(sizes->surface_bpp, 8), 64);
> - mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp,
> - sizes->surface_depth);
> -
> - size = mode_cmd.pitches[0] * mode_cmd.height;
> + size = mode_cmd->pitches[0] * mode_cmd->height;
> size = PAGE_ALIGN(size);
> obj = ERR_PTR(-ENODEV);
>
> @@ -67,9 +54,9 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
>
> fb = intel_framebuffer_create(&obj->ttm.base,
> drm_get_format_info(drm,
> - mode_cmd.pixel_format,
> - mode_cmd.modifier[0]),
> - &mode_cmd);
> + mode_cmd->pixel_format,
> + mode_cmd->modifier[0]),
> + mode_cmd);
> if (IS_ERR(fb)) {
> xe_bo_unpin_map_no_vm(obj);
> goto err;
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 05/10] drm/i915/fbdev: abstract bo creation
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (3 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 04/10] drm/{i915, xe}/fbdev: deduplicate struct drm_mode_fb_cmd2 init Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:42 ` Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 06/10] drm/xe/fbdev: " Jani Nikula
` (7 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
Separate fbdev bo creation into a separate function
intel_fbdev_fb_bo_create().
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 33 +++++++++++++------
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 1 +
2 files changed, 24 insertions(+), 10 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index 685612e6afc5..bfd05fd34348 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -13,17 +13,11 @@
#include "intel_fb.h"
#include "intel_fbdev_fb.h"
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_mode_fb_cmd2 *mode_cmd)
+struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
{
struct intel_display *display = to_intel_display(drm);
struct drm_i915_private *dev_priv = to_i915(drm);
- struct drm_framebuffer *fb;
struct drm_i915_gem_object *obj;
- int size;
-
- size = mode_cmd->pitches[0] * mode_cmd->height;
- size = PAGE_ALIGN(size);
obj = ERR_PTR(-ENODEV);
if (HAS_LMEM(dev_priv)) {
@@ -49,17 +43,36 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
return ERR_PTR(-ENOMEM);
}
- fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
+ return &obj->base;
+}
+
+struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
+ struct drm_mode_fb_cmd2 *mode_cmd)
+{
+ struct drm_framebuffer *fb;
+ struct drm_gem_object *obj;
+ int size;
+
+ size = mode_cmd->pitches[0] * mode_cmd->height;
+ size = PAGE_ALIGN(size);
+
+ obj = intel_fbdev_fb_bo_create(drm, size);
+ if (IS_ERR(obj)) {
+ fb = ERR_CAST(obj);
+ goto err;
+ }
+
+ fb = intel_framebuffer_create(obj,
drm_get_format_info(drm,
mode_cmd->pixel_format,
mode_cmd->modifier[0]),
mode_cmd);
if (IS_ERR(fb)) {
- i915_gem_object_put(obj);
+ drm_gem_object_put(obj);
goto err;
}
- i915_gem_object_put(obj);
+ drm_gem_object_put(obj);
return to_intel_framebuffer(fb);
err:
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index 83454ffbf79c..6a4ba40d5831 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -13,6 +13,7 @@ struct fb_info;
struct i915_vma;
struct intel_display;
+struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_mode_fb_cmd2 *mode_cmd);
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 05/10] drm/i915/fbdev: abstract bo creation
2025-09-18 8:40 ` [PATCH v2 05/10] drm/i915/fbdev: abstract bo creation Jani Nikula
@ 2025-09-18 17:42 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:42 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:55AM +0300, Jani Nikula wrote:
> Separate fbdev bo creation into a separate function
> intel_fbdev_fb_bo_create().
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 33 +++++++++++++------
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 1 +
> 2 files changed, 24 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index 685612e6afc5..bfd05fd34348 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -13,17 +13,11 @@
> #include "intel_fb.h"
> #include "intel_fbdev_fb.h"
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_mode_fb_cmd2 *mode_cmd)
> +struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
> {
> struct intel_display *display = to_intel_display(drm);
> struct drm_i915_private *dev_priv = to_i915(drm);
> - struct drm_framebuffer *fb;
> struct drm_i915_gem_object *obj;
> - int size;
> -
> - size = mode_cmd->pitches[0] * mode_cmd->height;
> - size = PAGE_ALIGN(size);
>
> obj = ERR_PTR(-ENODEV);
> if (HAS_LMEM(dev_priv)) {
> @@ -49,17 +43,36 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> return ERR_PTR(-ENOMEM);
> }
>
> - fb = intel_framebuffer_create(intel_bo_to_drm_bo(obj),
> + return &obj->base;
> +}
> +
> +struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> + struct drm_mode_fb_cmd2 *mode_cmd)
> +{
> + struct drm_framebuffer *fb;
> + struct drm_gem_object *obj;
> + int size;
> +
> + size = mode_cmd->pitches[0] * mode_cmd->height;
> + size = PAGE_ALIGN(size);
> +
> + obj = intel_fbdev_fb_bo_create(drm, size);
> + if (IS_ERR(obj)) {
> + fb = ERR_CAST(obj);
> + goto err;
> + }
> +
> + fb = intel_framebuffer_create(obj,
> drm_get_format_info(drm,
> mode_cmd->pixel_format,
> mode_cmd->modifier[0]),
> mode_cmd);
> if (IS_ERR(fb)) {
> - i915_gem_object_put(obj);
> + drm_gem_object_put(obj);
> goto err;
> }
>
> - i915_gem_object_put(obj);
> + drm_gem_object_put(obj);
>
> return to_intel_framebuffer(fb);
> err:
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index 83454ffbf79c..6a4ba40d5831 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -13,6 +13,7 @@ struct fb_info;
> struct i915_vma;
> struct intel_display;
>
> +struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_mode_fb_cmd2 *mode_cmd);
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 06/10] drm/xe/fbdev: abstract bo creation
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (4 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 05/10] drm/i915/fbdev: abstract bo creation Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:42 ` Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 07/10] drm/{i915, xe}/fbdev: add intel_fbdev_fb_bo_destroy() Jani Nikula
` (6 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
Separate fbdev bo creation into a separate function
intel_fbdev_fb_bo_create().
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 33 ++++++++++++++-------
1 file changed, 23 insertions(+), 10 deletions(-)
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index 8eaf1cc7fdf9..48225062211c 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -15,16 +15,11 @@
#include <generated/xe_wa_oob.h>
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_mode_fb_cmd2 *mode_cmd)
+struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
{
- struct drm_framebuffer *fb;
struct xe_device *xe = to_xe_device(drm);
struct xe_bo *obj;
- int size;
- size = mode_cmd->pitches[0] * mode_cmd->height;
- size = PAGE_ALIGN(size);
obj = ERR_PTR(-ENODEV);
if (!IS_DGFX(xe) && !XE_GT_WA(xe_root_mmio_gt(xe), 22019338487_display)) {
@@ -48,21 +43,39 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
if (IS_ERR(obj)) {
drm_err(&xe->drm, "failed to allocate framebuffer (%pe)\n", obj);
- fb = ERR_PTR(-ENOMEM);
+ return ERR_PTR(-ENOMEM);
+ }
+
+ return &obj->ttm.base;
+}
+
+struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
+ struct drm_mode_fb_cmd2 *mode_cmd)
+{
+ struct drm_framebuffer *fb;
+ struct drm_gem_object *obj;
+ int size;
+
+ size = mode_cmd->pitches[0] * mode_cmd->height;
+ size = PAGE_ALIGN(size);
+
+ obj = intel_fbdev_fb_bo_create(drm, size);
+ if (IS_ERR(obj)) {
+ fb = ERR_CAST(obj);
goto err;
}
- fb = intel_framebuffer_create(&obj->ttm.base,
+ fb = intel_framebuffer_create(obj,
drm_get_format_info(drm,
mode_cmd->pixel_format,
mode_cmd->modifier[0]),
mode_cmd);
if (IS_ERR(fb)) {
- xe_bo_unpin_map_no_vm(obj);
+ xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
goto err;
}
- drm_gem_object_put(&obj->ttm.base);
+ drm_gem_object_put(obj);
return to_intel_framebuffer(fb);
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 06/10] drm/xe/fbdev: abstract bo creation
2025-09-18 8:40 ` [PATCH v2 06/10] drm/xe/fbdev: " Jani Nikula
@ 2025-09-18 17:42 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:42 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:56AM +0300, Jani Nikula wrote:
> Separate fbdev bo creation into a separate function
> intel_fbdev_fb_bo_create().
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 33 ++++++++++++++-------
> 1 file changed, 23 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index 8eaf1cc7fdf9..48225062211c 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -15,16 +15,11 @@
>
> #include <generated/xe_wa_oob.h>
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_mode_fb_cmd2 *mode_cmd)
> +struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
> {
> - struct drm_framebuffer *fb;
> struct xe_device *xe = to_xe_device(drm);
> struct xe_bo *obj;
> - int size;
>
> - size = mode_cmd->pitches[0] * mode_cmd->height;
> - size = PAGE_ALIGN(size);
> obj = ERR_PTR(-ENODEV);
>
> if (!IS_DGFX(xe) && !XE_GT_WA(xe_root_mmio_gt(xe), 22019338487_display)) {
> @@ -48,21 +43,39 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
>
> if (IS_ERR(obj)) {
> drm_err(&xe->drm, "failed to allocate framebuffer (%pe)\n", obj);
> - fb = ERR_PTR(-ENOMEM);
> + return ERR_PTR(-ENOMEM);
> + }
> +
> + return &obj->ttm.base;
> +}
> +
> +struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> + struct drm_mode_fb_cmd2 *mode_cmd)
> +{
> + struct drm_framebuffer *fb;
> + struct drm_gem_object *obj;
> + int size;
> +
> + size = mode_cmd->pitches[0] * mode_cmd->height;
> + size = PAGE_ALIGN(size);
> +
> + obj = intel_fbdev_fb_bo_create(drm, size);
> + if (IS_ERR(obj)) {
> + fb = ERR_CAST(obj);
> goto err;
> }
>
> - fb = intel_framebuffer_create(&obj->ttm.base,
> + fb = intel_framebuffer_create(obj,
> drm_get_format_info(drm,
> mode_cmd->pixel_format,
> mode_cmd->modifier[0]),
> mode_cmd);
> if (IS_ERR(fb)) {
> - xe_bo_unpin_map_no_vm(obj);
> + xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
> goto err;
> }
>
> - drm_gem_object_put(&obj->ttm.base);
> + drm_gem_object_put(obj);
>
> return to_intel_framebuffer(fb);
>
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 07/10] drm/{i915, xe}/fbdev: add intel_fbdev_fb_bo_destroy()
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (5 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 06/10] drm/xe/fbdev: " Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:43 ` [PATCH v2 07/10] drm/{i915,xe}/fbdev: " Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 08/10] drm/{i915,xe}/fbdev: deduplicate fbdev creation Jani Nikula
` (5 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
i915 and xe do different things on the failure path; i915 calls
drm_gem_object_put() while xe calls xe_bo_unpin_map_no_vm(). Add a
helper to enable further refactoring.
v2: Call drm_gem_object_put() on intel_fbdev_fb_bo_destroy()
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 7 ++++++-
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 1 +
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 7 ++++++-
3 files changed, 13 insertions(+), 2 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index bfd05fd34348..a7dab8cd3aa2 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -46,6 +46,11 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
return &obj->base;
}
+void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
+{
+ drm_gem_object_put(obj);
+}
+
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_mode_fb_cmd2 *mode_cmd)
{
@@ -68,7 +73,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
mode_cmd->modifier[0]),
mode_cmd);
if (IS_ERR(fb)) {
- drm_gem_object_put(obj);
+ intel_fbdev_fb_bo_destroy(obj);
goto err;
}
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index 6a4ba40d5831..8b6214b0ad0e 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -14,6 +14,7 @@ struct i915_vma;
struct intel_display;
struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
+void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_mode_fb_cmd2 *mode_cmd);
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index 48225062211c..defbab3df55b 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -49,6 +49,11 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
return &obj->ttm.base;
}
+void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
+{
+ xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
+}
+
struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
struct drm_mode_fb_cmd2 *mode_cmd)
{
@@ -71,7 +76,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
mode_cmd->modifier[0]),
mode_cmd);
if (IS_ERR(fb)) {
- xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
+ intel_fbdev_fb_bo_destroy(obj);
goto err;
}
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 07/10] drm/{i915,xe}/fbdev: add intel_fbdev_fb_bo_destroy()
2025-09-18 8:40 ` [PATCH v2 07/10] drm/{i915, xe}/fbdev: add intel_fbdev_fb_bo_destroy() Jani Nikula
@ 2025-09-18 17:43 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:43 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:57AM +0300, Jani Nikula wrote:
> i915 and xe do different things on the failure path; i915 calls
> drm_gem_object_put() while xe calls xe_bo_unpin_map_no_vm(). Add a
> helper to enable further refactoring.
>
> v2: Call drm_gem_object_put() on intel_fbdev_fb_bo_destroy()
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 7 ++++++-
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 1 +
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 7 ++++++-
> 3 files changed, 13 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index bfd05fd34348..a7dab8cd3aa2 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -46,6 +46,11 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
> return &obj->base;
> }
>
> +void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> +{
> + drm_gem_object_put(obj);
> +}
> +
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_mode_fb_cmd2 *mode_cmd)
> {
> @@ -68,7 +73,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> mode_cmd->modifier[0]),
> mode_cmd);
> if (IS_ERR(fb)) {
> - drm_gem_object_put(obj);
> + intel_fbdev_fb_bo_destroy(obj);
> goto err;
> }
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index 6a4ba40d5831..8b6214b0ad0e 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -14,6 +14,7 @@ struct i915_vma;
> struct intel_display;
>
> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
> +void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_mode_fb_cmd2 *mode_cmd);
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index 48225062211c..defbab3df55b 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -49,6 +49,11 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
> return &obj->ttm.base;
> }
>
> +void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> +{
> + xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
> +}
> +
> struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> struct drm_mode_fb_cmd2 *mode_cmd)
> {
> @@ -71,7 +76,7 @@ struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> mode_cmd->modifier[0]),
> mode_cmd);
> if (IS_ERR(fb)) {
> - xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
> + intel_fbdev_fb_bo_destroy(obj);
> goto err;
> }
>
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 08/10] drm/{i915,xe}/fbdev: deduplicate fbdev creation
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (6 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 07/10] drm/{i915, xe}/fbdev: add intel_fbdev_fb_bo_destroy() Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:44 ` Ville Syrjälä
2025-09-18 8:40 ` [PATCH v2 09/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_fill_info() Jani Nikula
` (4 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
With the bo creation helper in place, we can lift
intel_framebuffer_create() part to common code.
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev.c | 31 ++++++++++++++--
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 34 ------------------
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 2 --
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 35 -------------------
4 files changed, 28 insertions(+), 74 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
index e46c08762b84..4bc9a053ca40 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
@@ -227,13 +227,38 @@ __intel_fbdev_fb_alloc(struct intel_display *display,
struct drm_fb_helper_surface_size *sizes)
{
struct drm_mode_fb_cmd2 mode_cmd = {};
- struct intel_framebuffer *fb;
+ struct drm_framebuffer *fb;
+ struct drm_gem_object *obj;
+ int size;
intel_fbdev_fill_mode_cmd(sizes, &mode_cmd);
- fb = intel_fbdev_fb_alloc(display->drm, &mode_cmd);
+ size = mode_cmd.pitches[0] * mode_cmd.height;
+ size = PAGE_ALIGN(size);
+
+ obj = intel_fbdev_fb_bo_create(display->drm, size);
+ if (IS_ERR(obj)) {
+ fb = ERR_CAST(obj);
+ goto err;
+ }
+
+ fb = intel_framebuffer_create(obj,
+ drm_get_format_info(display->drm,
+ mode_cmd.pixel_format,
+ mode_cmd.modifier[0]),
+ &mode_cmd);
+ if (IS_ERR(fb)) {
+ intel_fbdev_fb_bo_destroy(obj);
+ goto err;
+ }
+
+ drm_gem_object_put(obj);
+
+ return to_intel_framebuffer(fb);
+
+err:
+ return ERR_CAST(fb);
- return fb;
}
int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index a7dab8cd3aa2..c802a4b2bfc7 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -10,7 +10,6 @@
#include "i915_drv.h"
#include "intel_display_core.h"
#include "intel_display_types.h"
-#include "intel_fb.h"
#include "intel_fbdev_fb.h"
struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
@@ -51,39 +50,6 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
drm_gem_object_put(obj);
}
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_mode_fb_cmd2 *mode_cmd)
-{
- struct drm_framebuffer *fb;
- struct drm_gem_object *obj;
- int size;
-
- size = mode_cmd->pitches[0] * mode_cmd->height;
- size = PAGE_ALIGN(size);
-
- obj = intel_fbdev_fb_bo_create(drm, size);
- if (IS_ERR(obj)) {
- fb = ERR_CAST(obj);
- goto err;
- }
-
- fb = intel_framebuffer_create(obj,
- drm_get_format_info(drm,
- mode_cmd->pixel_format,
- mode_cmd->modifier[0]),
- mode_cmd);
- if (IS_ERR(fb)) {
- intel_fbdev_fb_bo_destroy(obj);
- goto err;
- }
-
- drm_gem_object_put(obj);
-
- return to_intel_framebuffer(fb);
-err:
- return ERR_CAST(fb);
-}
-
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
struct drm_gem_object *_obj, struct i915_vma *vma)
{
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index 8b6214b0ad0e..3b7b59d664b5 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -15,8 +15,6 @@ struct intel_display;
struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_mode_fb_cmd2 *mode_cmd);
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
struct drm_gem_object *obj, struct i915_vma *vma);
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index defbab3df55b..37681503edb1 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -7,7 +7,6 @@
#include "intel_display_core.h"
#include "intel_display_types.h"
-#include "intel_fb.h"
#include "intel_fbdev_fb.h"
#include "xe_bo.h"
#include "xe_ttm_stolen_mgr.h"
@@ -54,40 +53,6 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
}
-struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
- struct drm_mode_fb_cmd2 *mode_cmd)
-{
- struct drm_framebuffer *fb;
- struct drm_gem_object *obj;
- int size;
-
- size = mode_cmd->pitches[0] * mode_cmd->height;
- size = PAGE_ALIGN(size);
-
- obj = intel_fbdev_fb_bo_create(drm, size);
- if (IS_ERR(obj)) {
- fb = ERR_CAST(obj);
- goto err;
- }
-
- fb = intel_framebuffer_create(obj,
- drm_get_format_info(drm,
- mode_cmd->pixel_format,
- mode_cmd->modifier[0]),
- mode_cmd);
- if (IS_ERR(fb)) {
- intel_fbdev_fb_bo_destroy(obj);
- goto err;
- }
-
- drm_gem_object_put(obj);
-
- return to_intel_framebuffer(fb);
-
-err:
- return ERR_CAST(fb);
-}
-
int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
struct drm_gem_object *_obj, struct i915_vma *vma)
{
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 08/10] drm/{i915,xe}/fbdev: deduplicate fbdev creation
2025-09-18 8:40 ` [PATCH v2 08/10] drm/{i915,xe}/fbdev: deduplicate fbdev creation Jani Nikula
@ 2025-09-18 17:44 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:44 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:58AM +0300, Jani Nikula wrote:
> With the bo creation helper in place, we can lift
> intel_framebuffer_create() part to common code.
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev.c | 31 ++++++++++++++--
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 34 ------------------
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 2 --
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 35 -------------------
> 4 files changed, 28 insertions(+), 74 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
> index e46c08762b84..4bc9a053ca40 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
> @@ -227,13 +227,38 @@ __intel_fbdev_fb_alloc(struct intel_display *display,
> struct drm_fb_helper_surface_size *sizes)
> {
> struct drm_mode_fb_cmd2 mode_cmd = {};
> - struct intel_framebuffer *fb;
> + struct drm_framebuffer *fb;
> + struct drm_gem_object *obj;
> + int size;
>
> intel_fbdev_fill_mode_cmd(sizes, &mode_cmd);
>
> - fb = intel_fbdev_fb_alloc(display->drm, &mode_cmd);
> + size = mode_cmd.pitches[0] * mode_cmd.height;
> + size = PAGE_ALIGN(size);
> +
> + obj = intel_fbdev_fb_bo_create(display->drm, size);
> + if (IS_ERR(obj)) {
> + fb = ERR_CAST(obj);
> + goto err;
> + }
> +
> + fb = intel_framebuffer_create(obj,
> + drm_get_format_info(display->drm,
> + mode_cmd.pixel_format,
> + mode_cmd.modifier[0]),
> + &mode_cmd);
> + if (IS_ERR(fb)) {
> + intel_fbdev_fb_bo_destroy(obj);
> + goto err;
> + }
> +
> + drm_gem_object_put(obj);
> +
> + return to_intel_framebuffer(fb);
> +
> +err:
> + return ERR_CAST(fb);
>
> - return fb;
> }
>
> int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index a7dab8cd3aa2..c802a4b2bfc7 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -10,7 +10,6 @@
> #include "i915_drv.h"
> #include "intel_display_core.h"
> #include "intel_display_types.h"
> -#include "intel_fb.h"
> #include "intel_fbdev_fb.h"
>
> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
> @@ -51,39 +50,6 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> drm_gem_object_put(obj);
> }
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_mode_fb_cmd2 *mode_cmd)
> -{
> - struct drm_framebuffer *fb;
> - struct drm_gem_object *obj;
> - int size;
> -
> - size = mode_cmd->pitches[0] * mode_cmd->height;
> - size = PAGE_ALIGN(size);
> -
> - obj = intel_fbdev_fb_bo_create(drm, size);
> - if (IS_ERR(obj)) {
> - fb = ERR_CAST(obj);
> - goto err;
> - }
> -
> - fb = intel_framebuffer_create(obj,
> - drm_get_format_info(drm,
> - mode_cmd->pixel_format,
> - mode_cmd->modifier[0]),
> - mode_cmd);
> - if (IS_ERR(fb)) {
> - intel_fbdev_fb_bo_destroy(obj);
> - goto err;
> - }
> -
> - drm_gem_object_put(obj);
> -
> - return to_intel_framebuffer(fb);
> -err:
> - return ERR_CAST(fb);
> -}
> -
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> struct drm_gem_object *_obj, struct i915_vma *vma)
> {
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index 8b6214b0ad0e..3b7b59d664b5 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -15,8 +15,6 @@ struct intel_display;
>
> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
> void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_mode_fb_cmd2 *mode_cmd);
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> struct drm_gem_object *obj, struct i915_vma *vma);
>
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index defbab3df55b..37681503edb1 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -7,7 +7,6 @@
>
> #include "intel_display_core.h"
> #include "intel_display_types.h"
> -#include "intel_fb.h"
> #include "intel_fbdev_fb.h"
> #include "xe_bo.h"
> #include "xe_ttm_stolen_mgr.h"
> @@ -54,40 +53,6 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
> }
>
> -struct intel_framebuffer *intel_fbdev_fb_alloc(struct drm_device *drm,
> - struct drm_mode_fb_cmd2 *mode_cmd)
> -{
> - struct drm_framebuffer *fb;
> - struct drm_gem_object *obj;
> - int size;
> -
> - size = mode_cmd->pitches[0] * mode_cmd->height;
> - size = PAGE_ALIGN(size);
> -
> - obj = intel_fbdev_fb_bo_create(drm, size);
> - if (IS_ERR(obj)) {
> - fb = ERR_CAST(obj);
> - goto err;
> - }
> -
> - fb = intel_framebuffer_create(obj,
> - drm_get_format_info(drm,
> - mode_cmd->pixel_format,
> - mode_cmd->modifier[0]),
> - mode_cmd);
> - if (IS_ERR(fb)) {
> - intel_fbdev_fb_bo_destroy(obj);
> - goto err;
> - }
> -
> - drm_gem_object_put(obj);
> -
> - return to_intel_framebuffer(fb);
> -
> -err:
> - return ERR_CAST(fb);
> -}
> -
> int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> struct drm_gem_object *_obj, struct i915_vma *vma)
> {
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 09/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_fill_info()
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (7 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 08/10] drm/{i915,xe}/fbdev: deduplicate fbdev creation Jani Nikula
@ 2025-09-18 8:40 ` Jani Nikula
2025-09-18 17:45 ` [PATCH v2 09/10] drm/{i915,xe}/fbdev: " Ville Syrjälä
2025-09-18 8:41 ` [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code Jani Nikula
` (3 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:40 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
This code is in fact driver core rather than display specific. Pass
struct drm_device instead of struct intel_display.
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev.c | 2 +-
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 6 +++---
drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 3 +--
drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 6 ++----
4 files changed, 7 insertions(+), 10 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
index 4bc9a053ca40..3fbdf75415cc 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
@@ -332,7 +332,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
obj = intel_fb_bo(&fb->base);
- ret = intel_fbdev_fb_fill_info(display, info, obj, vma);
+ ret = intel_fbdev_fb_fill_info(display->drm, info, obj, vma);
if (ret)
goto out_unpin;
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index c802a4b2bfc7..8af409bff0f0 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -50,10 +50,10 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
drm_gem_object_put(obj);
}
-int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
+int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
struct drm_gem_object *_obj, struct i915_vma *vma)
{
- struct drm_i915_private *i915 = to_i915(display->drm);
+ struct drm_i915_private *i915 = to_i915(drm);
struct drm_i915_gem_object *obj = to_intel_bo(_obj);
struct i915_gem_ww_ctx ww;
void __iomem *vaddr;
@@ -85,7 +85,7 @@ int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info
vaddr = i915_vma_pin_iomap(vma);
if (IS_ERR(vaddr)) {
- drm_err(display->drm,
+ drm_err(drm,
"Failed to remap framebuffer into virtual memory (%pe)\n", vaddr);
ret = PTR_ERR(vaddr);
continue;
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
index 3b7b59d664b5..1fa44ed28543 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
@@ -11,11 +11,10 @@ struct drm_gem_object;
struct drm_mode_fb_cmd2;
struct fb_info;
struct i915_vma;
-struct intel_display;
struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
-int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
+int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
struct drm_gem_object *obj, struct i915_vma *vma);
#endif
diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
index 37681503edb1..35a5b07eeba4 100644
--- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
@@ -5,8 +5,6 @@
#include <linux/fb.h>
-#include "intel_display_core.h"
-#include "intel_display_types.h"
#include "intel_fbdev_fb.h"
#include "xe_bo.h"
#include "xe_ttm_stolen_mgr.h"
@@ -53,11 +51,11 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
}
-int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
+int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
struct drm_gem_object *_obj, struct i915_vma *vma)
{
struct xe_bo *obj = gem_to_xe_bo(_obj);
- struct pci_dev *pdev = to_pci_dev(display->drm->dev);
+ struct pci_dev *pdev = to_pci_dev(drm->dev);
if (!(obj->flags & XE_BO_FLAG_SYSTEM)) {
if (obj->flags & XE_BO_FLAG_STOLEN)
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 09/10] drm/{i915,xe}/fbdev: pass struct drm_device to intel_fbdev_fb_fill_info()
2025-09-18 8:40 ` [PATCH v2 09/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_fill_info() Jani Nikula
@ 2025-09-18 17:45 ` Ville Syrjälä
0 siblings, 0 replies; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:45 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:40:59AM +0300, Jani Nikula wrote:
> This code is in fact driver core rather than display specific. Pass
> struct drm_device instead of struct intel_display.
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev.c | 2 +-
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 6 +++---
> drivers/gpu/drm/i915/display/intel_fbdev_fb.h | 3 +--
> drivers/gpu/drm/xe/display/intel_fbdev_fb.c | 6 ++----
> 4 files changed, 7 insertions(+), 10 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
> index 4bc9a053ca40..3fbdf75415cc 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
> @@ -332,7 +332,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
>
> obj = intel_fb_bo(&fb->base);
>
> - ret = intel_fbdev_fb_fill_info(display, info, obj, vma);
> + ret = intel_fbdev_fb_fill_info(display->drm, info, obj, vma);
> if (ret)
> goto out_unpin;
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index c802a4b2bfc7..8af409bff0f0 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -50,10 +50,10 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> drm_gem_object_put(obj);
> }
>
> -int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> +int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
> struct drm_gem_object *_obj, struct i915_vma *vma)
> {
> - struct drm_i915_private *i915 = to_i915(display->drm);
> + struct drm_i915_private *i915 = to_i915(drm);
> struct drm_i915_gem_object *obj = to_intel_bo(_obj);
> struct i915_gem_ww_ctx ww;
> void __iomem *vaddr;
> @@ -85,7 +85,7 @@ int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info
>
> vaddr = i915_vma_pin_iomap(vma);
> if (IS_ERR(vaddr)) {
> - drm_err(display->drm,
> + drm_err(drm,
> "Failed to remap framebuffer into virtual memory (%pe)\n", vaddr);
> ret = PTR_ERR(vaddr);
> continue;
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> index 3b7b59d664b5..1fa44ed28543 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.h
> @@ -11,11 +11,10 @@ struct drm_gem_object;
> struct drm_mode_fb_cmd2;
> struct fb_info;
> struct i915_vma;
> -struct intel_display;
>
> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size);
> void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj);
> -int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> +int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
> struct drm_gem_object *obj, struct i915_vma *vma);
>
> #endif
> diff --git a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> index 37681503edb1..35a5b07eeba4 100644
> --- a/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/xe/display/intel_fbdev_fb.c
> @@ -5,8 +5,6 @@
>
> #include <linux/fb.h>
>
> -#include "intel_display_core.h"
> -#include "intel_display_types.h"
> #include "intel_fbdev_fb.h"
> #include "xe_bo.h"
> #include "xe_ttm_stolen_mgr.h"
> @@ -53,11 +51,11 @@ void intel_fbdev_fb_bo_destroy(struct drm_gem_object *obj)
> xe_bo_unpin_map_no_vm(gem_to_xe_bo(obj));
> }
>
> -int intel_fbdev_fb_fill_info(struct intel_display *display, struct fb_info *info,
> +int intel_fbdev_fb_fill_info(struct drm_device *drm, struct fb_info *info,
> struct drm_gem_object *_obj, struct i915_vma *vma)
> {
> struct xe_bo *obj = gem_to_xe_bo(_obj);
> - struct pci_dev *pdev = to_pci_dev(display->drm->dev);
> + struct pci_dev *pdev = to_pci_dev(drm->dev);
>
> if (!(obj->flags & XE_BO_FLAG_SYSTEM)) {
> if (obj->flags & XE_BO_FLAG_STOLEN)
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (8 preceding siblings ...)
2025-09-18 8:40 ` [PATCH v2 09/10] drm/{i915, xe}/fbdev: pass struct drm_device to intel_fbdev_fb_fill_info() Jani Nikula
@ 2025-09-18 8:41 ` Jani Nikula
2025-09-18 17:50 ` Ville Syrjälä
2025-09-18 8:59 ` ✓ CI.KUnit: success for drm/{i915,xe}/fbdev: refactor (rev2) Patchwork
` (2 subsequent siblings)
12 siblings, 1 reply; 25+ messages in thread
From: Jani Nikula @ 2025-09-18 8:41 UTC (permalink / raw)
To: intel-gfx, intel-xe; +Cc: jani.nikula, ville.syrjala
This code is in fact i915 driver core rather than display specific. Stop
using struct intel_display, and drop the dependency on display headers.
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 5 +----
1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
index 8af409bff0f0..56b145841473 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
@@ -8,13 +8,10 @@
#include "gem/i915_gem_lmem.h"
#include "i915_drv.h"
-#include "intel_display_core.h"
-#include "intel_display_types.h"
#include "intel_fbdev_fb.h"
struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
{
- struct intel_display *display = to_intel_display(drm);
struct drm_i915_private *dev_priv = to_i915(drm);
struct drm_i915_gem_object *obj;
@@ -31,7 +28,7 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
*
* Also skip stolen on MTL as Wa_22018444074 mitigation.
*/
- if (!display->platform.meteorlake && size * 2 < dev_priv->dsm.usable_size)
+ if (!IS_METEORLAKE(dev_priv) && size * 2 < dev_priv->dsm.usable_size)
obj = i915_gem_object_create_stolen(dev_priv, size);
if (IS_ERR(obj))
obj = i915_gem_object_create_shmem(dev_priv, size);
--
2.47.3
^ permalink raw reply related [flat|nested] 25+ messages in thread* Re: [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code
2025-09-18 8:41 ` [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code Jani Nikula
@ 2025-09-18 17:50 ` Ville Syrjälä
2025-09-19 7:00 ` Jani Nikula
0 siblings, 1 reply; 25+ messages in thread
From: Ville Syrjälä @ 2025-09-18 17:50 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-gfx, intel-xe
On Thu, Sep 18, 2025 at 11:41:00AM +0300, Jani Nikula wrote:
> This code is in fact i915 driver core rather than display specific. Stop
> using struct intel_display, and drop the dependency on display headers.
>
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
> ---
> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 5 +----
> 1 file changed, 1 insertion(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> index 8af409bff0f0..56b145841473 100644
> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
> @@ -8,13 +8,10 @@
> #include "gem/i915_gem_lmem.h"
>
> #include "i915_drv.h"
> -#include "intel_display_core.h"
> -#include "intel_display_types.h"
> #include "intel_fbdev_fb.h"
>
> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
> {
> - struct intel_display *display = to_intel_display(drm);
> struct drm_i915_private *dev_priv = to_i915(drm);
> struct drm_i915_gem_object *obj;
>
> @@ -31,7 +28,7 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
> *
> * Also skip stolen on MTL as Wa_22018444074 mitigation.
> */
> - if (!display->platform.meteorlake && size * 2 < dev_priv->dsm.usable_size)
> + if (!IS_METEORLAKE(dev_priv) && size * 2 < dev_priv->dsm.usable_size)
I have some old stuff [1] to rework the logic around stolen vs. not
usage here. But I suppose I'll need to rethink some of it if/when I
find the time to revisit that stuff...
In the meantine
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
[1] https://patchwork.freedesktop.org/series/135800/
> obj = i915_gem_object_create_stolen(dev_priv, size);
> if (IS_ERR(obj))
> obj = i915_gem_object_create_shmem(dev_priv, size);
> --
> 2.47.3
--
Ville Syrjälä
Intel
^ permalink raw reply [flat|nested] 25+ messages in thread* Re: [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code
2025-09-18 17:50 ` Ville Syrjälä
@ 2025-09-19 7:00 ` Jani Nikula
0 siblings, 0 replies; 25+ messages in thread
From: Jani Nikula @ 2025-09-19 7:00 UTC (permalink / raw)
To: Ville Syrjälä; +Cc: intel-gfx, intel-xe
On Thu, 18 Sep 2025, Ville Syrjälä <ville.syrjala@linux.intel.com> wrote:
> On Thu, Sep 18, 2025 at 11:41:00AM +0300, Jani Nikula wrote:
>> This code is in fact i915 driver core rather than display specific. Stop
>> using struct intel_display, and drop the dependency on display headers.
>>
>> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
>> ---
>> drivers/gpu/drm/i915/display/intel_fbdev_fb.c | 5 +----
>> 1 file changed, 1 insertion(+), 4 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
>> index 8af409bff0f0..56b145841473 100644
>> --- a/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
>> +++ b/drivers/gpu/drm/i915/display/intel_fbdev_fb.c
>> @@ -8,13 +8,10 @@
>> #include "gem/i915_gem_lmem.h"
>>
>> #include "i915_drv.h"
>> -#include "intel_display_core.h"
>> -#include "intel_display_types.h"
>> #include "intel_fbdev_fb.h"
>>
>> struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size)
>> {
>> - struct intel_display *display = to_intel_display(drm);
>> struct drm_i915_private *dev_priv = to_i915(drm);
>> struct drm_i915_gem_object *obj;
>>
>> @@ -31,7 +28,7 @@ struct drm_gem_object *intel_fbdev_fb_bo_create(struct drm_device *drm, int size
>> *
>> * Also skip stolen on MTL as Wa_22018444074 mitigation.
>> */
>> - if (!display->platform.meteorlake && size * 2 < dev_priv->dsm.usable_size)
>> + if (!IS_METEORLAKE(dev_priv) && size * 2 < dev_priv->dsm.usable_size)
>
> I have some old stuff [1] to rework the logic around stolen vs. not
> usage here. But I suppose I'll need to rethink some of it if/when I
> find the time to revisit that stuff...
>
> In the meantine
> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Thanks a bunch for the reviews, pushed the lot to din.
BR,
Jani.
>
> [1] https://patchwork.freedesktop.org/series/135800/
>
>> obj = i915_gem_object_create_stolen(dev_priv, size);
>> if (IS_ERR(obj))
>> obj = i915_gem_object_create_shmem(dev_priv, size);
>> --
>> 2.47.3
--
Jani Nikula, Intel
^ permalink raw reply [flat|nested] 25+ messages in thread
* ✓ CI.KUnit: success for drm/{i915,xe}/fbdev: refactor (rev2)
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (9 preceding siblings ...)
2025-09-18 8:41 ` [PATCH v2 10/10] drm/i915/fbdev: drop dependency on display in i915 specific code Jani Nikula
@ 2025-09-18 8:59 ` Patchwork
2025-09-18 9:33 ` ✓ Xe.CI.BAT: " Patchwork
2025-09-18 15:54 ` ✓ Xe.CI.Full: " Patchwork
12 siblings, 0 replies; 25+ messages in thread
From: Patchwork @ 2025-09-18 8:59 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-xe
== Series Details ==
Series: drm/{i915,xe}/fbdev: refactor (rev2)
URL : https://patchwork.freedesktop.org/series/153981/
State : success
== Summary ==
+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[08:58:21] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[08:58:26] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[08:58:56] Starting KUnit Kernel (1/1)...
[08:58:56] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[08:58:56] ================== guc_buf (11 subtests) ===================
[08:58:56] [PASSED] test_smallest
[08:58:56] [PASSED] test_largest
[08:58:56] [PASSED] test_granular
[08:58:56] [PASSED] test_unique
[08:58:56] [PASSED] test_overlap
[08:58:56] [PASSED] test_reusable
[08:58:56] [PASSED] test_too_big
[08:58:56] [PASSED] test_flush
[08:58:56] [PASSED] test_lookup
[08:58:56] [PASSED] test_data
[08:58:56] [PASSED] test_class
[08:58:56] ===================== [PASSED] guc_buf =====================
[08:58:56] =================== guc_dbm (7 subtests) ===================
[08:58:56] [PASSED] test_empty
[08:58:56] [PASSED] test_default
[08:58:56] ======================== test_size ========================
[08:58:56] [PASSED] 4
[08:58:56] [PASSED] 8
[08:58:56] [PASSED] 32
[08:58:56] [PASSED] 256
[08:58:56] ==================== [PASSED] test_size ====================
[08:58:56] ======================= test_reuse ========================
[08:58:56] [PASSED] 4
[08:58:56] [PASSED] 8
[08:58:56] [PASSED] 32
[08:58:56] [PASSED] 256
[08:58:56] =================== [PASSED] test_reuse ====================
[08:58:56] =================== test_range_overlap ====================
[08:58:56] [PASSED] 4
[08:58:56] [PASSED] 8
[08:58:56] [PASSED] 32
[08:58:56] [PASSED] 256
[08:58:56] =============== [PASSED] test_range_overlap ================
[08:58:56] =================== test_range_compact ====================
[08:58:56] [PASSED] 4
[08:58:56] [PASSED] 8
[08:58:56] [PASSED] 32
[08:58:56] [PASSED] 256
[08:58:56] =============== [PASSED] test_range_compact ================
[08:58:56] ==================== test_range_spare =====================
[08:58:56] [PASSED] 4
[08:58:56] [PASSED] 8
[08:58:56] [PASSED] 32
[08:58:56] [PASSED] 256
[08:58:56] ================ [PASSED] test_range_spare =================
[08:58:56] ===================== [PASSED] guc_dbm =====================
[08:58:56] =================== guc_idm (6 subtests) ===================
[08:58:56] [PASSED] bad_init
[08:58:56] [PASSED] no_init
[08:58:56] [PASSED] init_fini
[08:58:56] [PASSED] check_used
[08:58:56] [PASSED] check_quota
[08:58:56] [PASSED] check_all
[08:58:56] ===================== [PASSED] guc_idm =====================
[08:58:56] ================== no_relay (3 subtests) ===================
[08:58:56] [PASSED] xe_drops_guc2pf_if_not_ready
[08:58:56] [PASSED] xe_drops_guc2vf_if_not_ready
[08:58:56] [PASSED] xe_rejects_send_if_not_ready
[08:58:56] ==================== [PASSED] no_relay =====================
[08:58:56] ================== pf_relay (14 subtests) ==================
[08:58:56] [PASSED] pf_rejects_guc2pf_too_short
[08:58:56] [PASSED] pf_rejects_guc2pf_too_long
[08:58:56] [PASSED] pf_rejects_guc2pf_no_payload
[08:58:56] [PASSED] pf_fails_no_payload
[08:58:56] [PASSED] pf_fails_bad_origin
[08:58:56] [PASSED] pf_fails_bad_type
[08:58:56] [PASSED] pf_txn_reports_error
[08:58:56] [PASSED] pf_txn_sends_pf2guc
[08:58:56] [PASSED] pf_sends_pf2guc
[08:58:56] [SKIPPED] pf_loopback_nop
[08:58:56] [SKIPPED] pf_loopback_echo
[08:58:56] [SKIPPED] pf_loopback_fail
[08:58:56] [SKIPPED] pf_loopback_busy
[08:58:56] [SKIPPED] pf_loopback_retry
[08:58:56] ==================== [PASSED] pf_relay =====================
[08:58:56] ================== vf_relay (3 subtests) ===================
[08:58:56] [PASSED] vf_rejects_guc2vf_too_short
[08:58:56] [PASSED] vf_rejects_guc2vf_too_long
[08:58:56] [PASSED] vf_rejects_guc2vf_no_payload
[08:58:56] ==================== [PASSED] vf_relay =====================
[08:58:56] ===================== lmtt (1 subtest) =====================
[08:58:56] ======================== test_ops =========================
[08:58:56] [PASSED] 2-level
[08:58:56] [PASSED] multi-level
[08:58:56] ==================== [PASSED] test_ops =====================
[08:58:56] ====================== [PASSED] lmtt =======================
[08:58:56] ================= pf_service (11 subtests) =================
[08:58:56] [PASSED] pf_negotiate_any
[08:58:56] [PASSED] pf_negotiate_base_match
[08:58:56] [PASSED] pf_negotiate_base_newer
[08:58:56] [PASSED] pf_negotiate_base_next
[08:58:56] [SKIPPED] pf_negotiate_base_older
[08:58:56] [PASSED] pf_negotiate_base_prev
[08:58:56] [PASSED] pf_negotiate_latest_match
[08:58:56] [PASSED] pf_negotiate_latest_newer
[08:58:56] [PASSED] pf_negotiate_latest_next
[08:58:56] [SKIPPED] pf_negotiate_latest_older
[08:58:56] [SKIPPED] pf_negotiate_latest_prev
[08:58:56] =================== [PASSED] pf_service ====================
[08:58:56] ================= xe_guc_g2g (2 subtests) ==================
[08:58:56] ============== xe_live_guc_g2g_kunit_default ==============
[08:58:56] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[08:58:56] ============== xe_live_guc_g2g_kunit_allmem ===============
[08:58:56] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[08:58:56] =================== [SKIPPED] xe_guc_g2g ===================
[08:58:56] =================== xe_mocs (2 subtests) ===================
[08:58:56] ================ xe_live_mocs_kernel_kunit ================
[08:58:56] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[08:58:56] ================ xe_live_mocs_reset_kunit =================
[08:58:56] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[08:58:56] ==================== [SKIPPED] xe_mocs =====================
[08:58:56] ================= xe_migrate (2 subtests) ==================
[08:58:56] ================= xe_migrate_sanity_kunit =================
[08:58:56] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[08:58:56] ================== xe_validate_ccs_kunit ==================
[08:58:56] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[08:58:56] =================== [SKIPPED] xe_migrate ===================
[08:58:56] ================== xe_dma_buf (1 subtest) ==================
[08:58:56] ==================== xe_dma_buf_kunit =====================
[08:58:56] ================ [SKIPPED] xe_dma_buf_kunit ================
[08:58:56] =================== [SKIPPED] xe_dma_buf ===================
[08:58:56] ================= xe_bo_shrink (1 subtest) =================
[08:58:56] =================== xe_bo_shrink_kunit ====================
[08:58:56] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[08:58:56] ================== [SKIPPED] xe_bo_shrink ==================
[08:58:56] ==================== xe_bo (2 subtests) ====================
[08:58:56] ================== xe_ccs_migrate_kunit ===================
[08:58:56] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[08:58:56] ==================== xe_bo_evict_kunit ====================
[08:58:56] =============== [SKIPPED] xe_bo_evict_kunit ================
[08:58:56] ===================== [SKIPPED] xe_bo ======================
[08:58:56] ==================== args (11 subtests) ====================
[08:58:56] [PASSED] count_args_test
[08:58:56] [PASSED] call_args_example
[08:58:56] [PASSED] call_args_test
[08:58:56] [PASSED] drop_first_arg_example
[08:58:56] [PASSED] drop_first_arg_test
[08:58:56] [PASSED] first_arg_example
[08:58:56] [PASSED] first_arg_test
[08:58:56] [PASSED] last_arg_example
[08:58:56] [PASSED] last_arg_test
[08:58:56] [PASSED] pick_arg_example
[08:58:56] [PASSED] sep_comma_example
[08:58:56] ====================== [PASSED] args =======================
[08:58:56] =================== xe_pci (3 subtests) ====================
[08:58:56] ==================== check_graphics_ip ====================
[08:58:56] [PASSED] 12.00 Xe_LP
[08:58:56] [PASSED] 12.10 Xe_LP+
[08:58:56] [PASSED] 12.55 Xe_HPG
[08:58:56] [PASSED] 12.60 Xe_HPC
[08:58:56] [PASSED] 12.70 Xe_LPG
[08:58:56] [PASSED] 12.71 Xe_LPG
[08:58:56] [PASSED] 12.74 Xe_LPG+
[08:58:56] [PASSED] 20.01 Xe2_HPG
[08:58:56] [PASSED] 20.02 Xe2_HPG
[08:58:56] [PASSED] 20.04 Xe2_LPG
[08:58:56] [PASSED] 30.00 Xe3_LPG
[08:58:56] [PASSED] 30.01 Xe3_LPG
[08:58:56] [PASSED] 30.03 Xe3_LPG
[08:58:56] ================ [PASSED] check_graphics_ip ================
[08:58:56] ===================== check_media_ip ======================
[08:58:56] [PASSED] 12.00 Xe_M
[08:58:56] [PASSED] 12.55 Xe_HPM
[08:58:56] [PASSED] 13.00 Xe_LPM+
[08:58:56] [PASSED] 13.01 Xe2_HPM
[08:58:56] [PASSED] 20.00 Xe2_LPM
[08:58:56] [PASSED] 30.00 Xe3_LPM
[08:58:56] [PASSED] 30.02 Xe3_LPM
[08:58:56] ================= [PASSED] check_media_ip ==================
[08:58:56] ================= check_platform_gt_count =================
[08:58:56] [PASSED] 0x9A60 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A68 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A70 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A40 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A49 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A59 (TIGERLAKE)
[08:58:56] [PASSED] 0x9A78 (TIGERLAKE)
[08:58:56] [PASSED] 0x9AC0 (TIGERLAKE)
[08:58:56] [PASSED] 0x9AC9 (TIGERLAKE)
[08:58:56] [PASSED] 0x9AD9 (TIGERLAKE)
[08:58:56] [PASSED] 0x9AF8 (TIGERLAKE)
[08:58:56] [PASSED] 0x4C80 (ROCKETLAKE)
[08:58:56] [PASSED] 0x4C8A (ROCKETLAKE)
[08:58:56] [PASSED] 0x4C8B (ROCKETLAKE)
[08:58:56] [PASSED] 0x4C8C (ROCKETLAKE)
[08:58:56] [PASSED] 0x4C90 (ROCKETLAKE)
[08:58:56] [PASSED] 0x4C9A (ROCKETLAKE)
[08:58:56] [PASSED] 0x4680 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4682 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4688 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x468A (ALDERLAKE_S)
[08:58:56] [PASSED] 0x468B (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4690 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4692 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4693 (ALDERLAKE_S)
[08:58:56] [PASSED] 0x46A0 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46A1 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46A2 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46A3 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46A6 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46A8 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46AA (ALDERLAKE_P)
[08:58:56] [PASSED] 0x462A (ALDERLAKE_P)
[08:58:56] [PASSED] 0x4626 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x4628 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46B0 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46B1 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46B2 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46B3 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46C0 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46C1 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46C2 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46C3 (ALDERLAKE_P)
[08:58:56] [PASSED] 0x46D0 (ALDERLAKE_N)
[08:58:56] [PASSED] 0x46D1 (ALDERLAKE_N)
[08:58:56] [PASSED] 0x46D2 (ALDERLAKE_N)
[08:58:56] [PASSED] 0x46D3 (ALDERLAKE_N)
[08:58:56] [PASSED] 0x46D4 (ALDERLAKE_N)
[08:58:56] [PASSED] 0xA721 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7A1 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7A9 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7AC (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7AD (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA720 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7A0 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7A8 (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7AA (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA7AB (ALDERLAKE_P)
[08:58:56] [PASSED] 0xA780 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA781 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA782 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA783 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA788 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA789 (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA78A (ALDERLAKE_S)
[08:58:56] [PASSED] 0xA78B (ALDERLAKE_S)
[08:58:56] [PASSED] 0x4905 (DG1)
[08:58:56] [PASSED] 0x4906 (DG1)
[08:58:56] [PASSED] 0x4907 (DG1)
[08:58:56] [PASSED] 0x4908 (DG1)
[08:58:56] [PASSED] 0x4909 (DG1)
[08:58:56] [PASSED] 0x56C0 (DG2)
[08:58:56] [PASSED] 0x56C2 (DG2)
[08:58:56] [PASSED] 0x56C1 (DG2)
[08:58:56] [PASSED] 0x7D51 (METEORLAKE)
[08:58:56] [PASSED] 0x7DD1 (METEORLAKE)
[08:58:56] [PASSED] 0x7D41 (METEORLAKE)
[08:58:56] [PASSED] 0x7D67 (METEORLAKE)
[08:58:56] [PASSED] 0xB640 (METEORLAKE)
[08:58:56] [PASSED] 0x56A0 (DG2)
[08:58:56] [PASSED] 0x56A1 (DG2)
[08:58:56] [PASSED] 0x56A2 (DG2)
[08:58:56] [PASSED] 0x56BE (DG2)
[08:58:56] [PASSED] 0x56BF (DG2)
[08:58:56] [PASSED] 0x5690 (DG2)
[08:58:56] [PASSED] 0x5691 (DG2)
[08:58:56] [PASSED] 0x5692 (DG2)
[08:58:56] [PASSED] 0x56A5 (DG2)
[08:58:56] [PASSED] 0x56A6 (DG2)
[08:58:56] [PASSED] 0x56B0 (DG2)
[08:58:56] [PASSED] 0x56B1 (DG2)
[08:58:56] [PASSED] 0x56BA (DG2)
[08:58:56] [PASSED] 0x56BB (DG2)
[08:58:56] [PASSED] 0x56BC (DG2)
[08:58:56] [PASSED] 0x56BD (DG2)
[08:58:56] [PASSED] 0x5693 (DG2)
[08:58:56] [PASSED] 0x5694 (DG2)
[08:58:56] [PASSED] 0x5695 (DG2)
[08:58:56] [PASSED] 0x56A3 (DG2)
[08:58:56] [PASSED] 0x56A4 (DG2)
[08:58:56] [PASSED] 0x56B2 (DG2)
[08:58:56] [PASSED] 0x56B3 (DG2)
[08:58:56] [PASSED] 0x5696 (DG2)
[08:58:56] [PASSED] 0x5697 (DG2)
[08:58:56] [PASSED] 0xB69 (PVC)
[08:58:56] [PASSED] 0xB6E (PVC)
[08:58:56] [PASSED] 0xBD4 (PVC)
[08:58:56] [PASSED] 0xBD5 (PVC)
[08:58:56] [PASSED] 0xBD6 (PVC)
[08:58:56] [PASSED] 0xBD7 (PVC)
[08:58:56] [PASSED] 0xBD8 (PVC)
[08:58:56] [PASSED] 0xBD9 (PVC)
[08:58:56] [PASSED] 0xBDA (PVC)
[08:58:56] [PASSED] 0xBDB (PVC)
[08:58:56] [PASSED] 0xBE0 (PVC)
[08:58:56] [PASSED] 0xBE1 (PVC)
[08:58:56] [PASSED] 0xBE5 (PVC)
[08:58:56] [PASSED] 0x7D40 (METEORLAKE)
[08:58:56] [PASSED] 0x7D45 (METEORLAKE)
[08:58:56] [PASSED] 0x7D55 (METEORLAKE)
[08:58:56] [PASSED] 0x7D60 (METEORLAKE)
[08:58:56] [PASSED] 0x7DD5 (METEORLAKE)
[08:58:56] [PASSED] 0x6420 (LUNARLAKE)
[08:58:56] [PASSED] 0x64A0 (LUNARLAKE)
[08:58:56] [PASSED] 0x64B0 (LUNARLAKE)
[08:58:56] [PASSED] 0xE202 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE209 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE20B (BATTLEMAGE)
[08:58:56] [PASSED] 0xE20C (BATTLEMAGE)
[08:58:56] [PASSED] 0xE20D (BATTLEMAGE)
[08:58:56] [PASSED] 0xE210 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE211 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE212 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE216 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE220 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE221 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE222 (BATTLEMAGE)
[08:58:56] [PASSED] 0xE223 (BATTLEMAGE)
[08:58:56] [PASSED] 0xB080 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB081 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB082 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB083 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB084 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB085 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB086 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB087 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB08F (PANTHERLAKE)
[08:58:56] [PASSED] 0xB090 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB0A0 (PANTHERLAKE)
[08:58:56] [PASSED] 0xB0B0 (PANTHERLAKE)
[08:58:56] [PASSED] 0xFD80 (PANTHERLAKE)
[08:58:56] [PASSED] 0xFD81 (PANTHERLAKE)
[08:58:56] ============= [PASSED] check_platform_gt_count =============
[08:58:56] ===================== [PASSED] xe_pci ======================
[08:58:56] =================== xe_rtp (2 subtests) ====================
[08:58:56] =============== xe_rtp_process_to_sr_tests ================
[08:58:56] [PASSED] coalesce-same-reg
[08:58:56] [PASSED] no-match-no-add
[08:58:56] [PASSED] match-or
[08:58:56] [PASSED] match-or-xfail
[08:58:56] [PASSED] no-match-no-add-multiple-rules
[08:58:56] [PASSED] two-regs-two-entries
[08:58:56] [PASSED] clr-one-set-other
[08:58:56] [PASSED] set-field
[08:58:56] [PASSED] conflict-duplicate
[08:58:56] [PASSED] conflict-not-disjoint
[08:58:56] [PASSED] conflict-reg-type
[08:58:56] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[08:58:56] ================== xe_rtp_process_tests ===================
[08:58:56] [PASSED] active1
[08:58:56] [PASSED] active2
[08:58:56] [PASSED] active-inactive
[08:58:56] [PASSED] inactive-active
[08:58:56] [PASSED] inactive-1st_or_active-inactive
[08:58:56] [PASSED] inactive-2nd_or_active-inactive
[08:58:56] [PASSED] inactive-last_or_active-inactive
[08:58:56] [PASSED] inactive-no_or_active-inactive
[08:58:56] ============== [PASSED] xe_rtp_process_tests ===============
[08:58:56] ===================== [PASSED] xe_rtp ======================
[08:58:56] ==================== xe_wa (1 subtest) =====================
[08:58:56] ======================== xe_wa_gt =========================
[08:58:56] [PASSED] TIGERLAKE B0
[08:58:56] [PASSED] DG1 A0
[08:58:56] [PASSED] DG1 B0
[08:58:56] [PASSED] ALDERLAKE_S A0
[08:58:56] [PASSED] ALDERLAKE_S B0
stty: 'standard input': Inappropriate ioctl for device
[08:58:56] [PASSED] ALDERLAKE_S C0
[08:58:56] [PASSED] ALDERLAKE_S D0
[08:58:56] [PASSED] ALDERLAKE_P A0
[08:58:56] [PASSED] ALDERLAKE_P B0
[08:58:56] [PASSED] ALDERLAKE_P C0
[08:58:56] [PASSED] ALDERLAKE_S RPLS D0
[08:58:56] [PASSED] ALDERLAKE_P RPLU E0
[08:58:56] [PASSED] DG2 G10 C0
[08:58:56] [PASSED] DG2 G11 B1
[08:58:56] [PASSED] DG2 G12 A1
[08:58:56] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[08:58:56] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[08:58:56] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[08:58:56] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[08:58:56] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[08:58:56] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[08:58:56] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[08:58:56] ==================== [PASSED] xe_wa_gt =====================
[08:58:56] ====================== [PASSED] xe_wa ======================
[08:58:56] ============================================================
[08:58:56] Testing complete. Ran 306 tests: passed: 288, skipped: 18
[08:58:56] Elapsed time: 35.104s total, 4.794s configuring, 29.943s building, 0.336s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[08:58:56] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[08:58:58] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[08:59:22] Starting KUnit Kernel (1/1)...
[08:59:22] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[08:59:22] ============ drm_test_pick_cmdline (2 subtests) ============
[08:59:22] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[08:59:22] =============== drm_test_pick_cmdline_named ===============
[08:59:22] [PASSED] NTSC
[08:59:22] [PASSED] NTSC-J
[08:59:22] [PASSED] PAL
[08:59:22] [PASSED] PAL-M
[08:59:22] =========== [PASSED] drm_test_pick_cmdline_named ===========
[08:59:22] ============== [PASSED] drm_test_pick_cmdline ==============
[08:59:22] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[08:59:22] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[08:59:22] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[08:59:22] =========== drm_validate_clone_mode (2 subtests) ===========
[08:59:22] ============== drm_test_check_in_clone_mode ===============
[08:59:22] [PASSED] in_clone_mode
[08:59:22] [PASSED] not_in_clone_mode
[08:59:22] ========== [PASSED] drm_test_check_in_clone_mode ===========
[08:59:22] =============== drm_test_check_valid_clones ===============
[08:59:22] [PASSED] not_in_clone_mode
[08:59:22] [PASSED] valid_clone
[08:59:22] [PASSED] invalid_clone
[08:59:22] =========== [PASSED] drm_test_check_valid_clones ===========
[08:59:22] ============= [PASSED] drm_validate_clone_mode =============
[08:59:22] ============= drm_validate_modeset (1 subtest) =============
[08:59:22] [PASSED] drm_test_check_connector_changed_modeset
[08:59:22] ============== [PASSED] drm_validate_modeset ===============
[08:59:22] ====== drm_test_bridge_get_current_state (2 subtests) ======
[08:59:22] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[08:59:22] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[08:59:22] ======== [PASSED] drm_test_bridge_get_current_state ========
[08:59:22] ====== drm_test_bridge_helper_reset_crtc (3 subtests) ======
[08:59:22] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[08:59:22] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[08:59:22] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[08:59:22] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[08:59:22] ============== drm_bridge_alloc (2 subtests) ===============
[08:59:22] [PASSED] drm_test_drm_bridge_alloc_basic
[08:59:22] [PASSED] drm_test_drm_bridge_alloc_get_put
[08:59:22] ================ [PASSED] drm_bridge_alloc =================
[08:59:22] ================== drm_buddy (7 subtests) ==================
[08:59:22] [PASSED] drm_test_buddy_alloc_limit
[08:59:22] [PASSED] drm_test_buddy_alloc_optimistic
[08:59:22] [PASSED] drm_test_buddy_alloc_pessimistic
[08:59:22] [PASSED] drm_test_buddy_alloc_pathological
[08:59:22] [PASSED] drm_test_buddy_alloc_contiguous
[08:59:22] [PASSED] drm_test_buddy_alloc_clear
[08:59:22] [PASSED] drm_test_buddy_alloc_range_bias
[08:59:22] ==================== [PASSED] drm_buddy ====================
[08:59:22] ============= drm_cmdline_parser (40 subtests) =============
[08:59:22] [PASSED] drm_test_cmdline_force_d_only
[08:59:22] [PASSED] drm_test_cmdline_force_D_only_dvi
[08:59:22] [PASSED] drm_test_cmdline_force_D_only_hdmi
[08:59:22] [PASSED] drm_test_cmdline_force_D_only_not_digital
[08:59:22] [PASSED] drm_test_cmdline_force_e_only
[08:59:22] [PASSED] drm_test_cmdline_res
[08:59:22] [PASSED] drm_test_cmdline_res_vesa
[08:59:22] [PASSED] drm_test_cmdline_res_vesa_rblank
[08:59:22] [PASSED] drm_test_cmdline_res_rblank
[08:59:22] [PASSED] drm_test_cmdline_res_bpp
[08:59:22] [PASSED] drm_test_cmdline_res_refresh
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[08:59:22] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[08:59:22] [PASSED] drm_test_cmdline_res_margins_force_on
[08:59:22] [PASSED] drm_test_cmdline_res_vesa_margins
[08:59:22] [PASSED] drm_test_cmdline_name
[08:59:22] [PASSED] drm_test_cmdline_name_bpp
[08:59:22] [PASSED] drm_test_cmdline_name_option
[08:59:22] [PASSED] drm_test_cmdline_name_bpp_option
[08:59:22] [PASSED] drm_test_cmdline_rotate_0
[08:59:22] [PASSED] drm_test_cmdline_rotate_90
[08:59:22] [PASSED] drm_test_cmdline_rotate_180
[08:59:22] [PASSED] drm_test_cmdline_rotate_270
[08:59:22] [PASSED] drm_test_cmdline_hmirror
[08:59:22] [PASSED] drm_test_cmdline_vmirror
[08:59:22] [PASSED] drm_test_cmdline_margin_options
[08:59:22] [PASSED] drm_test_cmdline_multiple_options
[08:59:22] [PASSED] drm_test_cmdline_bpp_extra_and_option
[08:59:22] [PASSED] drm_test_cmdline_extra_and_option
[08:59:22] [PASSED] drm_test_cmdline_freestanding_options
[08:59:22] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[08:59:22] [PASSED] drm_test_cmdline_panel_orientation
[08:59:22] ================ drm_test_cmdline_invalid =================
[08:59:22] [PASSED] margin_only
[08:59:22] [PASSED] interlace_only
[08:59:22] [PASSED] res_missing_x
[08:59:22] [PASSED] res_missing_y
[08:59:22] [PASSED] res_bad_y
[08:59:22] [PASSED] res_missing_y_bpp
[08:59:22] [PASSED] res_bad_bpp
[08:59:22] [PASSED] res_bad_refresh
[08:59:22] [PASSED] res_bpp_refresh_force_on_off
[08:59:22] [PASSED] res_invalid_mode
[08:59:22] [PASSED] res_bpp_wrong_place_mode
[08:59:22] [PASSED] name_bpp_refresh
[08:59:22] [PASSED] name_refresh
[08:59:22] [PASSED] name_refresh_wrong_mode
[08:59:22] [PASSED] name_refresh_invalid_mode
[08:59:22] [PASSED] rotate_multiple
[08:59:22] [PASSED] rotate_invalid_val
[08:59:22] [PASSED] rotate_truncated
[08:59:22] [PASSED] invalid_option
[08:59:22] [PASSED] invalid_tv_option
[08:59:22] [PASSED] truncated_tv_option
[08:59:22] ============ [PASSED] drm_test_cmdline_invalid =============
[08:59:22] =============== drm_test_cmdline_tv_options ===============
[08:59:22] [PASSED] NTSC
[08:59:22] [PASSED] NTSC_443
[08:59:22] [PASSED] NTSC_J
[08:59:22] [PASSED] PAL
[08:59:22] [PASSED] PAL_M
[08:59:22] [PASSED] PAL_N
[08:59:22] [PASSED] SECAM
[08:59:22] [PASSED] MONO_525
[08:59:22] [PASSED] MONO_625
[08:59:22] =========== [PASSED] drm_test_cmdline_tv_options ===========
[08:59:22] =============== [PASSED] drm_cmdline_parser ================
[08:59:22] ========== drmm_connector_hdmi_init (20 subtests) ==========
[08:59:22] [PASSED] drm_test_connector_hdmi_init_valid
[08:59:22] [PASSED] drm_test_connector_hdmi_init_bpc_8
[08:59:22] [PASSED] drm_test_connector_hdmi_init_bpc_10
[08:59:22] [PASSED] drm_test_connector_hdmi_init_bpc_12
[08:59:22] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[08:59:22] [PASSED] drm_test_connector_hdmi_init_bpc_null
[08:59:22] [PASSED] drm_test_connector_hdmi_init_formats_empty
[08:59:22] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[08:59:22] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[08:59:22] [PASSED] supported_formats=0x9 yuv420_allowed=1
[08:59:22] [PASSED] supported_formats=0x9 yuv420_allowed=0
[08:59:22] [PASSED] supported_formats=0x3 yuv420_allowed=1
[08:59:22] [PASSED] supported_formats=0x3 yuv420_allowed=0
[08:59:22] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[08:59:22] [PASSED] drm_test_connector_hdmi_init_null_ddc
[08:59:22] [PASSED] drm_test_connector_hdmi_init_null_product
[08:59:22] [PASSED] drm_test_connector_hdmi_init_null_vendor
[08:59:22] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[08:59:22] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[08:59:22] [PASSED] drm_test_connector_hdmi_init_product_valid
[08:59:22] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[08:59:22] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[08:59:22] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[08:59:22] ========= drm_test_connector_hdmi_init_type_valid =========
[08:59:22] [PASSED] HDMI-A
[08:59:22] [PASSED] HDMI-B
[08:59:22] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[08:59:22] ======== drm_test_connector_hdmi_init_type_invalid ========
[08:59:22] [PASSED] Unknown
[08:59:22] [PASSED] VGA
[08:59:22] [PASSED] DVI-I
[08:59:22] [PASSED] DVI-D
[08:59:22] [PASSED] DVI-A
[08:59:22] [PASSED] Composite
[08:59:22] [PASSED] SVIDEO
[08:59:22] [PASSED] LVDS
[08:59:22] [PASSED] Component
[08:59:22] [PASSED] DIN
[08:59:22] [PASSED] DP
[08:59:22] [PASSED] TV
[08:59:22] [PASSED] eDP
[08:59:22] [PASSED] Virtual
[08:59:22] [PASSED] DSI
[08:59:22] [PASSED] DPI
[08:59:22] [PASSED] Writeback
[08:59:22] [PASSED] SPI
[08:59:22] [PASSED] USB
[08:59:22] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[08:59:22] ============ [PASSED] drmm_connector_hdmi_init =============
[08:59:22] ============= drmm_connector_init (3 subtests) =============
[08:59:22] [PASSED] drm_test_drmm_connector_init
[08:59:22] [PASSED] drm_test_drmm_connector_init_null_ddc
[08:59:22] ========= drm_test_drmm_connector_init_type_valid =========
[08:59:22] [PASSED] Unknown
[08:59:22] [PASSED] VGA
[08:59:22] [PASSED] DVI-I
[08:59:22] [PASSED] DVI-D
[08:59:22] [PASSED] DVI-A
[08:59:22] [PASSED] Composite
[08:59:22] [PASSED] SVIDEO
[08:59:22] [PASSED] LVDS
[08:59:22] [PASSED] Component
[08:59:22] [PASSED] DIN
[08:59:22] [PASSED] DP
[08:59:22] [PASSED] HDMI-A
[08:59:22] [PASSED] HDMI-B
[08:59:22] [PASSED] TV
[08:59:22] [PASSED] eDP
[08:59:22] [PASSED] Virtual
[08:59:22] [PASSED] DSI
[08:59:22] [PASSED] DPI
[08:59:22] [PASSED] Writeback
[08:59:22] [PASSED] SPI
[08:59:22] [PASSED] USB
[08:59:22] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[08:59:22] =============== [PASSED] drmm_connector_init ===============
[08:59:22] ========= drm_connector_dynamic_init (6 subtests) ==========
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_init
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_init_properties
[08:59:22] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[08:59:22] [PASSED] Unknown
[08:59:22] [PASSED] VGA
[08:59:22] [PASSED] DVI-I
[08:59:22] [PASSED] DVI-D
[08:59:22] [PASSED] DVI-A
[08:59:22] [PASSED] Composite
[08:59:22] [PASSED] SVIDEO
[08:59:22] [PASSED] LVDS
[08:59:22] [PASSED] Component
[08:59:22] [PASSED] DIN
[08:59:22] [PASSED] DP
[08:59:22] [PASSED] HDMI-A
[08:59:22] [PASSED] HDMI-B
[08:59:22] [PASSED] TV
[08:59:22] [PASSED] eDP
[08:59:22] [PASSED] Virtual
[08:59:22] [PASSED] DSI
[08:59:22] [PASSED] DPI
[08:59:22] [PASSED] Writeback
[08:59:22] [PASSED] SPI
[08:59:22] [PASSED] USB
[08:59:22] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[08:59:22] ======== drm_test_drm_connector_dynamic_init_name =========
[08:59:22] [PASSED] Unknown
[08:59:22] [PASSED] VGA
[08:59:22] [PASSED] DVI-I
[08:59:22] [PASSED] DVI-D
[08:59:22] [PASSED] DVI-A
[08:59:22] [PASSED] Composite
[08:59:22] [PASSED] SVIDEO
[08:59:22] [PASSED] LVDS
[08:59:22] [PASSED] Component
[08:59:22] [PASSED] DIN
[08:59:22] [PASSED] DP
[08:59:22] [PASSED] HDMI-A
[08:59:22] [PASSED] HDMI-B
[08:59:22] [PASSED] TV
[08:59:22] [PASSED] eDP
[08:59:22] [PASSED] Virtual
[08:59:22] [PASSED] DSI
[08:59:22] [PASSED] DPI
[08:59:22] [PASSED] Writeback
[08:59:22] [PASSED] SPI
[08:59:22] [PASSED] USB
[08:59:22] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[08:59:22] =========== [PASSED] drm_connector_dynamic_init ============
[08:59:22] ==== drm_connector_dynamic_register_early (4 subtests) =====
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[08:59:22] ====== [PASSED] drm_connector_dynamic_register_early =======
[08:59:22] ======= drm_connector_dynamic_register (7 subtests) ========
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[08:59:22] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[08:59:22] ========= [PASSED] drm_connector_dynamic_register ==========
[08:59:22] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[08:59:22] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[08:59:22] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[08:59:22] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[08:59:22] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[08:59:22] ========== drm_test_get_tv_mode_from_name_valid ===========
[08:59:22] [PASSED] NTSC
[08:59:22] [PASSED] NTSC-443
[08:59:22] [PASSED] NTSC-J
[08:59:22] [PASSED] PAL
[08:59:22] [PASSED] PAL-M
[08:59:22] [PASSED] PAL-N
[08:59:22] [PASSED] SECAM
[08:59:22] [PASSED] Mono
[08:59:22] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[08:59:22] [PASSED] drm_test_get_tv_mode_from_name_truncated
[08:59:22] ============ [PASSED] drm_get_tv_mode_from_name ============
[08:59:22] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[08:59:22] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[08:59:22] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[08:59:22] [PASSED] VIC 96
[08:59:22] [PASSED] VIC 97
[08:59:22] [PASSED] VIC 101
[08:59:22] [PASSED] VIC 102
[08:59:22] [PASSED] VIC 106
[08:59:22] [PASSED] VIC 107
[08:59:22] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[08:59:22] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[08:59:22] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[08:59:22] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[08:59:22] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[08:59:22] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[08:59:22] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[08:59:22] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[08:59:22] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[08:59:22] [PASSED] Automatic
[08:59:22] [PASSED] Full
[08:59:22] [PASSED] Limited 16:235
[08:59:22] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[08:59:22] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[08:59:22] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[08:59:22] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[08:59:22] === drm_test_drm_hdmi_connector_get_output_format_name ====
[08:59:22] [PASSED] RGB
[08:59:22] [PASSED] YUV 4:2:0
[08:59:22] [PASSED] YUV 4:2:2
[08:59:22] [PASSED] YUV 4:4:4
[08:59:22] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[08:59:22] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[08:59:22] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[08:59:22] ============= drm_damage_helper (21 subtests) ==============
[08:59:22] [PASSED] drm_test_damage_iter_no_damage
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_src_moved
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_not_visible
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[08:59:22] [PASSED] drm_test_damage_iter_no_damage_no_fb
[08:59:22] [PASSED] drm_test_damage_iter_simple_damage
[08:59:22] [PASSED] drm_test_damage_iter_single_damage
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_outside_src
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_src_moved
[08:59:22] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[08:59:22] [PASSED] drm_test_damage_iter_damage
[08:59:22] [PASSED] drm_test_damage_iter_damage_one_intersect
[08:59:22] [PASSED] drm_test_damage_iter_damage_one_outside
[08:59:22] [PASSED] drm_test_damage_iter_damage_src_moved
[08:59:22] [PASSED] drm_test_damage_iter_damage_not_visible
[08:59:22] ================ [PASSED] drm_damage_helper ================
[08:59:22] ============== drm_dp_mst_helper (3 subtests) ==============
[08:59:22] ============== drm_test_dp_mst_calc_pbn_mode ==============
[08:59:22] [PASSED] Clock 154000 BPP 30 DSC disabled
[08:59:22] [PASSED] Clock 234000 BPP 30 DSC disabled
[08:59:22] [PASSED] Clock 297000 BPP 24 DSC disabled
[08:59:22] [PASSED] Clock 332880 BPP 24 DSC enabled
[08:59:22] [PASSED] Clock 324540 BPP 24 DSC enabled
[08:59:22] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[08:59:22] ============== drm_test_dp_mst_calc_pbn_div ===============
[08:59:22] [PASSED] Link rate 2000000 lane count 4
[08:59:23] [PASSED] Link rate 2000000 lane count 2
[08:59:23] [PASSED] Link rate 2000000 lane count 1
[08:59:23] [PASSED] Link rate 1350000 lane count 4
[08:59:23] [PASSED] Link rate 1350000 lane count 2
[08:59:23] [PASSED] Link rate 1350000 lane count 1
[08:59:23] [PASSED] Link rate 1000000 lane count 4
[08:59:23] [PASSED] Link rate 1000000 lane count 2
[08:59:23] [PASSED] Link rate 1000000 lane count 1
[08:59:23] [PASSED] Link rate 810000 lane count 4
[08:59:23] [PASSED] Link rate 810000 lane count 2
[08:59:23] [PASSED] Link rate 810000 lane count 1
[08:59:23] [PASSED] Link rate 540000 lane count 4
[08:59:23] [PASSED] Link rate 540000 lane count 2
[08:59:23] [PASSED] Link rate 540000 lane count 1
[08:59:23] [PASSED] Link rate 270000 lane count 4
[08:59:23] [PASSED] Link rate 270000 lane count 2
[08:59:23] [PASSED] Link rate 270000 lane count 1
[08:59:23] [PASSED] Link rate 162000 lane count 4
[08:59:23] [PASSED] Link rate 162000 lane count 2
[08:59:23] [PASSED] Link rate 162000 lane count 1
[08:59:23] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[08:59:23] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[08:59:23] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[08:59:23] [PASSED] DP_POWER_UP_PHY with port number
[08:59:23] [PASSED] DP_POWER_DOWN_PHY with port number
[08:59:23] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[08:59:23] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[08:59:23] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[08:59:23] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[08:59:23] [PASSED] DP_QUERY_PAYLOAD with port number
[08:59:23] [PASSED] DP_QUERY_PAYLOAD with VCPI
[08:59:23] [PASSED] DP_REMOTE_DPCD_READ with port number
[08:59:23] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[08:59:23] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[08:59:23] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[08:59:23] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[08:59:23] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[08:59:23] [PASSED] DP_REMOTE_I2C_READ with port number
[08:59:23] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[08:59:23] [PASSED] DP_REMOTE_I2C_READ with transactions array
[08:59:23] [PASSED] DP_REMOTE_I2C_WRITE with port number
[08:59:23] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[08:59:23] [PASSED] DP_REMOTE_I2C_WRITE with data array
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[08:59:23] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[08:59:23] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[08:59:23] ================ [PASSED] drm_dp_mst_helper ================
[08:59:23] ================== drm_exec (7 subtests) ===================
[08:59:23] [PASSED] sanitycheck
[08:59:23] [PASSED] test_lock
[08:59:23] [PASSED] test_lock_unlock
[08:59:23] [PASSED] test_duplicates
[08:59:23] [PASSED] test_prepare
[08:59:23] [PASSED] test_prepare_array
[08:59:23] [PASSED] test_multiple_loops
[08:59:23] ==================== [PASSED] drm_exec =====================
[08:59:23] =========== drm_format_helper_test (17 subtests) ===========
[08:59:23] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[08:59:23] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[08:59:23] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[08:59:23] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[08:59:23] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[08:59:23] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[08:59:23] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[08:59:23] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[08:59:23] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[08:59:23] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[08:59:23] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[08:59:23] ============== drm_test_fb_xrgb8888_to_mono ===============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[08:59:23] ==================== drm_test_fb_swab =====================
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ================ [PASSED] drm_test_fb_swab =================
[08:59:23] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[08:59:23] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[08:59:23] [PASSED] single_pixel_source_buffer
[08:59:23] [PASSED] single_pixel_clip_rectangle
[08:59:23] [PASSED] well_known_colors
[08:59:23] [PASSED] destination_pitch
[08:59:23] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[08:59:23] ================= drm_test_fb_clip_offset =================
[08:59:23] [PASSED] pass through
[08:59:23] [PASSED] horizontal offset
[08:59:23] [PASSED] vertical offset
[08:59:23] [PASSED] horizontal and vertical offset
[08:59:23] [PASSED] horizontal offset (custom pitch)
[08:59:23] [PASSED] vertical offset (custom pitch)
[08:59:23] [PASSED] horizontal and vertical offset (custom pitch)
[08:59:23] ============= [PASSED] drm_test_fb_clip_offset =============
[08:59:23] =================== drm_test_fb_memcpy ====================
[08:59:23] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[08:59:23] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[08:59:23] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[08:59:23] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[08:59:23] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[08:59:23] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[08:59:23] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[08:59:23] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[08:59:23] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[08:59:23] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[08:59:23] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[08:59:23] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[08:59:23] =============== [PASSED] drm_test_fb_memcpy ================
[08:59:23] ============= [PASSED] drm_format_helper_test ==============
[08:59:23] ================= drm_format (18 subtests) =================
[08:59:23] [PASSED] drm_test_format_block_width_invalid
[08:59:23] [PASSED] drm_test_format_block_width_one_plane
[08:59:23] [PASSED] drm_test_format_block_width_two_plane
[08:59:23] [PASSED] drm_test_format_block_width_three_plane
[08:59:23] [PASSED] drm_test_format_block_width_tiled
[08:59:23] [PASSED] drm_test_format_block_height_invalid
[08:59:23] [PASSED] drm_test_format_block_height_one_plane
[08:59:23] [PASSED] drm_test_format_block_height_two_plane
[08:59:23] [PASSED] drm_test_format_block_height_three_plane
[08:59:23] [PASSED] drm_test_format_block_height_tiled
[08:59:23] [PASSED] drm_test_format_min_pitch_invalid
[08:59:23] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[08:59:23] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[08:59:23] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[08:59:23] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[08:59:23] [PASSED] drm_test_format_min_pitch_two_plane
[08:59:23] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[08:59:23] [PASSED] drm_test_format_min_pitch_tiled
[08:59:23] =================== [PASSED] drm_format ====================
[08:59:23] ============== drm_framebuffer (10 subtests) ===============
[08:59:23] ========== drm_test_framebuffer_check_src_coords ==========
[08:59:23] [PASSED] Success: source fits into fb
[08:59:23] [PASSED] Fail: overflowing fb with x-axis coordinate
[08:59:23] [PASSED] Fail: overflowing fb with y-axis coordinate
[08:59:23] [PASSED] Fail: overflowing fb with source width
[08:59:23] [PASSED] Fail: overflowing fb with source height
[08:59:23] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[08:59:23] [PASSED] drm_test_framebuffer_cleanup
[08:59:23] =============== drm_test_framebuffer_create ===============
[08:59:23] [PASSED] ABGR8888 normal sizes
[08:59:23] [PASSED] ABGR8888 max sizes
[08:59:23] [PASSED] ABGR8888 pitch greater than min required
[08:59:23] [PASSED] ABGR8888 pitch less than min required
[08:59:23] [PASSED] ABGR8888 Invalid width
[08:59:23] [PASSED] ABGR8888 Invalid buffer handle
[08:59:23] [PASSED] No pixel format
[08:59:23] [PASSED] ABGR8888 Width 0
[08:59:23] [PASSED] ABGR8888 Height 0
[08:59:23] [PASSED] ABGR8888 Out of bound height * pitch combination
[08:59:23] [PASSED] ABGR8888 Large buffer offset
[08:59:23] [PASSED] ABGR8888 Buffer offset for inexistent plane
[08:59:23] [PASSED] ABGR8888 Invalid flag
[08:59:23] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[08:59:23] [PASSED] ABGR8888 Valid buffer modifier
[08:59:23] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[08:59:23] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] NV12 Normal sizes
[08:59:23] [PASSED] NV12 Max sizes
[08:59:23] [PASSED] NV12 Invalid pitch
[08:59:23] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[08:59:23] [PASSED] NV12 different modifier per-plane
[08:59:23] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[08:59:23] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] NV12 Modifier for inexistent plane
[08:59:23] [PASSED] NV12 Handle for inexistent plane
[08:59:23] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[08:59:23] [PASSED] YVU420 Normal sizes
[08:59:23] [PASSED] YVU420 Max sizes
[08:59:23] [PASSED] YVU420 Invalid pitch
[08:59:23] [PASSED] YVU420 Different pitches
[08:59:23] [PASSED] YVU420 Different buffer offsets/pitches
[08:59:23] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[08:59:23] [PASSED] YVU420 Valid modifier
[08:59:23] [PASSED] YVU420 Different modifiers per plane
[08:59:23] [PASSED] YVU420 Modifier for inexistent plane
[08:59:23] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[08:59:23] [PASSED] X0L2 Normal sizes
[08:59:23] [PASSED] X0L2 Max sizes
[08:59:23] [PASSED] X0L2 Invalid pitch
[08:59:23] [PASSED] X0L2 Pitch greater than minimum required
[08:59:23] [PASSED] X0L2 Handle for inexistent plane
[08:59:23] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[08:59:23] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[08:59:23] [PASSED] X0L2 Valid modifier
[08:59:23] [PASSED] X0L2 Modifier for inexistent plane
[08:59:23] =========== [PASSED] drm_test_framebuffer_create ===========
[08:59:23] [PASSED] drm_test_framebuffer_free
[08:59:23] [PASSED] drm_test_framebuffer_init
[08:59:23] [PASSED] drm_test_framebuffer_init_bad_format
[08:59:23] [PASSED] drm_test_framebuffer_init_dev_mismatch
[08:59:23] [PASSED] drm_test_framebuffer_lookup
[08:59:23] [PASSED] drm_test_framebuffer_lookup_inexistent
[08:59:23] [PASSED] drm_test_framebuffer_modifiers_not_supported
[08:59:23] ================= [PASSED] drm_framebuffer =================
[08:59:23] ================ drm_gem_shmem (8 subtests) ================
[08:59:23] [PASSED] drm_gem_shmem_test_obj_create
[08:59:23] [PASSED] drm_gem_shmem_test_obj_create_private
[08:59:23] [PASSED] drm_gem_shmem_test_pin_pages
[08:59:23] [PASSED] drm_gem_shmem_test_vmap
[08:59:23] [PASSED] drm_gem_shmem_test_get_pages_sgt
[08:59:23] [PASSED] drm_gem_shmem_test_get_sg_table
[08:59:23] [PASSED] drm_gem_shmem_test_madvise
[08:59:23] [PASSED] drm_gem_shmem_test_purge
[08:59:23] ================== [PASSED] drm_gem_shmem ==================
[08:59:23] === drm_atomic_helper_connector_hdmi_check (27 subtests) ===
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[08:59:23] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[08:59:23] [PASSED] Automatic
[08:59:23] [PASSED] Full
[08:59:23] [PASSED] Limited 16:235
[08:59:23] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[08:59:23] [PASSED] drm_test_check_disable_connector
[08:59:23] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[08:59:23] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[08:59:23] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[08:59:23] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[08:59:23] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[08:59:23] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[08:59:23] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[08:59:23] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[08:59:23] [PASSED] drm_test_check_output_bpc_dvi
[08:59:23] [PASSED] drm_test_check_output_bpc_format_vic_1
[08:59:23] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[08:59:23] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[08:59:23] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[08:59:23] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[08:59:23] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[08:59:23] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[08:59:23] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[08:59:23] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[08:59:23] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[08:59:23] [PASSED] drm_test_check_broadcast_rgb_value
[08:59:23] [PASSED] drm_test_check_bpc_8_value
[08:59:23] [PASSED] drm_test_check_bpc_10_value
[08:59:23] [PASSED] drm_test_check_bpc_12_value
[08:59:23] [PASSED] drm_test_check_format_value
[08:59:23] [PASSED] drm_test_check_tmds_char_value
[08:59:23] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[08:59:23] = drm_atomic_helper_connector_hdmi_mode_valid (4 subtests) =
[08:59:23] [PASSED] drm_test_check_mode_valid
[08:59:23] [PASSED] drm_test_check_mode_valid_reject
[08:59:23] [PASSED] drm_test_check_mode_valid_reject_rate
[08:59:23] [PASSED] drm_test_check_mode_valid_reject_max_clock
[08:59:23] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[08:59:23] ================= drm_managed (2 subtests) =================
[08:59:23] [PASSED] drm_test_managed_release_action
[08:59:23] [PASSED] drm_test_managed_run_action
[08:59:23] =================== [PASSED] drm_managed ===================
[08:59:23] =================== drm_mm (6 subtests) ====================
[08:59:23] [PASSED] drm_test_mm_init
[08:59:23] [PASSED] drm_test_mm_debug
[08:59:23] [PASSED] drm_test_mm_align32
[08:59:23] [PASSED] drm_test_mm_align64
[08:59:23] [PASSED] drm_test_mm_lowest
[08:59:23] [PASSED] drm_test_mm_highest
[08:59:23] ===================== [PASSED] drm_mm ======================
[08:59:23] ============= drm_modes_analog_tv (5 subtests) =============
[08:59:23] [PASSED] drm_test_modes_analog_tv_mono_576i
[08:59:23] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[08:59:23] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[08:59:23] [PASSED] drm_test_modes_analog_tv_pal_576i
[08:59:23] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[08:59:23] =============== [PASSED] drm_modes_analog_tv ===============
[08:59:23] ============== drm_plane_helper (2 subtests) ===============
[08:59:23] =============== drm_test_check_plane_state ================
[08:59:23] [PASSED] clipping_simple
[08:59:23] [PASSED] clipping_rotate_reflect
[08:59:23] [PASSED] positioning_simple
[08:59:23] [PASSED] upscaling
[08:59:23] [PASSED] downscaling
[08:59:23] [PASSED] rounding1
[08:59:23] [PASSED] rounding2
[08:59:23] [PASSED] rounding3
[08:59:23] [PASSED] rounding4
[08:59:23] =========== [PASSED] drm_test_check_plane_state ============
[08:59:23] =========== drm_test_check_invalid_plane_state ============
[08:59:23] [PASSED] positioning_invalid
[08:59:23] [PASSED] upscaling_invalid
[08:59:23] [PASSED] downscaling_invalid
[08:59:23] ======= [PASSED] drm_test_check_invalid_plane_state ========
[08:59:23] ================ [PASSED] drm_plane_helper =================
[08:59:23] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[08:59:23] ====== drm_test_connector_helper_tv_get_modes_check =======
[08:59:23] [PASSED] None
[08:59:23] [PASSED] PAL
[08:59:23] [PASSED] NTSC
[08:59:23] [PASSED] Both, NTSC Default
[08:59:23] [PASSED] Both, PAL Default
[08:59:23] [PASSED] Both, NTSC Default, with PAL on command-line
[08:59:23] [PASSED] Both, PAL Default, with NTSC on command-line
[08:59:23] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[08:59:23] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[08:59:23] ================== drm_rect (9 subtests) ===================
[08:59:23] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[08:59:23] [PASSED] drm_test_rect_clip_scaled_not_clipped
[08:59:23] [PASSED] drm_test_rect_clip_scaled_clipped
[08:59:23] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[08:59:23] ================= drm_test_rect_intersect =================
[08:59:23] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[08:59:23] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[08:59:23] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[08:59:23] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[08:59:23] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[08:59:23] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[08:59:23] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[08:59:23] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[08:59:23] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[08:59:23] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[08:59:23] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[08:59:23] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[08:59:23] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[08:59:23] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[08:59:23] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[08:59:23] ============= [PASSED] drm_test_rect_intersect =============
[08:59:23] ================ drm_test_rect_calc_hscale ================
[08:59:23] [PASSED] normal use
[08:59:23] [PASSED] out of max range
[08:59:23] [PASSED] out of min range
[08:59:23] [PASSED] zero dst
[08:59:23] [PASSED] negative src
[08:59:23] [PASSED] negative dst
[08:59:23] ============ [PASSED] drm_test_rect_calc_hscale ============
[08:59:23] ================ drm_test_rect_calc_vscale ================
[08:59:23] [PASSED] normal use
[08:59:23] [PASSED] out of max range
[08:59:23] [PASSED] out of min range
[08:59:23] [PASSED] zero dst
[08:59:23] [PASSED] negative src
stty: 'standard input': Inappropriate ioctl for device
[08:59:23] [PASSED] negative dst
[08:59:23] ============ [PASSED] drm_test_rect_calc_vscale ============
[08:59:23] ================== drm_test_rect_rotate ===================
[08:59:23] [PASSED] reflect-x
[08:59:23] [PASSED] reflect-y
[08:59:23] [PASSED] rotate-0
[08:59:23] [PASSED] rotate-90
[08:59:23] [PASSED] rotate-180
[08:59:23] [PASSED] rotate-270
[08:59:23] ============== [PASSED] drm_test_rect_rotate ===============
[08:59:23] ================ drm_test_rect_rotate_inv =================
[08:59:23] [PASSED] reflect-x
[08:59:23] [PASSED] reflect-y
[08:59:23] [PASSED] rotate-0
[08:59:23] [PASSED] rotate-90
[08:59:23] [PASSED] rotate-180
[08:59:23] [PASSED] rotate-270
[08:59:23] ============ [PASSED] drm_test_rect_rotate_inv =============
[08:59:23] ==================== [PASSED] drm_rect =====================
[08:59:23] ============ drm_sysfb_modeset_test (1 subtest) ============
[08:59:23] ============ drm_test_sysfb_build_fourcc_list =============
[08:59:23] [PASSED] no native formats
[08:59:23] [PASSED] XRGB8888 as native format
[08:59:23] [PASSED] remove duplicates
[08:59:23] [PASSED] convert alpha formats
[08:59:23] [PASSED] random formats
[08:59:23] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[08:59:23] ============= [PASSED] drm_sysfb_modeset_test ==============
[08:59:23] ============================================================
[08:59:23] Testing complete. Ran 621 tests: passed: 621
[08:59:23] Elapsed time: 26.275s total, 1.782s configuring, 24.323s building, 0.147s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[08:59:23] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[08:59:24] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=48
[08:59:34] Starting KUnit Kernel (1/1)...
[08:59:34] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[08:59:34] ================= ttm_device (5 subtests) ==================
[08:59:34] [PASSED] ttm_device_init_basic
[08:59:34] [PASSED] ttm_device_init_multiple
[08:59:34] [PASSED] ttm_device_fini_basic
[08:59:34] [PASSED] ttm_device_init_no_vma_man
[08:59:34] ================== ttm_device_init_pools ==================
[08:59:34] [PASSED] No DMA allocations, no DMA32 required
[08:59:34] [PASSED] DMA allocations, DMA32 required
[08:59:34] [PASSED] No DMA allocations, DMA32 required
[08:59:34] [PASSED] DMA allocations, no DMA32 required
[08:59:34] ============== [PASSED] ttm_device_init_pools ==============
[08:59:34] =================== [PASSED] ttm_device ====================
[08:59:34] ================== ttm_pool (8 subtests) ===================
[08:59:34] ================== ttm_pool_alloc_basic ===================
[08:59:34] [PASSED] One page
[08:59:34] [PASSED] More than one page
[08:59:34] [PASSED] Above the allocation limit
[08:59:34] [PASSED] One page, with coherent DMA mappings enabled
[08:59:34] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[08:59:34] ============== [PASSED] ttm_pool_alloc_basic ===============
[08:59:34] ============== ttm_pool_alloc_basic_dma_addr ==============
[08:59:34] [PASSED] One page
[08:59:34] [PASSED] More than one page
[08:59:34] [PASSED] Above the allocation limit
[08:59:34] [PASSED] One page, with coherent DMA mappings enabled
[08:59:34] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[08:59:34] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[08:59:34] [PASSED] ttm_pool_alloc_order_caching_match
[08:59:34] [PASSED] ttm_pool_alloc_caching_mismatch
[08:59:34] [PASSED] ttm_pool_alloc_order_mismatch
[08:59:34] [PASSED] ttm_pool_free_dma_alloc
[08:59:34] [PASSED] ttm_pool_free_no_dma_alloc
[08:59:34] [PASSED] ttm_pool_fini_basic
[08:59:34] ==================== [PASSED] ttm_pool =====================
[08:59:34] ================ ttm_resource (8 subtests) =================
[08:59:34] ================= ttm_resource_init_basic =================
[08:59:34] [PASSED] Init resource in TTM_PL_SYSTEM
[08:59:34] [PASSED] Init resource in TTM_PL_VRAM
[08:59:34] [PASSED] Init resource in a private placement
[08:59:34] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[08:59:34] ============= [PASSED] ttm_resource_init_basic =============
[08:59:34] [PASSED] ttm_resource_init_pinned
[08:59:34] [PASSED] ttm_resource_fini_basic
[08:59:34] [PASSED] ttm_resource_manager_init_basic
[08:59:34] [PASSED] ttm_resource_manager_usage_basic
[08:59:34] [PASSED] ttm_resource_manager_set_used_basic
[08:59:34] [PASSED] ttm_sys_man_alloc_basic
[08:59:34] [PASSED] ttm_sys_man_free_basic
[08:59:34] ================== [PASSED] ttm_resource ===================
[08:59:34] =================== ttm_tt (15 subtests) ===================
[08:59:34] ==================== ttm_tt_init_basic ====================
[08:59:34] [PASSED] Page-aligned size
[08:59:34] [PASSED] Extra pages requested
[08:59:34] ================ [PASSED] ttm_tt_init_basic ================
[08:59:34] [PASSED] ttm_tt_init_misaligned
[08:59:34] [PASSED] ttm_tt_fini_basic
[08:59:34] [PASSED] ttm_tt_fini_sg
[08:59:34] [PASSED] ttm_tt_fini_shmem
[08:59:34] [PASSED] ttm_tt_create_basic
[08:59:34] [PASSED] ttm_tt_create_invalid_bo_type
[08:59:34] [PASSED] ttm_tt_create_ttm_exists
[08:59:34] [PASSED] ttm_tt_create_failed
[08:59:34] [PASSED] ttm_tt_destroy_basic
[08:59:34] [PASSED] ttm_tt_populate_null_ttm
[08:59:34] [PASSED] ttm_tt_populate_populated_ttm
[08:59:34] [PASSED] ttm_tt_unpopulate_basic
[08:59:34] [PASSED] ttm_tt_unpopulate_empty_ttm
[08:59:34] [PASSED] ttm_tt_swapin_basic
[08:59:34] ===================== [PASSED] ttm_tt ======================
[08:59:34] =================== ttm_bo (14 subtests) ===================
[08:59:34] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[08:59:34] [PASSED] Cannot be interrupted and sleeps
[08:59:34] [PASSED] Cannot be interrupted, locks straight away
[08:59:34] [PASSED] Can be interrupted, sleeps
[08:59:34] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[08:59:34] [PASSED] ttm_bo_reserve_locked_no_sleep
[08:59:34] [PASSED] ttm_bo_reserve_no_wait_ticket
[08:59:34] [PASSED] ttm_bo_reserve_double_resv
[08:59:34] [PASSED] ttm_bo_reserve_interrupted
[08:59:34] [PASSED] ttm_bo_reserve_deadlock
[08:59:34] [PASSED] ttm_bo_unreserve_basic
[08:59:34] [PASSED] ttm_bo_unreserve_pinned
[08:59:34] [PASSED] ttm_bo_unreserve_bulk
[08:59:34] [PASSED] ttm_bo_fini_basic
[08:59:34] [PASSED] ttm_bo_fini_shared_resv
[08:59:34] [PASSED] ttm_bo_pin_basic
[08:59:34] [PASSED] ttm_bo_pin_unpin_resource
[08:59:34] [PASSED] ttm_bo_multiple_pin_one_unpin
[08:59:34] ===================== [PASSED] ttm_bo ======================
[08:59:34] ============== ttm_bo_validate (21 subtests) ===============
[08:59:34] ============== ttm_bo_init_reserved_sys_man ===============
[08:59:34] [PASSED] Buffer object for userspace
[08:59:34] [PASSED] Kernel buffer object
[08:59:34] [PASSED] Shared buffer object
[08:59:34] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[08:59:34] ============== ttm_bo_init_reserved_mock_man ==============
[08:59:34] [PASSED] Buffer object for userspace
[08:59:34] [PASSED] Kernel buffer object
[08:59:34] [PASSED] Shared buffer object
[08:59:34] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[08:59:34] [PASSED] ttm_bo_init_reserved_resv
[08:59:34] ================== ttm_bo_validate_basic ==================
[08:59:34] [PASSED] Buffer object for userspace
[08:59:34] [PASSED] Kernel buffer object
[08:59:34] [PASSED] Shared buffer object
[08:59:34] ============== [PASSED] ttm_bo_validate_basic ==============
[08:59:34] [PASSED] ttm_bo_validate_invalid_placement
[08:59:34] ============= ttm_bo_validate_same_placement ==============
[08:59:34] [PASSED] System manager
[08:59:34] [PASSED] VRAM manager
[08:59:34] ========= [PASSED] ttm_bo_validate_same_placement ==========
[08:59:34] [PASSED] ttm_bo_validate_failed_alloc
[08:59:34] [PASSED] ttm_bo_validate_pinned
[08:59:34] [PASSED] ttm_bo_validate_busy_placement
[08:59:34] ================ ttm_bo_validate_multihop =================
[08:59:34] [PASSED] Buffer object for userspace
[08:59:34] [PASSED] Kernel buffer object
[08:59:34] [PASSED] Shared buffer object
[08:59:34] ============ [PASSED] ttm_bo_validate_multihop =============
[08:59:34] ========== ttm_bo_validate_no_placement_signaled ==========
[08:59:34] [PASSED] Buffer object in system domain, no page vector
[08:59:34] [PASSED] Buffer object in system domain with an existing page vector
[08:59:34] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[08:59:34] ======== ttm_bo_validate_no_placement_not_signaled ========
[08:59:34] [PASSED] Buffer object for userspace
[08:59:34] [PASSED] Kernel buffer object
[08:59:34] [PASSED] Shared buffer object
[08:59:34] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[08:59:34] [PASSED] ttm_bo_validate_move_fence_signaled
[08:59:34] ========= ttm_bo_validate_move_fence_not_signaled =========
[08:59:34] [PASSED] Waits for GPU
[08:59:34] [PASSED] Tries to lock straight away
[08:59:34] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[08:59:34] [PASSED] ttm_bo_validate_happy_evict
[08:59:34] [PASSED] ttm_bo_validate_all_pinned_evict
[08:59:34] [PASSED] ttm_bo_validate_allowed_only_evict
[08:59:34] [PASSED] ttm_bo_validate_deleted_evict
[08:59:34] [PASSED] ttm_bo_validate_busy_domain_evict
[08:59:34] [PASSED] ttm_bo_validate_evict_gutting
[08:59:34] [PASSED] ttm_bo_validate_recrusive_evict
stty: 'standard input': Inappropriate ioctl for device
[08:59:34] ================= [PASSED] ttm_bo_validate =================
[08:59:34] ============================================================
[08:59:34] Testing complete. Ran 101 tests: passed: 101
[08:59:34] Elapsed time: 11.180s total, 1.771s configuring, 9.093s building, 0.284s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 25+ messages in thread* ✓ Xe.CI.BAT: success for drm/{i915,xe}/fbdev: refactor (rev2)
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (10 preceding siblings ...)
2025-09-18 8:59 ` ✓ CI.KUnit: success for drm/{i915,xe}/fbdev: refactor (rev2) Patchwork
@ 2025-09-18 9:33 ` Patchwork
2025-09-18 15:54 ` ✓ Xe.CI.Full: " Patchwork
12 siblings, 0 replies; 25+ messages in thread
From: Patchwork @ 2025-09-18 9:33 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 2340 bytes --]
== Series Details ==
Series: drm/{i915,xe}/fbdev: refactor (rev2)
URL : https://patchwork.freedesktop.org/series/153981/
State : success
== Summary ==
CI Bug Log - changes from xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c_BAT -> xe-pw-153981v2_BAT
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (11 -> 11)
------------------------------
No changes in participating hosts
Known issues
------------
Here are the changes found in xe-pw-153981v2_BAT that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_flip@basic-flip-vs-dpms:
- bat-adlp-7: [PASS][1] -> [DMESG-WARN][2] ([Intel XE#4543]) +1 other test dmesg-warn
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/bat-adlp-7/igt@kms_flip@basic-flip-vs-dpms.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/bat-adlp-7/igt@kms_flip@basic-flip-vs-dpms.html
* igt@xe_pat@pat-index-xe2@render:
- bat-bmg-1: [PASS][3] -> [FAIL][4] ([Intel XE#5507]) +1 other test fail
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/bat-bmg-1/igt@xe_pat@pat-index-xe2@render.html
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/bat-bmg-1/igt@xe_pat@pat-index-xe2@render.html
#### Possible fixes ####
* igt@kms_flip@basic-plain-flip@a-edp1:
- bat-adlp-7: [DMESG-WARN][5] ([Intel XE#4543]) -> [PASS][6] +1 other test pass
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/bat-adlp-7/igt@kms_flip@basic-plain-flip@a-edp1.html
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/bat-adlp-7/igt@kms_flip@basic-plain-flip@a-edp1.html
[Intel XE#4543]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4543
[Intel XE#5507]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5507
Build changes
-------------
* Linux: xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c -> xe-pw-153981v2
IGT_8543: 8543
xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c: acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c
xe-pw-153981v2: 153981v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/index.html
[-- Attachment #2: Type: text/html, Size: 3037 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread* ✓ Xe.CI.Full: success for drm/{i915,xe}/fbdev: refactor (rev2)
2025-09-18 8:40 [PATCH v2 00/10] drm/{i915,xe}/fbdev: refactor Jani Nikula
` (11 preceding siblings ...)
2025-09-18 9:33 ` ✓ Xe.CI.BAT: " Patchwork
@ 2025-09-18 15:54 ` Patchwork
12 siblings, 0 replies; 25+ messages in thread
From: Patchwork @ 2025-09-18 15:54 UTC (permalink / raw)
To: Jani Nikula; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 36400 bytes --]
== Series Details ==
Series: drm/{i915,xe}/fbdev: refactor (rev2)
URL : https://patchwork.freedesktop.org/series/153981/
State : success
== Summary ==
CI Bug Log - changes from xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c_FULL -> xe-pw-153981v2_FULL
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (4 -> 4)
------------------------------
No changes in participating hosts
Known issues
------------
Here are the changes found in xe-pw-153981v2_FULL that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_async_flips@async-flip-with-page-flip-events-tiled@pipe-b-hdmi-a-1-y:
- shard-adlp: [PASS][1] -> [DMESG-WARN][2] ([Intel XE#4543]) +35 other tests dmesg-warn
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-4/igt@kms_async_flips@async-flip-with-page-flip-events-tiled@pipe-b-hdmi-a-1-y.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-6/igt@kms_async_flips@async-flip-with-page-flip-events-tiled@pipe-b-hdmi-a-1-y.html
* igt@kms_atomic_transition@plane-all-modeset-transition-fencing:
- shard-adlp: [PASS][3] -> [FAIL][4] ([Intel XE#3908]) +1 other test fail
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-4/igt@kms_atomic_transition@plane-all-modeset-transition-fencing.html
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-4/igt@kms_atomic_transition@plane-all-modeset-transition-fencing.html
* igt@kms_big_fb@linear-8bpp-rotate-270:
- shard-dg2-set2: NOTRUN -> [SKIP][5] ([Intel XE#316])
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_big_fb@linear-8bpp-rotate-270.html
* igt@kms_big_fb@y-tiled-max-hw-stride-32bpp-rotate-180-async-flip:
- shard-adlp: [PASS][6] -> [DMESG-FAIL][7] ([Intel XE#4543]) +24 other tests dmesg-fail
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-2/igt@kms_big_fb@y-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-2/igt@kms_big_fb@y-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
* igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-0-async-flip:
- shard-dg2-set2: NOTRUN -> [SKIP][8] ([Intel XE#1124]) +3 other tests skip
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-0-async-flip.html
* igt@kms_bw@connected-linear-tiling-2-displays-1920x1080p:
- shard-bmg: [PASS][9] -> [SKIP][10] ([Intel XE#2314] / [Intel XE#2894]) +1 other test skip
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_bw@connected-linear-tiling-2-displays-1920x1080p.html
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_bw@connected-linear-tiling-2-displays-1920x1080p.html
* igt@kms_bw@connected-linear-tiling-4-displays-1920x1080p:
- shard-dg2-set2: NOTRUN -> [SKIP][11] ([Intel XE#2191]) +2 other tests skip
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_bw@connected-linear-tiling-4-displays-1920x1080p.html
* igt@kms_ccs@bad-pixel-format-4-tiled-mtl-rc-ccs-cc@pipe-a-hdmi-a-6:
- shard-dg2-set2: NOTRUN -> [SKIP][12] ([Intel XE#787]) +118 other tests skip
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_ccs@bad-pixel-format-4-tiled-mtl-rc-ccs-cc@pipe-a-hdmi-a-6.html
* igt@kms_ccs@ccs-on-another-bo-4-tiled-mtl-rc-ccs-cc@pipe-d-dp-2:
- shard-dg2-set2: NOTRUN -> [SKIP][13] ([Intel XE#455] / [Intel XE#787]) +20 other tests skip
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-432/igt@kms_ccs@ccs-on-another-bo-4-tiled-mtl-rc-ccs-cc@pipe-d-dp-2.html
* igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs:
- shard-dg2-set2: NOTRUN -> [SKIP][14] ([Intel XE#3442])
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs.html
* igt@kms_ccs@crc-sprite-planes-basic-4-tiled-lnl-ccs@pipe-b-dp-2:
- shard-bmg: NOTRUN -> [SKIP][15] ([Intel XE#2652] / [Intel XE#787]) +3 other tests skip
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_ccs@crc-sprite-planes-basic-4-tiled-lnl-ccs@pipe-b-dp-2.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs:
- shard-dg2-set2: [PASS][16] -> [INCOMPLETE][17] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4345])
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs.html
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-464/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-d-hdmi-a-6:
- shard-dg2-set2: [PASS][18] -> [INCOMPLETE][19] ([Intel XE#1727] / [Intel XE#3113])
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-d-hdmi-a-6.html
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-464/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-d-hdmi-a-6.html
* igt@kms_cdclk@plane-scaling@pipe-b-dp-4:
- shard-dg2-set2: NOTRUN -> [SKIP][20] ([Intel XE#4416]) +3 other tests skip
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_cdclk@plane-scaling@pipe-b-dp-4.html
* igt@kms_chamelium_color@ctm-blue-to-red:
- shard-adlp: NOTRUN -> [SKIP][21] ([Intel XE#306])
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@kms_chamelium_color@ctm-blue-to-red.html
- shard-dg2-set2: NOTRUN -> [SKIP][22] ([Intel XE#306])
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_chamelium_color@ctm-blue-to-red.html
* igt@kms_chamelium_edid@hdmi-mode-timings:
- shard-dg2-set2: NOTRUN -> [SKIP][23] ([Intel XE#373]) +2 other tests skip
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_chamelium_edid@hdmi-mode-timings.html
* igt@kms_content_protection@srm@pipe-a-dp-2:
- shard-bmg: NOTRUN -> [FAIL][24] ([Intel XE#1178])
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_content_protection@srm@pipe-a-dp-2.html
- shard-dg2-set2: NOTRUN -> [FAIL][25] ([Intel XE#1178])
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-432/igt@kms_content_protection@srm@pipe-a-dp-2.html
* igt@kms_cursor_crc@cursor-offscreen-512x512:
- shard-dg2-set2: NOTRUN -> [SKIP][26] ([Intel XE#308])
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_cursor_crc@cursor-offscreen-512x512.html
* igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size:
- shard-bmg: [PASS][27] -> [SKIP][28] ([Intel XE#2291]) +2 other tests skip
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size.html
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size.html
* igt@kms_fbc_dirty_rect@fbc-dirty-rectangle-out-visible-area:
- shard-dg2-set2: NOTRUN -> [SKIP][29] ([Intel XE#4422])
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_fbc_dirty_rect@fbc-dirty-rectangle-out-visible-area.html
* igt@kms_flip@2x-blocking-wf_vblank:
- shard-bmg: [PASS][30] -> [SKIP][31] ([Intel XE#2316]) +3 other tests skip
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-5/igt@kms_flip@2x-blocking-wf_vblank.html
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_flip@2x-blocking-wf_vblank.html
* igt@kms_flip@flip-vs-panning-interruptible:
- shard-adlp: [PASS][32] -> [DMESG-WARN][33] ([Intel XE#4543] / [Intel XE#5208])
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-1/igt@kms_flip@flip-vs-panning-interruptible.html
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@kms_flip@flip-vs-panning-interruptible.html
* igt@kms_flip@flip-vs-rmfb:
- shard-adlp: [PASS][34] -> [DMESG-WARN][35] ([Intel XE#5208])
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-8/igt@kms_flip@flip-vs-rmfb.html
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@kms_flip@flip-vs-rmfb.html
* igt@kms_flip_scaled_crc@flip-64bpp-xtile-to-32bpp-xtile-downscaling@pipe-a-valid-mode:
- shard-adlp: [PASS][36] -> [DMESG-FAIL][37] ([Intel XE#4543] / [Intel XE#4921]) +3 other tests dmesg-fail
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-3/igt@kms_flip_scaled_crc@flip-64bpp-xtile-to-32bpp-xtile-downscaling@pipe-a-valid-mode.html
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@kms_flip_scaled_crc@flip-64bpp-xtile-to-32bpp-xtile-downscaling@pipe-a-valid-mode.html
* igt@kms_flip_tiling@flip-change-tiling@pipe-d-hdmi-a-1-y-to-y:
- shard-adlp: [PASS][38] -> [FAIL][39] ([Intel XE#1874]) +1 other test fail
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-2/igt@kms_flip_tiling@flip-change-tiling@pipe-d-hdmi-a-1-y-to-y.html
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-2/igt@kms_flip_tiling@flip-change-tiling@pipe-d-hdmi-a-1-y-to-y.html
* igt@kms_frontbuffer_tracking@drrs-suspend:
- shard-dg2-set2: NOTRUN -> [SKIP][40] ([Intel XE#651]) +10 other tests skip
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_frontbuffer_tracking@drrs-suspend.html
* igt@kms_frontbuffer_tracking@fbcpsr-1p-primscrn-shrfb-pgflip-blt:
- shard-dg2-set2: NOTRUN -> [SKIP][41] ([Intel XE#653]) +8 other tests skip
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_frontbuffer_tracking@fbcpsr-1p-primscrn-shrfb-pgflip-blt.html
- shard-adlp: NOTRUN -> [SKIP][42] ([Intel XE#653])
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@kms_frontbuffer_tracking@fbcpsr-1p-primscrn-shrfb-pgflip-blt.html
* igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-spr-indfb-draw-mmap-wc:
- shard-adlp: NOTRUN -> [SKIP][43] ([Intel XE#656])
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-spr-indfb-draw-mmap-wc.html
* igt@kms_hdr@static-toggle-dpms:
- shard-bmg: [PASS][44] -> [SKIP][45] ([Intel XE#1503])
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_hdr@static-toggle-dpms.html
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_hdr@static-toggle-dpms.html
* igt@kms_joiner@basic-max-non-joiner:
- shard-dg2-set2: NOTRUN -> [SKIP][46] ([Intel XE#4298])
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_joiner@basic-max-non-joiner.html
* igt@kms_plane_scaling@plane-upscale-factor-0-25-with-rotation@pipe-d:
- shard-adlp: [PASS][47] -> [DMESG-WARN][48] ([Intel XE#2953] / [Intel XE#4173]) +6 other tests dmesg-warn
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-1/igt@kms_plane_scaling@plane-upscale-factor-0-25-with-rotation@pipe-d.html
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-9/igt@kms_plane_scaling@plane-upscale-factor-0-25-with-rotation@pipe-d.html
* igt@kms_pm_dc@dc6-dpms:
- shard-dg2-set2: NOTRUN -> [SKIP][49] ([Intel XE#908])
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_pm_dc@dc6-dpms.html
* igt@kms_psr2_sf@fbc-pr-overlay-plane-update-sf-dmg-area:
- shard-dg2-set2: NOTRUN -> [SKIP][50] ([Intel XE#1406] / [Intel XE#1489]) +2 other tests skip
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_psr2_sf@fbc-pr-overlay-plane-update-sf-dmg-area.html
* igt@kms_psr@psr2-dpms:
- shard-dg2-set2: NOTRUN -> [SKIP][51] ([Intel XE#1406] / [Intel XE#2850] / [Intel XE#929]) +3 other tests skip
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_psr@psr2-dpms.html
* igt@kms_setmode@basic:
- shard-bmg: [PASS][52] -> [FAIL][53] ([Intel XE#2883]) +3 other tests fail
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-2/igt@kms_setmode@basic.html
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-4/igt@kms_setmode@basic.html
* igt@kms_vrr@flipline:
- shard-dg2-set2: NOTRUN -> [SKIP][54] ([Intel XE#455]) +7 other tests skip
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@kms_vrr@flipline.html
* igt@xe_eu_stall@blocking-re-enable:
- shard-dg2-set2: NOTRUN -> [SKIP][55] ([Intel XE#5626])
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@xe_eu_stall@blocking-re-enable.html
* igt@xe_eudebug@read-metadata:
- shard-dg2-set2: NOTRUN -> [SKIP][56] ([Intel XE#4837]) +1 other test skip
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_eudebug@read-metadata.html
* igt@xe_exec_basic@multigpu-no-exec-basic-defer-mmap:
- shard-dg2-set2: [PASS][57] -> [SKIP][58] ([Intel XE#1392]) +3 other tests skip
[57]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-466/igt@xe_exec_basic@multigpu-no-exec-basic-defer-mmap.html
[58]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-432/igt@xe_exec_basic@multigpu-no-exec-basic-defer-mmap.html
* igt@xe_exec_fault_mode@once-rebind:
- shard-dg2-set2: NOTRUN -> [SKIP][59] ([Intel XE#288]) +9 other tests skip
[59]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_exec_fault_mode@once-rebind.html
* igt@xe_exec_fault_mode@twice-userptr-rebind:
- shard-adlp: NOTRUN -> [SKIP][60] ([Intel XE#288] / [Intel XE#5561])
[60]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@xe_exec_fault_mode@twice-userptr-rebind.html
* igt@xe_exec_system_allocator@many-mmap-remap-ro-dontunmap:
- shard-adlp: NOTRUN -> [SKIP][61] ([Intel XE#4915]) +5 other tests skip
[61]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@xe_exec_system_allocator@many-mmap-remap-ro-dontunmap.html
* igt@xe_exec_system_allocator@process-many-execqueues-free-race:
- shard-dg2-set2: NOTRUN -> [SKIP][62] ([Intel XE#4915]) +83 other tests skip
[62]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_exec_system_allocator@process-many-execqueues-free-race.html
* igt@xe_oa@whitelisted-registers-userspace-config:
- shard-dg2-set2: NOTRUN -> [SKIP][63] ([Intel XE#3573]) +1 other test skip
[63]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_oa@whitelisted-registers-userspace-config.html
* igt@xe_pm@s2idle-basic:
- shard-adlp: [PASS][64] -> [DMESG-WARN][65] ([Intel XE#2953] / [Intel XE#4173] / [Intel XE#4504])
[64]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-8/igt@xe_pm@s2idle-basic.html
[65]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@xe_pm@s2idle-basic.html
* igt@xe_pm@s3-vm-bind-unbind-all:
- shard-adlp: [PASS][66] -> [DMESG-WARN][67] ([Intel XE#2953] / [Intel XE#4173] / [Intel XE#569])
[66]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-3/igt@xe_pm@s3-vm-bind-unbind-all.html
[67]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@xe_pm@s3-vm-bind-unbind-all.html
* igt@xe_pmu@all-fn-engine-activity-load:
- shard-dg2-set2: NOTRUN -> [SKIP][68] ([Intel XE#4650])
[68]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_pmu@all-fn-engine-activity-load.html
* igt@xe_pxp@pxp-stale-bo-bind-post-suspend:
- shard-dg2-set2: NOTRUN -> [SKIP][69] ([Intel XE#4733])
[69]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_pxp@pxp-stale-bo-bind-post-suspend.html
* igt@xe_query@multigpu-query-pxp-status:
- shard-dg2-set2: NOTRUN -> [SKIP][70] ([Intel XE#944])
[70]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_query@multigpu-query-pxp-status.html
* igt@xe_render_copy@render-stress-0-copies:
- shard-dg2-set2: NOTRUN -> [SKIP][71] ([Intel XE#4814])
[71]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@xe_render_copy@render-stress-0-copies.html
* igt@xe_sriov_scheduling@nonpreempt-engine-resets:
- shard-dg2-set2: NOTRUN -> [SKIP][72] ([Intel XE#4351])
[72]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@xe_sriov_scheduling@nonpreempt-engine-resets.html
#### Possible fixes ####
* igt@kms_atomic_transition@plane-all-modeset-transition@pipe-a-hdmi-a-1:
- shard-adlp: [FAIL][73] ([Intel XE#3908]) -> [PASS][74] +1 other test pass
[73]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-1/igt@kms_atomic_transition@plane-all-modeset-transition@pipe-a-hdmi-a-1.html
[74]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-8/igt@kms_atomic_transition@plane-all-modeset-transition@pipe-a-hdmi-a-1.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs:
- shard-dg2-set2: [INCOMPLETE][75] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4345]) -> [PASS][76]
[75]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs.html
[76]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-dp-4:
- shard-dg2-set2: [INCOMPLETE][77] ([Intel XE#6168]) -> [PASS][78]
[77]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-dp-4.html
[78]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-dp-4.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-hdmi-a-6:
- shard-dg2-set2: [DMESG-WARN][79] ([Intel XE#1727] / [Intel XE#3113]) -> [PASS][80]
[79]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-hdmi-a-6.html
[80]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-436/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-b-hdmi-a-6.html
* igt@kms_cursor_legacy@2x-flip-vs-cursor-legacy:
- shard-bmg: [SKIP][81] ([Intel XE#2291]) -> [PASS][82] +2 other tests pass
[81]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_cursor_legacy@2x-flip-vs-cursor-legacy.html
[82]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_cursor_legacy@2x-flip-vs-cursor-legacy.html
* igt@kms_dp_link_training@non-uhbr-sst:
- shard-bmg: [SKIP][83] ([Intel XE#4354]) -> [PASS][84]
[83]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_dp_link_training@non-uhbr-sst.html
[84]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-2/igt@kms_dp_link_training@non-uhbr-sst.html
* igt@kms_feature_discovery@display-2x:
- shard-bmg: [SKIP][85] ([Intel XE#2373]) -> [PASS][86]
[85]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_feature_discovery@display-2x.html
[86]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-2/igt@kms_feature_discovery@display-2x.html
* igt@kms_flip@2x-flip-vs-dpms:
- shard-bmg: [SKIP][87] ([Intel XE#2316]) -> [PASS][88] +2 other tests pass
[87]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_flip@2x-flip-vs-dpms.html
[88]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-2/igt@kms_flip@2x-flip-vs-dpms.html
* igt@kms_flip@flip-vs-rmfb-interruptible:
- shard-adlp: [DMESG-WARN][89] ([Intel XE#4543] / [Intel XE#5208]) -> [PASS][90]
[89]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-1/igt@kms_flip@flip-vs-rmfb-interruptible.html
[90]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-4/igt@kms_flip@flip-vs-rmfb-interruptible.html
* igt@kms_flip@flip-vs-rmfb-interruptible@b-hdmi-a1:
- shard-adlp: [DMESG-WARN][91] ([Intel XE#4543]) -> [PASS][92] +5 other tests pass
[91]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-1/igt@kms_flip@flip-vs-rmfb-interruptible@b-hdmi-a1.html
[92]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-4/igt@kms_flip@flip-vs-rmfb-interruptible@b-hdmi-a1.html
* igt@kms_flip@flip-vs-suspend-interruptible:
- shard-adlp: [DMESG-WARN][93] ([Intel XE#2953] / [Intel XE#4173]) -> [PASS][94] +3 other tests pass
[93]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-2/igt@kms_flip@flip-vs-suspend-interruptible.html
[94]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-2/igt@kms_flip@flip-vs-suspend-interruptible.html
* igt@kms_hdr@invalid-metadata-sizes:
- shard-bmg: [SKIP][95] ([Intel XE#1503]) -> [PASS][96]
[95]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_hdr@invalid-metadata-sizes.html
[96]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_hdr@invalid-metadata-sizes.html
* igt@kms_vblank@ts-continuation-dpms-suspend:
- shard-adlp: [INCOMPLETE][97] ([Intel XE#4488]) -> [PASS][98] +1 other test pass
[97]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-8/igt@kms_vblank@ts-continuation-dpms-suspend.html
[98]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@kms_vblank@ts-continuation-dpms-suspend.html
* igt@kms_vblank@ts-continuation-dpms-suspend@pipe-a-hdmi-a-1:
- shard-adlp: [DMESG-FAIL][99] -> [PASS][100]
[99]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-8/igt@kms_vblank@ts-continuation-dpms-suspend@pipe-a-hdmi-a-1.html
[100]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@kms_vblank@ts-continuation-dpms-suspend@pipe-a-hdmi-a-1.html
* igt@kms_vrr@cmrr@pipe-a-edp-1:
- shard-lnl: [FAIL][101] ([Intel XE#4459]) -> [PASS][102] +1 other test pass
[101]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-lnl-8/igt@kms_vrr@cmrr@pipe-a-edp-1.html
[102]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-lnl-3/igt@kms_vrr@cmrr@pipe-a-edp-1.html
* igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-rebind:
- shard-dg2-set2: [SKIP][103] ([Intel XE#1392]) -> [PASS][104] +3 other tests pass
[103]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-432/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-rebind.html
[104]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-rebind.html
* igt@xe_exec_reset@parallel-gt-reset:
- shard-adlp: [DMESG-WARN][105] ([Intel XE#3876]) -> [PASS][106]
[105]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-adlp-8/igt@xe_exec_reset@parallel-gt-reset.html
[106]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-adlp-3/igt@xe_exec_reset@parallel-gt-reset.html
* igt@xe_pm@s2idle-d3hot-basic-exec:
- shard-dg2-set2: [INCOMPLETE][107] ([Intel XE#4504]) -> [PASS][108]
[107]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-dg2-435/igt@xe_pm@s2idle-d3hot-basic-exec.html
[108]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-dg2-434/igt@xe_pm@s2idle-d3hot-basic-exec.html
#### Warnings ####
* igt@kms_content_protection@atomic-dpms:
- shard-bmg: [FAIL][109] ([Intel XE#1178]) -> [SKIP][110] ([Intel XE#2341])
[109]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-5/igt@kms_content_protection@atomic-dpms.html
[110]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_content_protection@atomic-dpms.html
* igt@kms_content_protection@srm:
- shard-bmg: [SKIP][111] ([Intel XE#2341]) -> [FAIL][112] ([Intel XE#1178])
[111]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_content_protection@srm.html
[112]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_content_protection@srm.html
* igt@kms_content_protection@uevent:
- shard-bmg: [FAIL][113] ([Intel XE#1188]) -> [SKIP][114] ([Intel XE#2341])
[113]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-5/igt@kms_content_protection@uevent.html
[114]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_content_protection@uevent.html
* igt@kms_frontbuffer_tracking@drrs-2p-pri-indfb-multidraw:
- shard-bmg: [SKIP][115] ([Intel XE#2311]) -> [SKIP][116] ([Intel XE#2312]) +11 other tests skip
[115]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_frontbuffer_tracking@drrs-2p-pri-indfb-multidraw.html
[116]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_frontbuffer_tracking@drrs-2p-pri-indfb-multidraw.html
* igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc:
- shard-bmg: [SKIP][117] ([Intel XE#2312]) -> [SKIP][118] ([Intel XE#2311]) +6 other tests skip
[117]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc.html
[118]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-2/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbc-2p-primscrn-indfb-msflip-blt:
- shard-bmg: [SKIP][119] ([Intel XE#5390]) -> [SKIP][120] ([Intel XE#2312]) +5 other tests skip
[119]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-indfb-msflip-blt.html
[120]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-indfb-msflip-blt.html
* igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-spr-indfb-onoff:
- shard-bmg: [SKIP][121] ([Intel XE#2312]) -> [SKIP][122] ([Intel XE#5390]) +3 other tests skip
[121]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-spr-indfb-onoff.html
[122]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-2/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-spr-indfb-onoff.html
* igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-cur-indfb-draw-blt:
- shard-bmg: [SKIP][123] ([Intel XE#2313]) -> [SKIP][124] ([Intel XE#2312]) +10 other tests skip
[123]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-cur-indfb-draw-blt.html
[124]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-6/igt@kms_frontbuffer_tracking@fbcpsr-2p-scndscrn-cur-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@psr-2p-primscrn-indfb-plflip-blt:
- shard-bmg: [SKIP][125] ([Intel XE#2312]) -> [SKIP][126] ([Intel XE#2313]) +7 other tests skip
[125]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-6/igt@kms_frontbuffer_tracking@psr-2p-primscrn-indfb-plflip-blt.html
[126]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-5/igt@kms_frontbuffer_tracking@psr-2p-primscrn-indfb-plflip-blt.html
* igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv:
- shard-bmg: [ABORT][127] ([Intel XE#5466] / [Intel XE#5530]) -> [ABORT][128] ([Intel XE#4917] / [Intel XE#5466] / [Intel XE#5530])
[127]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c/shard-bmg-5/igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv.html
[128]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/shard-bmg-1/igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv.html
{name}: This element is suppressed. This means it is ignored when computing
the status of the difference (SUCCESS, WARNING, or FAILURE).
[Intel XE#1124]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1124
[Intel XE#1178]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1178
[Intel XE#1188]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1188
[Intel XE#1392]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1392
[Intel XE#1406]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1406
[Intel XE#1489]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1489
[Intel XE#1503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1503
[Intel XE#1727]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1727
[Intel XE#1874]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1874
[Intel XE#2191]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2191
[Intel XE#2291]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2291
[Intel XE#2311]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2311
[Intel XE#2312]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2312
[Intel XE#2313]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2313
[Intel XE#2314]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2314
[Intel XE#2316]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2316
[Intel XE#2341]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2341
[Intel XE#2373]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2373
[Intel XE#2652]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2652
[Intel XE#2850]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2850
[Intel XE#288]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/288
[Intel XE#2883]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2883
[Intel XE#2894]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2894
[Intel XE#2953]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2953
[Intel XE#306]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/306
[Intel XE#308]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/308
[Intel XE#3113]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3113
[Intel XE#316]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/316
[Intel XE#3442]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3442
[Intel XE#3573]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3573
[Intel XE#373]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/373
[Intel XE#3876]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3876
[Intel XE#3908]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3908
[Intel XE#4173]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4173
[Intel XE#4298]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4298
[Intel XE#4345]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4345
[Intel XE#4351]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4351
[Intel XE#4354]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4354
[Intel XE#4416]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4416
[Intel XE#4422]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4422
[Intel XE#4459]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4459
[Intel XE#4488]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4488
[Intel XE#4504]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4504
[Intel XE#4543]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4543
[Intel XE#455]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/455
[Intel XE#4650]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4650
[Intel XE#4733]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4733
[Intel XE#4814]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4814
[Intel XE#4837]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4837
[Intel XE#4915]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4915
[Intel XE#4917]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4917
[Intel XE#4921]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4921
[Intel XE#5208]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5208
[Intel XE#5390]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5390
[Intel XE#5466]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5466
[Intel XE#5503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5503
[Intel XE#5530]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5530
[Intel XE#5561]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5561
[Intel XE#5624]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5624
[Intel XE#5626]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5626
[Intel XE#569]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/569
[Intel XE#6168]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6168
[Intel XE#651]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/651
[Intel XE#653]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/653
[Intel XE#656]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/656
[Intel XE#787]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/787
[Intel XE#908]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/908
[Intel XE#929]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/929
[Intel XE#944]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/944
Build changes
-------------
* Linux: xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c -> xe-pw-153981v2
IGT_8543: 8543
xe-3788-acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c: acd89e2bfd2cc09d3bcab83abc7237a907a1ac7c
xe-pw-153981v2: 153981v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-153981v2/index.html
[-- Attachment #2: Type: text/html, Size: 41959 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread