* [PATCH 1/2] drm/i915: Track fence region ID in plane state
@ 2026-03-31 16:21 Ville Syrjala
2026-03-31 16:21 ` [PATCH 2/2] drm/i915: Remove the vma parent interface Ville Syrjala
` (3 more replies)
0 siblings, 4 replies; 8+ messages in thread
From: Ville Syrjala @ 2026-03-31 16:21 UTC (permalink / raw)
To: intel-gfx; +Cc: intel-xe
From: Ville Syrjälä <ville.syrjala@linux.intel.com>
Get rid of the needlessly complicated PLANE_HAS_FENCE +
intel_parent_vma_fence_id() dance by simply tracking the
fence_id directly in the plane state.
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
---
.../drm/i915/display/intel_display_types.h | 5 +--
drivers/gpu/drm/i915/display/intel_fb_pin.c | 33 ++++++++++---------
drivers/gpu/drm/i915/display/intel_fb_pin.h | 5 ++-
drivers/gpu/drm/i915/display/intel_fbc.c | 11 ++-----
drivers/gpu/drm/i915/display/intel_fbdev.c | 14 ++++----
drivers/gpu/drm/i915/display/intel_plane.c | 3 +-
drivers/gpu/drm/i915/i915_initial_plane.c | 2 +-
drivers/gpu/drm/xe/display/xe_fb_pin.c | 8 ++---
drivers/gpu/drm/xe/display/xe_initial_plane.c | 2 +-
9 files changed, 42 insertions(+), 41 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h b/drivers/gpu/drm/i915/display/intel_display_types.h
index e2496db1642a..73eb4f38620c 100644
--- a/drivers/gpu/drm/i915/display/intel_display_types.h
+++ b/drivers/gpu/drm/i915/display/intel_display_types.h
@@ -683,14 +683,15 @@ struct intel_plane_state {
struct i915_vma *ggtt_vma;
struct i915_vma *dpt_vma;
- unsigned long flags;
-#define PLANE_HAS_FENCE BIT(0)
struct intel_fb_view view;
/* for legacy cursor fb unpin */
struct drm_vblank_work unpin_work;
+ /* fenced region ID (-1 if none) */
+ s8 fence_id;
+
/* Plane pxp decryption state */
bool decrypt;
diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.c b/drivers/gpu/drm/i915/display/intel_fb_pin.c
index 738d77a1468a..0b8b057647af 100644
--- a/drivers/gpu/drm/i915/display/intel_fb_pin.c
+++ b/drivers/gpu/drm/i915/display/intel_fb_pin.c
@@ -26,7 +26,6 @@ static struct i915_vma *
intel_fb_pin_to_dpt(const struct drm_framebuffer *fb,
const struct i915_gtt_view *view,
unsigned int alignment,
- unsigned long *out_flags,
struct intel_dpt *dpt)
{
struct drm_device *dev = fb->dev;
@@ -115,8 +114,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
unsigned int alignment,
unsigned int phys_alignment,
unsigned int vtd_guard,
- bool uses_fence,
- unsigned long *out_flags)
+ int *out_fence_id)
{
struct drm_device *dev = fb->dev;
struct intel_display *display = to_intel_display(dev);
@@ -177,7 +175,10 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
goto err_unpin;
}
- if (uses_fence && i915_vma_is_map_and_fenceable(vma)) {
+ if (out_fence_id)
+ *out_fence_id = -1;
+
+ if (out_fence_id && i915_vma_is_map_and_fenceable(vma)) {
/*
* Install a fence for tiled scan-out. Pre-i965 always needs a
* fence, whereas 965+ only requires a fence if using
@@ -203,7 +204,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
ret = 0;
if (vma->fence)
- *out_flags |= PLANE_HAS_FENCE;
+ *out_fence_id |= vma->fence->id;
}
i915_vma_get(vma);
@@ -225,9 +226,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
return vma;
}
-void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags)
+void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id)
{
- if (flags & PLANE_HAS_FENCE)
+ if (fence_id >= 0)
i915_vma_unpin_fence(vma);
i915_vma_unpin(vma);
i915_vma_put(vma);
@@ -271,17 +272,18 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state,
struct i915_vma *vma;
if (!intel_fb_uses_dpt(&fb->base)) {
+ int fence_id = -1;
+
vma = intel_fb_pin_to_ggtt(&fb->base, &plane_state->view.gtt,
intel_plane_fb_min_alignment(plane_state),
intel_plane_fb_min_phys_alignment(plane_state),
intel_plane_fb_vtd_guard(plane_state),
- intel_plane_uses_fence(plane_state),
- &plane_state->flags);
+ intel_plane_uses_fence(plane_state) ? &fence_id : NULL);
if (IS_ERR(vma))
return PTR_ERR(vma);
plane_state->ggtt_vma = vma;
-
+ plane_state->fence_id = fence_id;
} else {
unsigned int alignment = intel_plane_fb_min_alignment(plane_state);
@@ -292,8 +294,7 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state,
plane_state->ggtt_vma = vma;
vma = intel_fb_pin_to_dpt(&fb->base, &plane_state->view.gtt,
- alignment, &plane_state->flags,
- fb->dpt);
+ alignment, fb->dpt);
if (IS_ERR(vma)) {
i915_dpt_unpin_from_ggtt(fb->dpt);
plane_state->ggtt_vma = NULL;
@@ -338,12 +339,14 @@ void intel_plane_unpin_fb(struct intel_plane_state *old_plane_state)
if (!intel_fb_uses_dpt(&fb->base)) {
vma = fetch_and_zero(&old_plane_state->ggtt_vma);
- if (vma)
- intel_fb_unpin_vma(vma, old_plane_state->flags);
+ if (vma) {
+ intel_fb_unpin_vma(vma, old_plane_state->fence_id);
+ old_plane_state->fence_id = -1;
+ }
} else {
vma = fetch_and_zero(&old_plane_state->dpt_vma);
if (vma)
- intel_fb_unpin_vma(vma, old_plane_state->flags);
+ intel_fb_unpin_vma(vma, -1);
vma = fetch_and_zero(&old_plane_state->ggtt_vma);
if (vma)
diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.h b/drivers/gpu/drm/i915/display/intel_fb_pin.h
index 81ab79da1af7..2eca42b74c4a 100644
--- a/drivers/gpu/drm/i915/display/intel_fb_pin.h
+++ b/drivers/gpu/drm/i915/display/intel_fb_pin.h
@@ -20,10 +20,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
unsigned int alignment,
unsigned int phys_alignment,
unsigned int vtd_guard,
- bool uses_fence,
- unsigned long *out_flags);
+ int *out_fence_id);
-void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags);
+void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id);
int intel_plane_pin_fb(struct intel_plane_state *new_plane_state,
const struct intel_plane_state *old_plane_state);
diff --git a/drivers/gpu/drm/i915/display/intel_fbc.c b/drivers/gpu/drm/i915/display/intel_fbc.c
index ea0ce00c8474..677ac5be749b 100644
--- a/drivers/gpu/drm/i915/display/intel_fbc.c
+++ b/drivers/gpu/drm/i915/display/intel_fbc.c
@@ -1458,13 +1458,10 @@ static void intel_fbc_update_state(struct intel_atomic_state *state,
fbc_state->fence_y_offset = intel_plane_fence_y_offset(plane_state);
- drm_WARN_ON(display->drm, plane_state->flags & PLANE_HAS_FENCE &&
+ drm_WARN_ON(display->drm, plane_state->fence_id >= 0 &&
!intel_fbc_has_fences(display));
- if (plane_state->flags & PLANE_HAS_FENCE)
- fbc_state->fence_id = intel_parent_vma_fence_id(display, plane_state->ggtt_vma);
- else
- fbc_state->fence_id = -1;
+ fbc_state->fence_id = plane_state->fence_id;
fbc_state->cfb_stride = intel_fbc_cfb_stride(plane_state);
fbc_state->cfb_size = intel_fbc_cfb_size(plane_state);
@@ -1487,9 +1484,7 @@ static bool intel_fbc_is_fence_ok(const struct intel_plane_state *plane_state)
* so have no fence associated with it) due to aperture constraints
* at the time of pinning.
*/
- return DISPLAY_VER(display) >= 9 ||
- (plane_state->flags & PLANE_HAS_FENCE &&
- intel_parent_vma_fence_id(display, plane_state->ggtt_vma) != -1);
+ return DISPLAY_VER(display) >= 9 || plane_state->fence_id >= 0;
}
static bool intel_fbc_is_cfb_ok(const struct intel_plane_state *plane_state)
diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c
index bdaaf3edba0c..0d7be5186393 100644
--- a/drivers/gpu/drm/i915/display/intel_fbdev.c
+++ b/drivers/gpu/drm/i915/display/intel_fbdev.c
@@ -60,7 +60,7 @@
struct intel_fbdev {
struct intel_framebuffer *fb;
struct i915_vma *vma;
- unsigned long vma_flags;
+ s8 fence_id;
};
static struct intel_fbdev *to_intel_fbdev(struct drm_fb_helper *fb_helper)
@@ -141,7 +141,7 @@ static void intel_fbdev_fb_destroy(struct fb_info *info)
* the info->screen_base mmaping. Leaking the VMA is simpler than
* trying to rectify all the possible error paths leading here.
*/
- intel_fb_unpin_vma(ifbdev->vma, ifbdev->vma_flags);
+ intel_fb_unpin_vma(ifbdev->vma, ifbdev->fence_id);
drm_framebuffer_remove(fb_helper->fb);
drm_client_release(&fb_helper->client);
@@ -269,9 +269,9 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
struct fb_info *info = helper->info;
struct ref_tracker *wakeref;
struct i915_vma *vma;
- unsigned long flags = 0;
bool prealloc = false;
struct drm_gem_object *obj;
+ int fence_id = -1;
int ret;
ifbdev->fb = NULL;
@@ -314,7 +314,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
fb->min_alignment, 0,
intel_fb_view_vtd_guard(&fb->base, &fb->normal_view,
DRM_MODE_ROTATE_0),
- false, &flags);
+ &fence_id);
if (IS_ERR(vma)) {
ret = PTR_ERR(vma);
goto out_unlock;
@@ -345,14 +345,14 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper,
drm_dbg_kms(display->drm, "allocated %dx%d fb\n", fb->base.width, fb->base.height);
ifbdev->fb = fb;
ifbdev->vma = vma;
- ifbdev->vma_flags = flags;
+ ifbdev->fence_id = fence_id;
intel_display_rpm_put(display, wakeref);
return 0;
out_unpin:
- intel_fb_unpin_vma(vma, flags);
+ intel_fb_unpin_vma(vma, fence_id);
out_unlock:
intel_display_rpm_put(display, wakeref);
@@ -539,6 +539,8 @@ void intel_fbdev_setup(struct intel_display *display)
if (!ifbdev)
return;
+ ifbdev->fence_id = -1;
+
display->fbdev.fbdev = ifbdev;
if (intel_fbdev_init_bios(display, ifbdev))
preferred_bpp = intel_fbdev_color_mode(ifbdev->fb->base.format);
diff --git a/drivers/gpu/drm/i915/display/intel_plane.c b/drivers/gpu/drm/i915/display/intel_plane.c
index 5390ceb21ca4..f15dd9e91243 100644
--- a/drivers/gpu/drm/i915/display/intel_plane.c
+++ b/drivers/gpu/drm/i915/display/intel_plane.c
@@ -70,6 +70,7 @@ static void intel_plane_state_reset(struct intel_plane_state *plane_state,
__drm_atomic_helper_plane_state_reset(&plane_state->uapi, &plane->base);
plane_state->scaler_id = -1;
+ plane_state->fence_id = -1;
}
struct intel_plane *intel_plane_alloc(void)
@@ -137,7 +138,7 @@ intel_plane_duplicate_state(struct drm_plane *plane)
intel_state->ggtt_vma = NULL;
intel_state->dpt_vma = NULL;
- intel_state->flags = 0;
+ intel_state->fence_id = -1;
intel_state->damage = DRM_RECT_INIT(0, 0, 0, 0);
/* add reference to fb */
diff --git a/drivers/gpu/drm/i915/i915_initial_plane.c b/drivers/gpu/drm/i915/i915_initial_plane.c
index 390a9248d631..db51a468ddd4 100644
--- a/drivers/gpu/drm/i915/i915_initial_plane.c
+++ b/drivers/gpu/drm/i915/i915_initial_plane.c
@@ -268,7 +268,7 @@ i915_initial_plane_setup(struct drm_plane_state *_plane_state,
plane_state->ggtt_vma = i915_vma_get(vma);
if (intel_plane_uses_fence(plane_state) &&
i915_vma_pin_fence(vma) == 0 && vma->fence)
- plane_state->flags |= PLANE_HAS_FENCE;
+ plane_state->fence_id = vma->fence->id;
plane_state->surf = i915_ggtt_offset(plane_state->ggtt_vma);
diff --git a/drivers/gpu/drm/xe/display/xe_fb_pin.c b/drivers/gpu/drm/xe/display/xe_fb_pin.c
index e45a1e7a4670..739d9c019094 100644
--- a/drivers/gpu/drm/xe/display/xe_fb_pin.c
+++ b/drivers/gpu/drm/xe/display/xe_fb_pin.c
@@ -418,15 +418,15 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb,
unsigned int alignment,
unsigned int phys_alignment,
unsigned int vtd_guard,
- bool uses_fence,
- unsigned long *out_flags)
+ int *out_fence_id)
{
- *out_flags = 0;
+ if (out_fence_id)
+ *out_fence_id = -1;
return __xe_pin_fb_vma(to_intel_framebuffer(fb), view, alignment);
}
-void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags)
+void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id)
{
__xe_unpin_fb_vma(vma);
}
diff --git a/drivers/gpu/drm/xe/display/xe_initial_plane.c b/drivers/gpu/drm/xe/display/xe_initial_plane.c
index 8bcae552dddc..09ec8f94bf57 100644
--- a/drivers/gpu/drm/xe/display/xe_initial_plane.c
+++ b/drivers/gpu/drm/xe/display/xe_initial_plane.c
@@ -153,7 +153,7 @@ xe_initial_plane_setup(struct drm_plane_state *_plane_state,
struct i915_vma *vma;
vma = intel_fb_pin_to_ggtt(fb, &plane_state->view.gtt,
- 0, 0, 0, false, &plane_state->flags);
+ 0, 0, 0, NULL);
if (IS_ERR(vma))
return PTR_ERR(vma);
--
2.52.0
^ permalink raw reply related [flat|nested] 8+ messages in thread* [PATCH 2/2] drm/i915: Remove the vma parent interface 2026-03-31 16:21 [PATCH 1/2] drm/i915: Track fence region ID in plane state Ville Syrjala @ 2026-03-31 16:21 ` Ville Syrjala 2026-04-01 13:10 ` Jani Nikula 2026-03-31 17:15 ` ✗ i915.CI.BAT: failure for series starting with [1/2] drm/i915: Track fence region ID in plane state Patchwork ` (2 subsequent siblings) 3 siblings, 1 reply; 8+ messages in thread From: Ville Syrjala @ 2026-03-31 16:21 UTC (permalink / raw) To: intel-gfx; +Cc: intel-xe From: Ville Syrjälä <ville.syrjala@linux.intel.com> With the fb pinning stuff directly returning the fence_id there is no longer any need for the vma parent interface. Get rid of it. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> --- drivers/gpu/drm/i915/display/intel_parent.c | 9 --------- drivers/gpu/drm/i915/display/intel_parent.h | 3 --- drivers/gpu/drm/i915/i915_driver.c | 1 - drivers/gpu/drm/i915/i915_vma.c | 10 ---------- drivers/gpu/drm/i915/i915_vma.h | 2 -- include/drm/intel/display_parent_interface.h | 7 ------- 6 files changed, 32 deletions(-) diff --git a/drivers/gpu/drm/i915/display/intel_parent.c b/drivers/gpu/drm/i915/display/intel_parent.c index 2e3bad2b3e6b..4142fe3eed7c 100644 --- a/drivers/gpu/drm/i915/display/intel_parent.c +++ b/drivers/gpu/drm/i915/display/intel_parent.c @@ -338,15 +338,6 @@ void intel_parent_stolen_node_free(struct intel_display *display, const struct i display->parent->stolen->node_free(node); } -/* vma */ -int intel_parent_vma_fence_id(struct intel_display *display, const struct i915_vma *vma) -{ - if (!display->parent->vma) - return -1; - - return display->parent->vma->fence_id(vma); -} - /* generic */ void intel_parent_fence_priority_display(struct intel_display *display, struct dma_fence *fence) { diff --git a/drivers/gpu/drm/i915/display/intel_parent.h b/drivers/gpu/drm/i915/display/intel_parent.h index 2013e5ed5aa9..c1214d3329a8 100644 --- a/drivers/gpu/drm/i915/display/intel_parent.h +++ b/drivers/gpu/drm/i915/display/intel_parent.h @@ -109,9 +109,6 @@ u64 intel_parent_stolen_node_size(struct intel_display *display, const struct in struct intel_stolen_node *intel_parent_stolen_node_alloc(struct intel_display *display); void intel_parent_stolen_node_free(struct intel_display *display, const struct intel_stolen_node *node); -/* vma */ -int intel_parent_vma_fence_id(struct intel_display *display, const struct i915_vma *vma); - /* generic */ bool intel_parent_has_auxccs(struct intel_display *display); bool intel_parent_has_fenced_regions(struct intel_display *display); diff --git a/drivers/gpu/drm/i915/i915_driver.c b/drivers/gpu/drm/i915/i915_driver.c index 385a634c3ed0..6dde714d4646 100644 --- a/drivers/gpu/drm/i915/i915_driver.c +++ b/drivers/gpu/drm/i915/i915_driver.c @@ -780,7 +780,6 @@ static const struct intel_display_parent_interface parent = { .rpm = &i915_display_rpm_interface, .rps = &i915_display_rps_interface, .stolen = &i915_display_stolen_interface, - .vma = &i915_display_vma_interface, .fence_priority_display = fence_priority_display, .has_auxccs = has_auxccs, diff --git a/drivers/gpu/drm/i915/i915_vma.c b/drivers/gpu/drm/i915/i915_vma.c index 6a3a4d4244dc..afc192d9931b 100644 --- a/drivers/gpu/drm/i915/i915_vma.c +++ b/drivers/gpu/drm/i915/i915_vma.c @@ -27,7 +27,6 @@ #include <drm/drm_gem.h> #include <drm/drm_print.h> -#include <drm/intel/display_parent_interface.h> #include "display/intel_fb.h" #include "display/intel_frontbuffer.h" @@ -2333,12 +2332,3 @@ int __init i915_vma_module_init(void) return 0; } - -static int i915_vma_fence_id(const struct i915_vma *vma) -{ - return vma->fence ? vma->fence->id : -1; -} - -const struct intel_display_vma_interface i915_display_vma_interface = { - .fence_id = i915_vma_fence_id, -}; diff --git a/drivers/gpu/drm/i915/i915_vma.h b/drivers/gpu/drm/i915/i915_vma.h index fa2d9b429db6..892306ab935d 100644 --- a/drivers/gpu/drm/i915/i915_vma.h +++ b/drivers/gpu/drm/i915/i915_vma.h @@ -476,6 +476,4 @@ int i915_vma_module_init(void); I915_SELFTEST_DECLARE(int i915_vma_get_pages(struct i915_vma *vma)); I915_SELFTEST_DECLARE(void i915_vma_put_pages(struct i915_vma *vma)); -extern const struct intel_display_vma_interface i915_display_vma_interface; - #endif diff --git a/include/drm/intel/display_parent_interface.h b/include/drm/intel/display_parent_interface.h index 97ec94a2e749..aef6a16efd90 100644 --- a/include/drm/intel/display_parent_interface.h +++ b/include/drm/intel/display_parent_interface.h @@ -176,10 +176,6 @@ struct intel_display_stolen_interface { void (*node_free)(const struct intel_stolen_node *node); }; -struct intel_display_vma_interface { - int (*fence_id)(const struct i915_vma *vma); -}; - /** * struct intel_display_parent_interface - services parent driver provides to display * @@ -235,9 +231,6 @@ struct intel_display_parent_interface { /** @stolen: Stolen memory. */ const struct intel_display_stolen_interface *stolen; - /** @vma: VMA interface. Optional. */ - const struct intel_display_vma_interface *vma; - /* Generic independent functions */ struct { /** @fence_priority_display: Set display priority. Optional. */ -- 2.52.0 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH 2/2] drm/i915: Remove the vma parent interface 2026-03-31 16:21 ` [PATCH 2/2] drm/i915: Remove the vma parent interface Ville Syrjala @ 2026-04-01 13:10 ` Jani Nikula 0 siblings, 0 replies; 8+ messages in thread From: Jani Nikula @ 2026-04-01 13:10 UTC (permalink / raw) To: Ville Syrjala, intel-gfx; +Cc: intel-xe On Tue, 31 Mar 2026, Ville Syrjala <ville.syrjala@linux.intel.com> wrote: > From: Ville Syrjälä <ville.syrjala@linux.intel.com> > > With the fb pinning stuff directly returning the fence_id > there is no longer any need for the vma parent interface. > Get rid of it. > > Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Jani Nikula <jani.nikula@intel.com> > --- > drivers/gpu/drm/i915/display/intel_parent.c | 9 --------- > drivers/gpu/drm/i915/display/intel_parent.h | 3 --- > drivers/gpu/drm/i915/i915_driver.c | 1 - > drivers/gpu/drm/i915/i915_vma.c | 10 ---------- > drivers/gpu/drm/i915/i915_vma.h | 2 -- > include/drm/intel/display_parent_interface.h | 7 ------- > 6 files changed, 32 deletions(-) > > diff --git a/drivers/gpu/drm/i915/display/intel_parent.c b/drivers/gpu/drm/i915/display/intel_parent.c > index 2e3bad2b3e6b..4142fe3eed7c 100644 > --- a/drivers/gpu/drm/i915/display/intel_parent.c > +++ b/drivers/gpu/drm/i915/display/intel_parent.c > @@ -338,15 +338,6 @@ void intel_parent_stolen_node_free(struct intel_display *display, const struct i > display->parent->stolen->node_free(node); > } > > -/* vma */ > -int intel_parent_vma_fence_id(struct intel_display *display, const struct i915_vma *vma) > -{ > - if (!display->parent->vma) > - return -1; > - > - return display->parent->vma->fence_id(vma); > -} > - > /* generic */ > void intel_parent_fence_priority_display(struct intel_display *display, struct dma_fence *fence) > { > diff --git a/drivers/gpu/drm/i915/display/intel_parent.h b/drivers/gpu/drm/i915/display/intel_parent.h > index 2013e5ed5aa9..c1214d3329a8 100644 > --- a/drivers/gpu/drm/i915/display/intel_parent.h > +++ b/drivers/gpu/drm/i915/display/intel_parent.h > @@ -109,9 +109,6 @@ u64 intel_parent_stolen_node_size(struct intel_display *display, const struct in > struct intel_stolen_node *intel_parent_stolen_node_alloc(struct intel_display *display); > void intel_parent_stolen_node_free(struct intel_display *display, const struct intel_stolen_node *node); > > -/* vma */ > -int intel_parent_vma_fence_id(struct intel_display *display, const struct i915_vma *vma); > - > /* generic */ > bool intel_parent_has_auxccs(struct intel_display *display); > bool intel_parent_has_fenced_regions(struct intel_display *display); > diff --git a/drivers/gpu/drm/i915/i915_driver.c b/drivers/gpu/drm/i915/i915_driver.c > index 385a634c3ed0..6dde714d4646 100644 > --- a/drivers/gpu/drm/i915/i915_driver.c > +++ b/drivers/gpu/drm/i915/i915_driver.c > @@ -780,7 +780,6 @@ static const struct intel_display_parent_interface parent = { > .rpm = &i915_display_rpm_interface, > .rps = &i915_display_rps_interface, > .stolen = &i915_display_stolen_interface, > - .vma = &i915_display_vma_interface, > > .fence_priority_display = fence_priority_display, > .has_auxccs = has_auxccs, > diff --git a/drivers/gpu/drm/i915/i915_vma.c b/drivers/gpu/drm/i915/i915_vma.c > index 6a3a4d4244dc..afc192d9931b 100644 > --- a/drivers/gpu/drm/i915/i915_vma.c > +++ b/drivers/gpu/drm/i915/i915_vma.c > @@ -27,7 +27,6 @@ > > #include <drm/drm_gem.h> > #include <drm/drm_print.h> > -#include <drm/intel/display_parent_interface.h> > > #include "display/intel_fb.h" > #include "display/intel_frontbuffer.h" > @@ -2333,12 +2332,3 @@ int __init i915_vma_module_init(void) > > return 0; > } > - > -static int i915_vma_fence_id(const struct i915_vma *vma) > -{ > - return vma->fence ? vma->fence->id : -1; > -} > - > -const struct intel_display_vma_interface i915_display_vma_interface = { > - .fence_id = i915_vma_fence_id, > -}; > diff --git a/drivers/gpu/drm/i915/i915_vma.h b/drivers/gpu/drm/i915/i915_vma.h > index fa2d9b429db6..892306ab935d 100644 > --- a/drivers/gpu/drm/i915/i915_vma.h > +++ b/drivers/gpu/drm/i915/i915_vma.h > @@ -476,6 +476,4 @@ int i915_vma_module_init(void); > I915_SELFTEST_DECLARE(int i915_vma_get_pages(struct i915_vma *vma)); > I915_SELFTEST_DECLARE(void i915_vma_put_pages(struct i915_vma *vma)); > > -extern const struct intel_display_vma_interface i915_display_vma_interface; > - > #endif > diff --git a/include/drm/intel/display_parent_interface.h b/include/drm/intel/display_parent_interface.h > index 97ec94a2e749..aef6a16efd90 100644 > --- a/include/drm/intel/display_parent_interface.h > +++ b/include/drm/intel/display_parent_interface.h > @@ -176,10 +176,6 @@ struct intel_display_stolen_interface { > void (*node_free)(const struct intel_stolen_node *node); > }; > > -struct intel_display_vma_interface { > - int (*fence_id)(const struct i915_vma *vma); > -}; > - > /** > * struct intel_display_parent_interface - services parent driver provides to display > * > @@ -235,9 +231,6 @@ struct intel_display_parent_interface { > /** @stolen: Stolen memory. */ > const struct intel_display_stolen_interface *stolen; > > - /** @vma: VMA interface. Optional. */ > - const struct intel_display_vma_interface *vma; > - > /* Generic independent functions */ > struct { > /** @fence_priority_display: Set display priority. Optional. */ -- Jani Nikula, Intel ^ permalink raw reply [flat|nested] 8+ messages in thread
* ✗ i915.CI.BAT: failure for series starting with [1/2] drm/i915: Track fence region ID in plane state 2026-03-31 16:21 [PATCH 1/2] drm/i915: Track fence region ID in plane state Ville Syrjala 2026-03-31 16:21 ` [PATCH 2/2] drm/i915: Remove the vma parent interface Ville Syrjala @ 2026-03-31 17:15 ` Patchwork 2026-04-01 13:10 ` [PATCH 1/2] " Jani Nikula 2026-04-02 14:54 ` Jani Nikula 3 siblings, 0 replies; 8+ messages in thread From: Patchwork @ 2026-03-31 17:15 UTC (permalink / raw) To: Ville Syrjala; +Cc: intel-gfx [-- Attachment #1: Type: text/plain, Size: 15605 bytes --] == Series Details == Series: series starting with [1/2] drm/i915: Track fence region ID in plane state URL : https://patchwork.freedesktop.org/series/164182/ State : failure == Summary == CI Bug Log - changes from CI_DRM_18256 -> Patchwork_164182v1 ==================================================== Summary ------- **FAILURE** Serious unknown changes coming with Patchwork_164182v1 absolutely need to be verified manually. If you think the reported changes have nothing to do with the changes introduced in Patchwork_164182v1, please notify your bug team (I915-ci-infra@lists.freedesktop.org) to allow them to document this new failure mode, which will reduce false positives in CI. External URL: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/index.html Participating hosts (41 -> 40) ------------------------------ Additional (1): bat-adls-6 Missing (2): bat-dg2-13 fi-snb-2520m Possible new issues ------------------- Here are the unknown changes that may have been introduced in Patchwork_164182v1: ### IGT changes ### #### Possible regressions #### * igt@kms_busy@basic: - fi-pnv-d510: [PASS][1] -> [ABORT][2] [1]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-pnv-d510/igt@kms_busy@basic.html [2]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-pnv-d510/igt@kms_busy@basic.html * igt@kms_busy@basic@flip: - fi-cfl-8700k: [PASS][3] -> [DMESG-WARN][4] [3]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-8700k/igt@kms_busy@basic@flip.html [4]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-8700k/igt@kms_busy@basic@flip.html - bat-adls-6: NOTRUN -> [DMESG-WARN][5] [5]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-adls-6/igt@kms_busy@basic@flip.html - fi-pnv-d510: [PASS][6] -> [DMESG-WARN][7] [6]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-pnv-d510/igt@kms_busy@basic@flip.html [7]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-pnv-d510/igt@kms_busy@basic@flip.html - bat-rpls-4: [PASS][8] -> [DMESG-WARN][9] [8]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-rpls-4/igt@kms_busy@basic@flip.html [9]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-rpls-4/igt@kms_busy@basic@flip.html - fi-kbl-7567u: [PASS][10] -> [ABORT][11] +1 other test abort [10]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-kbl-7567u/igt@kms_busy@basic@flip.html [11]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-kbl-7567u/igt@kms_busy@basic@flip.html - bat-jsl-5: [PASS][12] -> [ABORT][13] +1 other test abort [12]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-jsl-5/igt@kms_busy@basic@flip.html [13]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-jsl-5/igt@kms_busy@basic@flip.html - fi-tgl-1115g4: [PASS][14] -> [DMESG-WARN][15] [14]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-tgl-1115g4/igt@kms_busy@basic@flip.html [15]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-tgl-1115g4/igt@kms_busy@basic@flip.html - fi-cfl-guc: [PASS][16] -> [DMESG-WARN][17] [16]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-guc/igt@kms_busy@basic@flip.html [17]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-guc/igt@kms_busy@basic@flip.html - fi-cfl-8109u: [PASS][18] -> [ABORT][19] +1 other test abort [18]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-8109u/igt@kms_busy@basic@flip.html [19]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-8109u/igt@kms_busy@basic@flip.html * igt@kms_busy@basic@modeset: - fi-cfl-8700k: [PASS][20] -> [ABORT][21] +1 other test abort [20]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-8700k/igt@kms_busy@basic@modeset.html [21]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-8700k/igt@kms_busy@basic@modeset.html - bat-adls-6: NOTRUN -> [ABORT][22] +1 other test abort [22]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-adls-6/igt@kms_busy@basic@modeset.html - fi-glk-j4005: [PASS][23] -> [ABORT][24] +1 other test abort [23]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-glk-j4005/igt@kms_busy@basic@modeset.html [24]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-glk-j4005/igt@kms_busy@basic@modeset.html - bat-rpls-4: [PASS][25] -> [ABORT][26] +1 other test abort [25]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-rpls-4/igt@kms_busy@basic@modeset.html [26]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-rpls-4/igt@kms_busy@basic@modeset.html - fi-tgl-1115g4: [PASS][27] -> [ABORT][28] +1 other test abort [27]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-tgl-1115g4/igt@kms_busy@basic@modeset.html [28]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-tgl-1115g4/igt@kms_busy@basic@modeset.html - fi-cfl-guc: [PASS][29] -> [ABORT][30] +1 other test abort [29]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-guc/igt@kms_busy@basic@modeset.html [30]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-guc/igt@kms_busy@basic@modeset.html #### Warnings #### * igt@kms_busy@basic@modeset: - fi-pnv-d510: [SKIP][31] -> [ABORT][32] [31]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-pnv-d510/igt@kms_busy@basic@modeset.html [32]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-pnv-d510/igt@kms_busy@basic@modeset.html New tests --------- New tests have been introduced between CI_DRM_18256 and Patchwork_164182v1: ### New IGT tests (60) ### * igt@kms_busy@addfb25-4-tiled: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-bad-modifier: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-framebuffer-vs-set-tiling: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-modifier-no-flag: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-x-tiled-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-x-tiled-mismatch-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-y-tiled-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-y-tiled-small-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@addfb25-yf-tiled-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-close: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-flink: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-open: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-0: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-1024: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-128: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-256: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-32: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-63: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-65536: - Statuses : - Exec time: [None] s * igt@kms_busy@bad-pitch-999: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-all: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-await: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-each: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-eu-total: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-process: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-subslice-total: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-x-tiled-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@basic-y-tiled-legacy: - Statuses : - Exec time: [None] s * igt@kms_busy@bo-too-small: - Statuses : - Exec time: [None] s * igt@kms_busy@bo-too-small-due-to-tiling: - Statuses : - Exec time: [None] s * igt@kms_busy@busy: - Statuses : - Exec time: [None] s * igt@kms_busy@clobberred-modifier: - Statuses : - Exec time: [None] s * igt@kms_busy@create-fd-close: - Statuses : - Exec time: [None] s * igt@kms_busy@double-flink: - Statuses : - Exec time: [None] s * igt@kms_busy@engines: - Statuses : - Exec time: [None] s * igt@kms_busy@error-state-basic: - Statuses : - Exec time: [None] s * igt@kms_busy@flink-lifetime: - Statuses : - Exec time: [None] s * igt@kms_busy@framebuffer-vs-set-tiling: - Statuses : - Exec time: [None] s * igt@kms_busy@info: - Statuses : - Exec time: [None] s * igt@kms_busy@invalid-get-prop: - Statuses : - Exec time: [None] s * igt@kms_busy@invalid-get-prop-any: - Statuses : - Exec time: [None] s * igt@kms_busy@invalid-set-prop: - Statuses : - Exec time: [None] s * igt@kms_busy@invalid-set-prop-any: - Statuses : - Exec time: [None] s * igt@kms_busy@nb-await: - Statuses : - Exec time: [None] s * igt@kms_busy@no-handle: - Statuses : - Exec time: [None] s * igt@kms_busy@nullptr: - Statuses : - Exec time: [None] s * igt@kms_busy@read: - Statuses : - Exec time: [None] s * igt@kms_busy@read-all-entries: - Statuses : - Exec time: [None] s * igt@kms_busy@safe-alignment: - Statuses : - Exec time: [None] s * igt@kms_busy@size-max: - Statuses : - Exec time: [None] s * igt@kms_busy@small-bo: - Statuses : - Exec time: [None] s * igt@kms_busy@tile-pitch-mismatch: - Statuses : - Exec time: [None] s * igt@kms_busy@too-high: - Statuses : - Exec time: [None] s * igt@kms_busy@too-wide: - Statuses : - Exec time: [None] s * igt@kms_busy@unused-handle: - Statuses : - Exec time: [None] s * igt@kms_busy@unused-modifier: - Statuses : - Exec time: [None] s * igt@kms_busy@unused-offsets: - Statuses : - Exec time: [None] s * igt@kms_busy@unused-pitches: - Statuses : - Exec time: [None] s * igt@kms_busy@wait: - Statuses : - Exec time: [None] s * igt@kms_busy@write: - Statuses : - Exec time: [None] s Known issues ------------ Here are the changes found in Patchwork_164182v1 that come from known issues: ### IGT changes ### #### Issues hit #### * igt@dmabuf@all-tests@dma_fence_chain: - fi-skl-6600u: NOTRUN -> [SKIP][33] [33]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-skl-6600u/igt@dmabuf@all-tests@dma_fence_chain.html * igt@gem_tiled_pread_basic@basic: - bat-adls-6: NOTRUN -> [SKIP][34] ([i915#15656]) [34]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-adls-6/igt@gem_tiled_pread_basic@basic.html * igt@i915_selftest@live: - bat-dg2-8: [PASS][35] -> [DMESG-FAIL][36] ([i915#12061]) +1 other test dmesg-fail [35]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-dg2-8/igt@i915_selftest@live.html [36]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-dg2-8/igt@i915_selftest@live.html * igt@i915_selftest@live@mman: - bat-atsm-1: [PASS][37] -> [DMESG-FAIL][38] ([i915#14204]) [37]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-atsm-1/igt@i915_selftest@live@mman.html [38]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-atsm-1/igt@i915_selftest@live@mman.html * igt@i915_selftest@live@workarounds: - bat-arlh-3: [PASS][39] -> [DMESG-FAIL][40] ([i915#12061]) +1 other test dmesg-fail [39]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-arlh-3/igt@i915_selftest@live@workarounds.html [40]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-arlh-3/igt@i915_selftest@live@workarounds.html - bat-arls-5: [PASS][41] -> [DMESG-FAIL][42] ([i915#12061]) +1 other test dmesg-fail [41]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-arls-5/igt@i915_selftest@live@workarounds.html [42]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-arls-5/igt@i915_selftest@live@workarounds.html * igt@intel_hwmon@hwmon-read: - bat-adls-6: NOTRUN -> [SKIP][43] ([i915#7707]) +1 other test skip [43]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-adls-6/igt@intel_hwmon@hwmon-read.html * igt@kms_busy@basic@modeset: - fi-kbl-7567u: [PASS][44] -> [INCOMPLETE][45] ([i915#10056]) [44]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-kbl-7567u/igt@kms_busy@basic@modeset.html [45]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-kbl-7567u/igt@kms_busy@basic@modeset.html - bat-jsl-5: [PASS][46] -> [INCOMPLETE][47] ([i915#10056]) [46]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-jsl-5/igt@kms_busy@basic@modeset.html [47]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-jsl-5/igt@kms_busy@basic@modeset.html - fi-cfl-8109u: [PASS][48] -> [INCOMPLETE][49] ([i915#10056]) [48]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-cfl-8109u/igt@kms_busy@basic@modeset.html [49]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-cfl-8109u/igt@kms_busy@basic@modeset.html #### Possible fixes #### * igt@i915_selftest@live: - fi-skl-6600u: [INCOMPLETE][50] ([i915#15859]) -> [PASS][51] [50]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-skl-6600u/igt@i915_selftest@live.html [51]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-skl-6600u/igt@i915_selftest@live.html * igt@i915_selftest@live@gem_contexts: - fi-skl-6600u: [INCOMPLETE][52] -> [PASS][53] [52]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/fi-skl-6600u/igt@i915_selftest@live@gem_contexts.html [53]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/fi-skl-6600u/igt@i915_selftest@live@gem_contexts.html #### Warnings #### * igt@i915_selftest@live: - bat-atsm-1: [DMESG-FAIL][54] ([i915#12061]) -> [DMESG-FAIL][55] ([i915#12061] / [i915#14204]) [54]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_18256/bat-atsm-1/igt@i915_selftest@live.html [55]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/bat-atsm-1/igt@i915_selftest@live.html [i915#10056]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/10056 [i915#12061]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/12061 [i915#14204]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/14204 [i915#15656]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/15656 [i915#15859]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/15859 [i915#7707]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/7707 Build changes ------------- * Linux: CI_DRM_18256 -> Patchwork_164182v1 CI-20190529: 20190529 CI_DRM_18256: 779129c7868f4c7205901d6e57b25de52b411d1c @ git://anongit.freedesktop.org/gfx-ci/linux IGT_8839: 8839 Patchwork_164182v1: 779129c7868f4c7205901d6e57b25de52b411d1c @ git://anongit.freedesktop.org/gfx-ci/linux == Logs == For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_164182v1/index.html [-- Attachment #2: Type: text/html, Size: 18978 bytes --] ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] drm/i915: Track fence region ID in plane state 2026-03-31 16:21 [PATCH 1/2] drm/i915: Track fence region ID in plane state Ville Syrjala 2026-03-31 16:21 ` [PATCH 2/2] drm/i915: Remove the vma parent interface Ville Syrjala 2026-03-31 17:15 ` ✗ i915.CI.BAT: failure for series starting with [1/2] drm/i915: Track fence region ID in plane state Patchwork @ 2026-04-01 13:10 ` Jani Nikula 2026-04-01 14:29 ` Ville Syrjälä 2026-04-02 14:54 ` Jani Nikula 3 siblings, 1 reply; 8+ messages in thread From: Jani Nikula @ 2026-04-01 13:10 UTC (permalink / raw) To: Ville Syrjala, intel-gfx; +Cc: intel-xe On Tue, 31 Mar 2026, Ville Syrjala <ville.syrjala@linux.intel.com> wrote: > From: Ville Syrjälä <ville.syrjala@linux.intel.com> > > Get rid of the needlessly complicated PLANE_HAS_FENCE + > intel_parent_vma_fence_id() dance by simply tracking the > fence_id directly in the plane state. This is good cleanup, but I still dread what to do about the whole {intel,xe}_fb_pin.[ch] interface. Needs to be moved to the parent interface, but there's just too much direct display structure poking from the i915 and xe cores there. Ugh. > > Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> > --- > .../drm/i915/display/intel_display_types.h | 5 +-- > drivers/gpu/drm/i915/display/intel_fb_pin.c | 33 ++++++++++--------- > drivers/gpu/drm/i915/display/intel_fb_pin.h | 5 ++- > drivers/gpu/drm/i915/display/intel_fbc.c | 11 ++----- > drivers/gpu/drm/i915/display/intel_fbdev.c | 14 ++++---- > drivers/gpu/drm/i915/display/intel_plane.c | 3 +- > drivers/gpu/drm/i915/i915_initial_plane.c | 2 +- > drivers/gpu/drm/xe/display/xe_fb_pin.c | 8 ++--- > drivers/gpu/drm/xe/display/xe_initial_plane.c | 2 +- > 9 files changed, 42 insertions(+), 41 deletions(-) > > diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h b/drivers/gpu/drm/i915/display/intel_display_types.h > index e2496db1642a..73eb4f38620c 100644 > --- a/drivers/gpu/drm/i915/display/intel_display_types.h > +++ b/drivers/gpu/drm/i915/display/intel_display_types.h > @@ -683,14 +683,15 @@ struct intel_plane_state { > > struct i915_vma *ggtt_vma; > struct i915_vma *dpt_vma; > - unsigned long flags; > -#define PLANE_HAS_FENCE BIT(0) > > struct intel_fb_view view; > > /* for legacy cursor fb unpin */ > struct drm_vblank_work unpin_work; > > + /* fenced region ID (-1 if none) */ > + s8 fence_id; I guess I would've made this an int for consistency with all the parameters and local variables. > + > /* Plane pxp decryption state */ > bool decrypt; > > diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.c b/drivers/gpu/drm/i915/display/intel_fb_pin.c > index 738d77a1468a..0b8b057647af 100644 > --- a/drivers/gpu/drm/i915/display/intel_fb_pin.c > +++ b/drivers/gpu/drm/i915/display/intel_fb_pin.c > @@ -26,7 +26,6 @@ static struct i915_vma * > intel_fb_pin_to_dpt(const struct drm_framebuffer *fb, > const struct i915_gtt_view *view, > unsigned int alignment, > - unsigned long *out_flags, > struct intel_dpt *dpt) > { > struct drm_device *dev = fb->dev; > @@ -115,8 +114,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > unsigned int alignment, > unsigned int phys_alignment, > unsigned int vtd_guard, > - bool uses_fence, > - unsigned long *out_flags) > + int *out_fence_id) > { > struct drm_device *dev = fb->dev; > struct intel_display *display = to_intel_display(dev); > @@ -177,7 +175,10 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > goto err_unpin; > } > > - if (uses_fence && i915_vma_is_map_and_fenceable(vma)) { > + if (out_fence_id) > + *out_fence_id = -1; > + > + if (out_fence_id && i915_vma_is_map_and_fenceable(vma)) { > /* > * Install a fence for tiled scan-out. Pre-i965 always needs a > * fence, whereas 965+ only requires a fence if using > @@ -203,7 +204,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > ret = 0; > > if (vma->fence) > - *out_flags |= PLANE_HAS_FENCE; > + *out_fence_id |= vma->fence->id; > } > > i915_vma_get(vma); > @@ -225,9 +226,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > return vma; > } > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags) > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id) > { > - if (flags & PLANE_HAS_FENCE) > + if (fence_id >= 0) > i915_vma_unpin_fence(vma); > i915_vma_unpin(vma); > i915_vma_put(vma); > @@ -271,17 +272,18 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state, > struct i915_vma *vma; > > if (!intel_fb_uses_dpt(&fb->base)) { > + int fence_id = -1; > + > vma = intel_fb_pin_to_ggtt(&fb->base, &plane_state->view.gtt, > intel_plane_fb_min_alignment(plane_state), > intel_plane_fb_min_phys_alignment(plane_state), > intel_plane_fb_vtd_guard(plane_state), > - intel_plane_uses_fence(plane_state), > - &plane_state->flags); > + intel_plane_uses_fence(plane_state) ? &fence_id : NULL); E.g. here you could pass &plane_state->fence_id direcly if it was an int and ditch the local variable. > if (IS_ERR(vma)) > return PTR_ERR(vma); > > plane_state->ggtt_vma = vma; > - > + plane_state->fence_id = fence_id; > } else { > unsigned int alignment = intel_plane_fb_min_alignment(plane_state); > > @@ -292,8 +294,7 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state, > plane_state->ggtt_vma = vma; > > vma = intel_fb_pin_to_dpt(&fb->base, &plane_state->view.gtt, > - alignment, &plane_state->flags, > - fb->dpt); > + alignment, fb->dpt); > if (IS_ERR(vma)) { > i915_dpt_unpin_from_ggtt(fb->dpt); > plane_state->ggtt_vma = NULL; > @@ -338,12 +339,14 @@ void intel_plane_unpin_fb(struct intel_plane_state *old_plane_state) > > if (!intel_fb_uses_dpt(&fb->base)) { > vma = fetch_and_zero(&old_plane_state->ggtt_vma); > - if (vma) > - intel_fb_unpin_vma(vma, old_plane_state->flags); > + if (vma) { > + intel_fb_unpin_vma(vma, old_plane_state->fence_id); > + old_plane_state->fence_id = -1; > + } > } else { > vma = fetch_and_zero(&old_plane_state->dpt_vma); > if (vma) > - intel_fb_unpin_vma(vma, old_plane_state->flags); > + intel_fb_unpin_vma(vma, -1); > > vma = fetch_and_zero(&old_plane_state->ggtt_vma); > if (vma) > diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.h b/drivers/gpu/drm/i915/display/intel_fb_pin.h > index 81ab79da1af7..2eca42b74c4a 100644 > --- a/drivers/gpu/drm/i915/display/intel_fb_pin.h > +++ b/drivers/gpu/drm/i915/display/intel_fb_pin.h > @@ -20,10 +20,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > unsigned int alignment, > unsigned int phys_alignment, > unsigned int vtd_guard, > - bool uses_fence, > - unsigned long *out_flags); > + int *out_fence_id); > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags); > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id); > > int intel_plane_pin_fb(struct intel_plane_state *new_plane_state, > const struct intel_plane_state *old_plane_state); > diff --git a/drivers/gpu/drm/i915/display/intel_fbc.c b/drivers/gpu/drm/i915/display/intel_fbc.c > index ea0ce00c8474..677ac5be749b 100644 > --- a/drivers/gpu/drm/i915/display/intel_fbc.c > +++ b/drivers/gpu/drm/i915/display/intel_fbc.c > @@ -1458,13 +1458,10 @@ static void intel_fbc_update_state(struct intel_atomic_state *state, > > fbc_state->fence_y_offset = intel_plane_fence_y_offset(plane_state); > > - drm_WARN_ON(display->drm, plane_state->flags & PLANE_HAS_FENCE && > + drm_WARN_ON(display->drm, plane_state->fence_id >= 0 && > !intel_fbc_has_fences(display)); > > - if (plane_state->flags & PLANE_HAS_FENCE) > - fbc_state->fence_id = intel_parent_vma_fence_id(display, plane_state->ggtt_vma); > - else > - fbc_state->fence_id = -1; > + fbc_state->fence_id = plane_state->fence_id; > > fbc_state->cfb_stride = intel_fbc_cfb_stride(plane_state); > fbc_state->cfb_size = intel_fbc_cfb_size(plane_state); > @@ -1487,9 +1484,7 @@ static bool intel_fbc_is_fence_ok(const struct intel_plane_state *plane_state) > * so have no fence associated with it) due to aperture constraints > * at the time of pinning. > */ > - return DISPLAY_VER(display) >= 9 || > - (plane_state->flags & PLANE_HAS_FENCE && > - intel_parent_vma_fence_id(display, plane_state->ggtt_vma) != -1); > + return DISPLAY_VER(display) >= 9 || plane_state->fence_id >= 0; > } > > static bool intel_fbc_is_cfb_ok(const struct intel_plane_state *plane_state) > diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c > index bdaaf3edba0c..0d7be5186393 100644 > --- a/drivers/gpu/drm/i915/display/intel_fbdev.c > +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c > @@ -60,7 +60,7 @@ > struct intel_fbdev { > struct intel_framebuffer *fb; > struct i915_vma *vma; > - unsigned long vma_flags; > + s8 fence_id; Ditto. Regardless, Reviewed-by: Jani Nikula <jani.nikula@intel.com> > }; > > static struct intel_fbdev *to_intel_fbdev(struct drm_fb_helper *fb_helper) > @@ -141,7 +141,7 @@ static void intel_fbdev_fb_destroy(struct fb_info *info) > * the info->screen_base mmaping. Leaking the VMA is simpler than > * trying to rectify all the possible error paths leading here. > */ > - intel_fb_unpin_vma(ifbdev->vma, ifbdev->vma_flags); > + intel_fb_unpin_vma(ifbdev->vma, ifbdev->fence_id); > drm_framebuffer_remove(fb_helper->fb); > > drm_client_release(&fb_helper->client); > @@ -269,9 +269,9 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > struct fb_info *info = helper->info; > struct ref_tracker *wakeref; > struct i915_vma *vma; > - unsigned long flags = 0; > bool prealloc = false; > struct drm_gem_object *obj; > + int fence_id = -1; > int ret; > > ifbdev->fb = NULL; > @@ -314,7 +314,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > fb->min_alignment, 0, > intel_fb_view_vtd_guard(&fb->base, &fb->normal_view, > DRM_MODE_ROTATE_0), > - false, &flags); > + &fence_id); > if (IS_ERR(vma)) { > ret = PTR_ERR(vma); > goto out_unlock; > @@ -345,14 +345,14 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > drm_dbg_kms(display->drm, "allocated %dx%d fb\n", fb->base.width, fb->base.height); > ifbdev->fb = fb; > ifbdev->vma = vma; > - ifbdev->vma_flags = flags; > + ifbdev->fence_id = fence_id; > > intel_display_rpm_put(display, wakeref); > > return 0; > > out_unpin: > - intel_fb_unpin_vma(vma, flags); > + intel_fb_unpin_vma(vma, fence_id); > out_unlock: > intel_display_rpm_put(display, wakeref); > > @@ -539,6 +539,8 @@ void intel_fbdev_setup(struct intel_display *display) > if (!ifbdev) > return; > > + ifbdev->fence_id = -1; > + > display->fbdev.fbdev = ifbdev; > if (intel_fbdev_init_bios(display, ifbdev)) > preferred_bpp = intel_fbdev_color_mode(ifbdev->fb->base.format); > diff --git a/drivers/gpu/drm/i915/display/intel_plane.c b/drivers/gpu/drm/i915/display/intel_plane.c > index 5390ceb21ca4..f15dd9e91243 100644 > --- a/drivers/gpu/drm/i915/display/intel_plane.c > +++ b/drivers/gpu/drm/i915/display/intel_plane.c > @@ -70,6 +70,7 @@ static void intel_plane_state_reset(struct intel_plane_state *plane_state, > __drm_atomic_helper_plane_state_reset(&plane_state->uapi, &plane->base); > > plane_state->scaler_id = -1; > + plane_state->fence_id = -1; > } > > struct intel_plane *intel_plane_alloc(void) > @@ -137,7 +138,7 @@ intel_plane_duplicate_state(struct drm_plane *plane) > > intel_state->ggtt_vma = NULL; > intel_state->dpt_vma = NULL; > - intel_state->flags = 0; > + intel_state->fence_id = -1; > intel_state->damage = DRM_RECT_INIT(0, 0, 0, 0); > > /* add reference to fb */ > diff --git a/drivers/gpu/drm/i915/i915_initial_plane.c b/drivers/gpu/drm/i915/i915_initial_plane.c > index 390a9248d631..db51a468ddd4 100644 > --- a/drivers/gpu/drm/i915/i915_initial_plane.c > +++ b/drivers/gpu/drm/i915/i915_initial_plane.c > @@ -268,7 +268,7 @@ i915_initial_plane_setup(struct drm_plane_state *_plane_state, > plane_state->ggtt_vma = i915_vma_get(vma); > if (intel_plane_uses_fence(plane_state) && > i915_vma_pin_fence(vma) == 0 && vma->fence) > - plane_state->flags |= PLANE_HAS_FENCE; > + plane_state->fence_id = vma->fence->id; > > plane_state->surf = i915_ggtt_offset(plane_state->ggtt_vma); > > diff --git a/drivers/gpu/drm/xe/display/xe_fb_pin.c b/drivers/gpu/drm/xe/display/xe_fb_pin.c > index e45a1e7a4670..739d9c019094 100644 > --- a/drivers/gpu/drm/xe/display/xe_fb_pin.c > +++ b/drivers/gpu/drm/xe/display/xe_fb_pin.c > @@ -418,15 +418,15 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > unsigned int alignment, > unsigned int phys_alignment, > unsigned int vtd_guard, > - bool uses_fence, > - unsigned long *out_flags) > + int *out_fence_id) > { > - *out_flags = 0; > + if (out_fence_id) > + *out_fence_id = -1; > > return __xe_pin_fb_vma(to_intel_framebuffer(fb), view, alignment); > } > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags) > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id) > { > __xe_unpin_fb_vma(vma); > } > diff --git a/drivers/gpu/drm/xe/display/xe_initial_plane.c b/drivers/gpu/drm/xe/display/xe_initial_plane.c > index 8bcae552dddc..09ec8f94bf57 100644 > --- a/drivers/gpu/drm/xe/display/xe_initial_plane.c > +++ b/drivers/gpu/drm/xe/display/xe_initial_plane.c > @@ -153,7 +153,7 @@ xe_initial_plane_setup(struct drm_plane_state *_plane_state, > struct i915_vma *vma; > > vma = intel_fb_pin_to_ggtt(fb, &plane_state->view.gtt, > - 0, 0, 0, false, &plane_state->flags); > + 0, 0, 0, NULL); > if (IS_ERR(vma)) > return PTR_ERR(vma); -- Jani Nikula, Intel ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] drm/i915: Track fence region ID in plane state 2026-04-01 13:10 ` [PATCH 1/2] " Jani Nikula @ 2026-04-01 14:29 ` Ville Syrjälä 0 siblings, 0 replies; 8+ messages in thread From: Ville Syrjälä @ 2026-04-01 14:29 UTC (permalink / raw) To: Jani Nikula; +Cc: intel-gfx, intel-xe On Wed, Apr 01, 2026 at 04:10:16PM +0300, Jani Nikula wrote: > On Tue, 31 Mar 2026, Ville Syrjala <ville.syrjala@linux.intel.com> wrote: > > From: Ville Syrjälä <ville.syrjala@linux.intel.com> > > > > Get rid of the needlessly complicated PLANE_HAS_FENCE + > > intel_parent_vma_fence_id() dance by simply tracking the > > fence_id directly in the plane state. > > This is good cleanup, but I still dread what to do about the whole > {intel,xe}_fb_pin.[ch] interface. Needs to be moved to the parent > interface, but there's just too much direct display structure poking > from the i915 and xe cores there. Ugh. Hmm. I'll put on my thinking cap and ponder about it a bit... > > > > > Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> > > --- > > .../drm/i915/display/intel_display_types.h | 5 +-- > > drivers/gpu/drm/i915/display/intel_fb_pin.c | 33 ++++++++++--------- > > drivers/gpu/drm/i915/display/intel_fb_pin.h | 5 ++- > > drivers/gpu/drm/i915/display/intel_fbc.c | 11 ++----- > > drivers/gpu/drm/i915/display/intel_fbdev.c | 14 ++++---- > > drivers/gpu/drm/i915/display/intel_plane.c | 3 +- > > drivers/gpu/drm/i915/i915_initial_plane.c | 2 +- > > drivers/gpu/drm/xe/display/xe_fb_pin.c | 8 ++--- > > drivers/gpu/drm/xe/display/xe_initial_plane.c | 2 +- > > 9 files changed, 42 insertions(+), 41 deletions(-) > > > > diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h b/drivers/gpu/drm/i915/display/intel_display_types.h > > index e2496db1642a..73eb4f38620c 100644 > > --- a/drivers/gpu/drm/i915/display/intel_display_types.h > > +++ b/drivers/gpu/drm/i915/display/intel_display_types.h > > @@ -683,14 +683,15 @@ struct intel_plane_state { > > > > struct i915_vma *ggtt_vma; > > struct i915_vma *dpt_vma; > > - unsigned long flags; > > -#define PLANE_HAS_FENCE BIT(0) > > > > struct intel_fb_view view; > > > > /* for legacy cursor fb unpin */ > > struct drm_vblank_work unpin_work; > > > > + /* fenced region ID (-1 if none) */ > > + s8 fence_id; > > I guess I would've made this an int for consistency with all the > parameters and local variables. I considered it after the fact. But FBC had the s8, and I found it really hard to give up on that nice little hole I found :/ > > > + > > /* Plane pxp decryption state */ > > bool decrypt; > > > > diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.c b/drivers/gpu/drm/i915/display/intel_fb_pin.c > > index 738d77a1468a..0b8b057647af 100644 > > --- a/drivers/gpu/drm/i915/display/intel_fb_pin.c > > +++ b/drivers/gpu/drm/i915/display/intel_fb_pin.c > > @@ -26,7 +26,6 @@ static struct i915_vma * > > intel_fb_pin_to_dpt(const struct drm_framebuffer *fb, > > const struct i915_gtt_view *view, > > unsigned int alignment, > > - unsigned long *out_flags, > > struct intel_dpt *dpt) > > { > > struct drm_device *dev = fb->dev; > > @@ -115,8 +114,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > unsigned int alignment, > > unsigned int phys_alignment, > > unsigned int vtd_guard, > > - bool uses_fence, > > - unsigned long *out_flags) > > + int *out_fence_id) > > { > > struct drm_device *dev = fb->dev; > > struct intel_display *display = to_intel_display(dev); > > @@ -177,7 +175,10 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > goto err_unpin; > > } > > > > - if (uses_fence && i915_vma_is_map_and_fenceable(vma)) { > > + if (out_fence_id) > > + *out_fence_id = -1; > > + > > + if (out_fence_id && i915_vma_is_map_and_fenceable(vma)) { > > /* > > * Install a fence for tiled scan-out. Pre-i965 always needs a > > * fence, whereas 965+ only requires a fence if using > > @@ -203,7 +204,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > ret = 0; > > > > if (vma->fence) > > - *out_flags |= PLANE_HAS_FENCE; > > + *out_fence_id |= vma->fence->id; > > } > > > > i915_vma_get(vma); > > @@ -225,9 +226,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > return vma; > > } > > > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags) > > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id) > > { > > - if (flags & PLANE_HAS_FENCE) > > + if (fence_id >= 0) > > i915_vma_unpin_fence(vma); > > i915_vma_unpin(vma); > > i915_vma_put(vma); > > @@ -271,17 +272,18 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state, > > struct i915_vma *vma; > > > > if (!intel_fb_uses_dpt(&fb->base)) { > > + int fence_id = -1; > > + > > vma = intel_fb_pin_to_ggtt(&fb->base, &plane_state->view.gtt, > > intel_plane_fb_min_alignment(plane_state), > > intel_plane_fb_min_phys_alignment(plane_state), > > intel_plane_fb_vtd_guard(plane_state), > > - intel_plane_uses_fence(plane_state), > > - &plane_state->flags); > > + intel_plane_uses_fence(plane_state) ? &fence_id : NULL); > > E.g. here you could pass &plane_state->fence_id direcly if it was an int > and ditch the local variable. > > > if (IS_ERR(vma)) > > return PTR_ERR(vma); > > > > plane_state->ggtt_vma = vma; > > - > > + plane_state->fence_id = fence_id; > > } else { > > unsigned int alignment = intel_plane_fb_min_alignment(plane_state); > > > > @@ -292,8 +294,7 @@ int intel_plane_pin_fb(struct intel_plane_state *plane_state, > > plane_state->ggtt_vma = vma; > > > > vma = intel_fb_pin_to_dpt(&fb->base, &plane_state->view.gtt, > > - alignment, &plane_state->flags, > > - fb->dpt); > > + alignment, fb->dpt); > > if (IS_ERR(vma)) { > > i915_dpt_unpin_from_ggtt(fb->dpt); > > plane_state->ggtt_vma = NULL; > > @@ -338,12 +339,14 @@ void intel_plane_unpin_fb(struct intel_plane_state *old_plane_state) > > > > if (!intel_fb_uses_dpt(&fb->base)) { > > vma = fetch_and_zero(&old_plane_state->ggtt_vma); > > - if (vma) > > - intel_fb_unpin_vma(vma, old_plane_state->flags); > > + if (vma) { > > + intel_fb_unpin_vma(vma, old_plane_state->fence_id); > > + old_plane_state->fence_id = -1; > > + } > > } else { > > vma = fetch_and_zero(&old_plane_state->dpt_vma); > > if (vma) > > - intel_fb_unpin_vma(vma, old_plane_state->flags); > > + intel_fb_unpin_vma(vma, -1); > > > > vma = fetch_and_zero(&old_plane_state->ggtt_vma); > > if (vma) > > diff --git a/drivers/gpu/drm/i915/display/intel_fb_pin.h b/drivers/gpu/drm/i915/display/intel_fb_pin.h > > index 81ab79da1af7..2eca42b74c4a 100644 > > --- a/drivers/gpu/drm/i915/display/intel_fb_pin.h > > +++ b/drivers/gpu/drm/i915/display/intel_fb_pin.h > > @@ -20,10 +20,9 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > unsigned int alignment, > > unsigned int phys_alignment, > > unsigned int vtd_guard, > > - bool uses_fence, > > - unsigned long *out_flags); > > + int *out_fence_id); > > > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags); > > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id); > > > > int intel_plane_pin_fb(struct intel_plane_state *new_plane_state, > > const struct intel_plane_state *old_plane_state); > > diff --git a/drivers/gpu/drm/i915/display/intel_fbc.c b/drivers/gpu/drm/i915/display/intel_fbc.c > > index ea0ce00c8474..677ac5be749b 100644 > > --- a/drivers/gpu/drm/i915/display/intel_fbc.c > > +++ b/drivers/gpu/drm/i915/display/intel_fbc.c > > @@ -1458,13 +1458,10 @@ static void intel_fbc_update_state(struct intel_atomic_state *state, > > > > fbc_state->fence_y_offset = intel_plane_fence_y_offset(plane_state); > > > > - drm_WARN_ON(display->drm, plane_state->flags & PLANE_HAS_FENCE && > > + drm_WARN_ON(display->drm, plane_state->fence_id >= 0 && > > !intel_fbc_has_fences(display)); > > > > - if (plane_state->flags & PLANE_HAS_FENCE) > > - fbc_state->fence_id = intel_parent_vma_fence_id(display, plane_state->ggtt_vma); > > - else > > - fbc_state->fence_id = -1; > > + fbc_state->fence_id = plane_state->fence_id; > > > > fbc_state->cfb_stride = intel_fbc_cfb_stride(plane_state); > > fbc_state->cfb_size = intel_fbc_cfb_size(plane_state); > > @@ -1487,9 +1484,7 @@ static bool intel_fbc_is_fence_ok(const struct intel_plane_state *plane_state) > > * so have no fence associated with it) due to aperture constraints > > * at the time of pinning. > > */ > > - return DISPLAY_VER(display) >= 9 || > > - (plane_state->flags & PLANE_HAS_FENCE && > > - intel_parent_vma_fence_id(display, plane_state->ggtt_vma) != -1); > > + return DISPLAY_VER(display) >= 9 || plane_state->fence_id >= 0; > > } > > > > static bool intel_fbc_is_cfb_ok(const struct intel_plane_state *plane_state) > > diff --git a/drivers/gpu/drm/i915/display/intel_fbdev.c b/drivers/gpu/drm/i915/display/intel_fbdev.c > > index bdaaf3edba0c..0d7be5186393 100644 > > --- a/drivers/gpu/drm/i915/display/intel_fbdev.c > > +++ b/drivers/gpu/drm/i915/display/intel_fbdev.c > > @@ -60,7 +60,7 @@ > > struct intel_fbdev { > > struct intel_framebuffer *fb; > > struct i915_vma *vma; > > - unsigned long vma_flags; > > + s8 fence_id; > > Ditto. > > Regardless, > > Reviewed-by: Jani Nikula <jani.nikula@intel.com> > > > > }; > > > > static struct intel_fbdev *to_intel_fbdev(struct drm_fb_helper *fb_helper) > > @@ -141,7 +141,7 @@ static void intel_fbdev_fb_destroy(struct fb_info *info) > > * the info->screen_base mmaping. Leaking the VMA is simpler than > > * trying to rectify all the possible error paths leading here. > > */ > > - intel_fb_unpin_vma(ifbdev->vma, ifbdev->vma_flags); > > + intel_fb_unpin_vma(ifbdev->vma, ifbdev->fence_id); > > drm_framebuffer_remove(fb_helper->fb); > > > > drm_client_release(&fb_helper->client); > > @@ -269,9 +269,9 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > > struct fb_info *info = helper->info; > > struct ref_tracker *wakeref; > > struct i915_vma *vma; > > - unsigned long flags = 0; > > bool prealloc = false; > > struct drm_gem_object *obj; > > + int fence_id = -1; > > int ret; > > > > ifbdev->fb = NULL; > > @@ -314,7 +314,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > > fb->min_alignment, 0, > > intel_fb_view_vtd_guard(&fb->base, &fb->normal_view, > > DRM_MODE_ROTATE_0), > > - false, &flags); > > + &fence_id); > > if (IS_ERR(vma)) { > > ret = PTR_ERR(vma); > > goto out_unlock; > > @@ -345,14 +345,14 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > > drm_dbg_kms(display->drm, "allocated %dx%d fb\n", fb->base.width, fb->base.height); > > ifbdev->fb = fb; > > ifbdev->vma = vma; > > - ifbdev->vma_flags = flags; > > + ifbdev->fence_id = fence_id; > > > > intel_display_rpm_put(display, wakeref); > > > > return 0; > > > > out_unpin: > > - intel_fb_unpin_vma(vma, flags); > > + intel_fb_unpin_vma(vma, fence_id); > > out_unlock: > > intel_display_rpm_put(display, wakeref); > > > > @@ -539,6 +539,8 @@ void intel_fbdev_setup(struct intel_display *display) > > if (!ifbdev) > > return; > > > > + ifbdev->fence_id = -1; > > + > > display->fbdev.fbdev = ifbdev; > > if (intel_fbdev_init_bios(display, ifbdev)) > > preferred_bpp = intel_fbdev_color_mode(ifbdev->fb->base.format); > > diff --git a/drivers/gpu/drm/i915/display/intel_plane.c b/drivers/gpu/drm/i915/display/intel_plane.c > > index 5390ceb21ca4..f15dd9e91243 100644 > > --- a/drivers/gpu/drm/i915/display/intel_plane.c > > +++ b/drivers/gpu/drm/i915/display/intel_plane.c > > @@ -70,6 +70,7 @@ static void intel_plane_state_reset(struct intel_plane_state *plane_state, > > __drm_atomic_helper_plane_state_reset(&plane_state->uapi, &plane->base); > > > > plane_state->scaler_id = -1; > > + plane_state->fence_id = -1; > > } > > > > struct intel_plane *intel_plane_alloc(void) > > @@ -137,7 +138,7 @@ intel_plane_duplicate_state(struct drm_plane *plane) > > > > intel_state->ggtt_vma = NULL; > > intel_state->dpt_vma = NULL; > > - intel_state->flags = 0; > > + intel_state->fence_id = -1; > > intel_state->damage = DRM_RECT_INIT(0, 0, 0, 0); > > > > /* add reference to fb */ > > diff --git a/drivers/gpu/drm/i915/i915_initial_plane.c b/drivers/gpu/drm/i915/i915_initial_plane.c > > index 390a9248d631..db51a468ddd4 100644 > > --- a/drivers/gpu/drm/i915/i915_initial_plane.c > > +++ b/drivers/gpu/drm/i915/i915_initial_plane.c > > @@ -268,7 +268,7 @@ i915_initial_plane_setup(struct drm_plane_state *_plane_state, > > plane_state->ggtt_vma = i915_vma_get(vma); > > if (intel_plane_uses_fence(plane_state) && > > i915_vma_pin_fence(vma) == 0 && vma->fence) > > - plane_state->flags |= PLANE_HAS_FENCE; > > + plane_state->fence_id = vma->fence->id; > > > > plane_state->surf = i915_ggtt_offset(plane_state->ggtt_vma); > > > > diff --git a/drivers/gpu/drm/xe/display/xe_fb_pin.c b/drivers/gpu/drm/xe/display/xe_fb_pin.c > > index e45a1e7a4670..739d9c019094 100644 > > --- a/drivers/gpu/drm/xe/display/xe_fb_pin.c > > +++ b/drivers/gpu/drm/xe/display/xe_fb_pin.c > > @@ -418,15 +418,15 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > unsigned int alignment, > > unsigned int phys_alignment, > > unsigned int vtd_guard, > > - bool uses_fence, > > - unsigned long *out_flags) > > + int *out_fence_id) > > { > > - *out_flags = 0; > > + if (out_fence_id) > > + *out_fence_id = -1; > > > > return __xe_pin_fb_vma(to_intel_framebuffer(fb), view, alignment); > > } > > > > -void intel_fb_unpin_vma(struct i915_vma *vma, unsigned long flags) > > +void intel_fb_unpin_vma(struct i915_vma *vma, int fence_id) > > { > > __xe_unpin_fb_vma(vma); > > } > > diff --git a/drivers/gpu/drm/xe/display/xe_initial_plane.c b/drivers/gpu/drm/xe/display/xe_initial_plane.c > > index 8bcae552dddc..09ec8f94bf57 100644 > > --- a/drivers/gpu/drm/xe/display/xe_initial_plane.c > > +++ b/drivers/gpu/drm/xe/display/xe_initial_plane.c > > @@ -153,7 +153,7 @@ xe_initial_plane_setup(struct drm_plane_state *_plane_state, > > struct i915_vma *vma; > > > > vma = intel_fb_pin_to_ggtt(fb, &plane_state->view.gtt, > > - 0, 0, 0, false, &plane_state->flags); > > + 0, 0, 0, NULL); > > if (IS_ERR(vma)) > > return PTR_ERR(vma); > > -- > Jani Nikula, Intel -- Ville Syrjälä Intel ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] drm/i915: Track fence region ID in plane state 2026-03-31 16:21 [PATCH 1/2] drm/i915: Track fence region ID in plane state Ville Syrjala ` (2 preceding siblings ...) 2026-04-01 13:10 ` [PATCH 1/2] " Jani Nikula @ 2026-04-02 14:54 ` Jani Nikula 2026-04-02 17:20 ` Ville Syrjälä 3 siblings, 1 reply; 8+ messages in thread From: Jani Nikula @ 2026-04-02 14:54 UTC (permalink / raw) To: Ville Syrjala, intel-gfx; +Cc: intel-xe On Tue, 31 Mar 2026, Ville Syrjala <ville.syrjala@linux.intel.com> wrote: > @@ -203,7 +204,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > ret = 0; > > if (vma->fence) > - *out_flags |= PLANE_HAS_FENCE; > + *out_fence_id |= vma->fence->id; That should obviously be an assignment rather than OR. I was reviewing the recently enabled Sashiko LLM reviews, and it had spotted this one [1]. > @@ -314,7 +314,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > fb->min_alignment, 0, > intel_fb_view_vtd_guard(&fb->base, &fb->normal_view, > DRM_MODE_ROTATE_0), > - false, &flags); > + &fence_id); This might also change behaviour as previously uses_fence == false. BR, Jani. [1] https://sashiko.dev/#/patchset/20260331162138.19258-1-ville.syrjala%40linux.intel.com -- Jani Nikula, Intel ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH 1/2] drm/i915: Track fence region ID in plane state 2026-04-02 14:54 ` Jani Nikula @ 2026-04-02 17:20 ` Ville Syrjälä 0 siblings, 0 replies; 8+ messages in thread From: Ville Syrjälä @ 2026-04-02 17:20 UTC (permalink / raw) To: Jani Nikula; +Cc: intel-gfx, intel-xe On Thu, Apr 02, 2026 at 05:54:05PM +0300, Jani Nikula wrote: > On Tue, 31 Mar 2026, Ville Syrjala <ville.syrjala@linux.intel.com> wrote: > > @@ -203,7 +204,7 @@ intel_fb_pin_to_ggtt(const struct drm_framebuffer *fb, > > ret = 0; > > > > if (vma->fence) > > - *out_flags |= PLANE_HAS_FENCE; > > + *out_fence_id |= vma->fence->id; > > That should obviously be an assignment rather than OR. > > I was reviewing the recently enabled Sashiko LLM reviews, and it had > spotted this one [1]. > > > @@ -314,7 +314,7 @@ int intel_fbdev_driver_fbdev_probe(struct drm_fb_helper *helper, > > fb->min_alignment, 0, > > intel_fb_view_vtd_guard(&fb->base, &fb->normal_view, > > DRM_MODE_ROTATE_0), > > - false, &flags); > > + &fence_id); > > This might also change behaviour as previously uses_fence == false. Hmm. Seems harmless but I guess we don't need the fence here at all. If a fence is needed i915_vma_pin_iomap() will anyway grab one. And even if we didn't iomap the thing intel_plane_pin_fb() would still grab a fence if the display hardware needs it. > > BR, > Jani. > > > > [1] https://sashiko.dev/#/patchset/20260331162138.19258-1-ville.syrjala%40linux.intel.com > > > > -- > Jani Nikula, Intel -- Ville Syrjälä Intel ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2026-04-02 17:20 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2026-03-31 16:21 [PATCH 1/2] drm/i915: Track fence region ID in plane state Ville Syrjala 2026-03-31 16:21 ` [PATCH 2/2] drm/i915: Remove the vma parent interface Ville Syrjala 2026-04-01 13:10 ` Jani Nikula 2026-03-31 17:15 ` ✗ i915.CI.BAT: failure for series starting with [1/2] drm/i915: Track fence region ID in plane state Patchwork 2026-04-01 13:10 ` [PATCH 1/2] " Jani Nikula 2026-04-01 14:29 ` Ville Syrjälä 2026-04-02 14:54 ` Jani Nikula 2026-04-02 17:20 ` Ville Syrjälä
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox