* [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
@ 2026-05-18 14:14 ` Francois Dugast
2026-05-18 15:38 ` Matthew Auld
2026-05-18 15:55 ` Matthew Auld
2026-05-18 14:14 ` [PATCH v3 2/5] gpu/buddy: Remove redundant condition in alloc_from_freetree() error path Francois Dugast
` (7 subsequent siblings)
8 siblings, 2 replies; 18+ messages in thread
From: Francois Dugast @ 2026-05-18 14:14 UTC (permalink / raw)
To: intel-xe; +Cc: dri-devel, matthew.auld, Francois Dugast, Sashiko
When split_block() fails it returns before calling mark_split(), leaving
the block in the FREE state and still linked in the rbtree. The four
err_undo paths then call __gpu_buddy_free() without first removing the
block from the tree, which leads to two distinct bugs:
- If the buddy is also free, __gpu_buddy_free() merges the two siblings
by calling gpu_block_free(mm, block) while block->rb is still linked
in the tree. Any subsequent rbtree traversal will follow the now-
dangling pointer, causing a use-after-free.
- In alloc_from_freetree(), where there is no buddy guard,
__gpu_buddy_free() always reaches mark_free() -> rbtree_insert() with
block still in the tree, corrupting the rbtree.
The same pattern is already used correctly in __force_merge(): call
rbtree_remove() to unlink the block before handing it to
__gpu_buddy_free(). Apply the same fix to all four err_undo sites.
Reported-by: Sashiko <sashiko-bot@kernel.org>
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
Assisted-by: GitHub Copilot:claude-sonnet-4.6
---
drivers/gpu/buddy.c | 16 ++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)
diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
index eb1457376307..dac2027bb64a 100644
--- a/drivers/gpu/buddy.c
+++ b/drivers/gpu/buddy.c
@@ -737,8 +737,10 @@ __alloc_range_bias(struct gpu_buddy *mm,
buddy = __get_buddy(block);
if (buddy &&
(gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy)))
+ gpu_buddy_block_is_free(buddy))) {
+ rbtree_remove(mm, block);
__gpu_buddy_free(mm, block, false);
+ }
return ERR_PTR(err);
}
@@ -847,8 +849,10 @@ alloc_from_freetree(struct gpu_buddy *mm,
return block;
err_undo:
- if (tmp != order)
+ if (tmp != order) {
+ rbtree_remove(mm, block);
__gpu_buddy_free(mm, block, false);
+ }
return ERR_PTR(err);
}
@@ -968,8 +972,10 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
buddy = __get_buddy(block);
if (buddy &&
(gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy)))
+ gpu_buddy_block_is_free(buddy))) {
+ rbtree_remove(mm, block);
__gpu_buddy_free(mm, block, false);
+ }
return ERR_PTR(err);
}
@@ -1054,8 +1060,10 @@ static int __alloc_range(struct gpu_buddy *mm,
buddy = __get_buddy(block);
if (buddy &&
(gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy)))
+ gpu_buddy_block_is_free(buddy))) {
+ rbtree_remove(mm, block);
__gpu_buddy_free(mm, block, false);
+ }
err_free:
if (err == -ENOSPC && total_allocated_on_err) {
--
2.43.0
^ permalink raw reply related [flat|nested] 18+ messages in thread* Re: [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites
2026-05-18 14:14 ` [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites Francois Dugast
@ 2026-05-18 15:38 ` Matthew Auld
2026-05-18 15:55 ` Matthew Auld
1 sibling, 0 replies; 18+ messages in thread
From: Matthew Auld @ 2026-05-18 15:38 UTC (permalink / raw)
To: Francois Dugast, intel-xe; +Cc: dri-devel, Sashiko
On 18/05/2026 15:14, Francois Dugast wrote:
> When split_block() fails it returns before calling mark_split(), leaving
> the block in the FREE state and still linked in the rbtree. The four
> err_undo paths then call __gpu_buddy_free() without first removing the
> block from the tree, which leads to two distinct bugs:
>
> - If the buddy is also free, __gpu_buddy_free() merges the two siblings
> by calling gpu_block_free(mm, block) while block->rb is still linked
> in the tree. Any subsequent rbtree traversal will follow the now-
> dangling pointer, causing a use-after-free.
>
> - In alloc_from_freetree(), where there is no buddy guard,
> __gpu_buddy_free() always reaches mark_free() -> rbtree_insert() with
> block still in the tree, corrupting the rbtree.
>
> The same pattern is already used correctly in __force_merge(): call
> rbtree_remove() to unlink the block before handing it to
> __gpu_buddy_free(). Apply the same fix to all four err_undo sites.
>
> Reported-by: Sashiko <sashiko-bot@kernel.org>
> Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> Assisted-by: GitHub Copilot:claude-sonnet-4.6
Reviewed-by: Matthew Auld <matthew.auld@intel.com>
> ---
> drivers/gpu/buddy.c | 16 ++++++++++++----
> 1 file changed, 12 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> index eb1457376307..dac2027bb64a 100644
> --- a/drivers/gpu/buddy.c
> +++ b/drivers/gpu/buddy.c
> @@ -737,8 +737,10 @@ __alloc_range_bias(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -847,8 +849,10 @@ alloc_from_freetree(struct gpu_buddy *mm,
> return block;
>
> err_undo:
> - if (tmp != order)
> + if (tmp != order) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -968,8 +972,10 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -1054,8 +1060,10 @@ static int __alloc_range(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
>
> err_free:
> if (err == -ENOSPC && total_allocated_on_err) {
^ permalink raw reply [flat|nested] 18+ messages in thread* Re: [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites
2026-05-18 14:14 ` [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites Francois Dugast
2026-05-18 15:38 ` Matthew Auld
@ 2026-05-18 15:55 ` Matthew Auld
2026-05-20 10:58 ` Francois Dugast
1 sibling, 1 reply; 18+ messages in thread
From: Matthew Auld @ 2026-05-18 15:55 UTC (permalink / raw)
To: Francois Dugast, intel-xe; +Cc: dri-devel, Sashiko
On 18/05/2026 15:14, Francois Dugast wrote:
> When split_block() fails it returns before calling mark_split(), leaving
> the block in the FREE state and still linked in the rbtree. The four
> err_undo paths then call __gpu_buddy_free() without first removing the
> block from the tree, which leads to two distinct bugs:
>
> - If the buddy is also free, __gpu_buddy_free() merges the two siblings
> by calling gpu_block_free(mm, block) while block->rb is still linked
> in the tree. Any subsequent rbtree traversal will follow the now-
> dangling pointer, causing a use-after-free.
>
> - In alloc_from_freetree(), where there is no buddy guard,
> __gpu_buddy_free() always reaches mark_free() -> rbtree_insert() with
> block still in the tree, corrupting the rbtree.
>
> The same pattern is already used correctly in __force_merge(): call
> rbtree_remove() to unlink the block before handing it to
> __gpu_buddy_free(). Apply the same fix to all four err_undo sites.
>
> Reported-by: Sashiko <sashiko-bot@kernel.org>
> Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> Assisted-by: GitHub Copilot:claude-sonnet-4.6
> ---
> drivers/gpu/buddy.c | 16 ++++++++++++----
> 1 file changed, 12 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> index eb1457376307..dac2027bb64a 100644
> --- a/drivers/gpu/buddy.c
> +++ b/drivers/gpu/buddy.c
> @@ -737,8 +737,10 @@ __alloc_range_bias(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -847,8 +849,10 @@ alloc_from_freetree(struct gpu_buddy *mm,
> return block;
>
> err_undo:
> - if (tmp != order)
> + if (tmp != order) {
> + rbtree_remove(mm, block);
Actually, I think this needs the same checking like elsewhere? Say we
fail on the first split? Nothing was actually split, right?
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -968,8 +972,10 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
> return ERR_PTR(err);
> }
>
> @@ -1054,8 +1060,10 @@ static int __alloc_range(struct gpu_buddy *mm,
> buddy = __get_buddy(block);
> if (buddy &&
> (gpu_buddy_block_is_free(block) &&
> - gpu_buddy_block_is_free(buddy)))
> + gpu_buddy_block_is_free(buddy))) {
> + rbtree_remove(mm, block);
> __gpu_buddy_free(mm, block, false);
> + }
>
> err_free:
> if (err == -ENOSPC && total_allocated_on_err) {
^ permalink raw reply [flat|nested] 18+ messages in thread* Re: [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites
2026-05-18 15:55 ` Matthew Auld
@ 2026-05-20 10:58 ` Francois Dugast
2026-05-21 16:18 ` Matthew Auld
0 siblings, 1 reply; 18+ messages in thread
From: Francois Dugast @ 2026-05-20 10:58 UTC (permalink / raw)
To: Matthew Auld; +Cc: intel-xe, dri-devel, Sashiko
On Mon, May 18, 2026 at 04:55:12PM +0100, Matthew Auld wrote:
> On 18/05/2026 15:14, Francois Dugast wrote:
> > When split_block() fails it returns before calling mark_split(), leaving
> > the block in the FREE state and still linked in the rbtree. The four
> > err_undo paths then call __gpu_buddy_free() without first removing the
> > block from the tree, which leads to two distinct bugs:
> >
> > - If the buddy is also free, __gpu_buddy_free() merges the two siblings
> > by calling gpu_block_free(mm, block) while block->rb is still linked
> > in the tree. Any subsequent rbtree traversal will follow the now-
> > dangling pointer, causing a use-after-free.
> >
> > - In alloc_from_freetree(), where there is no buddy guard,
> > __gpu_buddy_free() always reaches mark_free() -> rbtree_insert() with
> > block still in the tree, corrupting the rbtree.
> >
> > The same pattern is already used correctly in __force_merge(): call
> > rbtree_remove() to unlink the block before handing it to
> > __gpu_buddy_free(). Apply the same fix to all four err_undo sites.
> >
> > Reported-by: Sashiko <sashiko-bot@kernel.org>
> > Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> > Assisted-by: GitHub Copilot:claude-sonnet-4.6
> > ---
> > drivers/gpu/buddy.c | 16 ++++++++++++----
> > 1 file changed, 12 insertions(+), 4 deletions(-)
> >
> > diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> > index eb1457376307..dac2027bb64a 100644
> > --- a/drivers/gpu/buddy.c
> > +++ b/drivers/gpu/buddy.c
> > @@ -737,8 +737,10 @@ __alloc_range_bias(struct gpu_buddy *mm,
> > buddy = __get_buddy(block);
> > if (buddy &&
> > (gpu_buddy_block_is_free(block) &&
> > - gpu_buddy_block_is_free(buddy)))
> > + gpu_buddy_block_is_free(buddy))) {
> > + rbtree_remove(mm, block);
> > __gpu_buddy_free(mm, block, false);
> > + }
> > return ERR_PTR(err);
> > }
> > @@ -847,8 +849,10 @@ alloc_from_freetree(struct gpu_buddy *mm,
> > return block;
> > err_undo:
> > - if (tmp != order)
> > + if (tmp != order) {
> > + rbtree_remove(mm, block);
>
> Actually, I think this needs the same checking like elsewhere? Say we fail
> on the first split? Nothing was actually split, right?
I think this is unnecessary: for block this is tested above with
BUG_ON(!gpu_buddy_block_is_free(block)). If split_block() fails then it
happens before mark_split() so block remains free. If buddy is not free
then the merge loop is skipped in __gpu_buddy_free() but mark_free() is
called so we do remove + re-insert.
Also, the checks are added with patch #3 and the introduction of
__gpu_buddy_undo_splits().
Francois
>
> > __gpu_buddy_free(mm, block, false);
> > + }
> > return ERR_PTR(err);
> > }
> > @@ -968,8 +972,10 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
> > buddy = __get_buddy(block);
> > if (buddy &&
> > (gpu_buddy_block_is_free(block) &&
> > - gpu_buddy_block_is_free(buddy)))
> > + gpu_buddy_block_is_free(buddy))) {
> > + rbtree_remove(mm, block);
> > __gpu_buddy_free(mm, block, false);
> > + }
> > return ERR_PTR(err);
> > }
> > @@ -1054,8 +1060,10 @@ static int __alloc_range(struct gpu_buddy *mm,
> > buddy = __get_buddy(block);
> > if (buddy &&
> > (gpu_buddy_block_is_free(block) &&
> > - gpu_buddy_block_is_free(buddy)))
> > + gpu_buddy_block_is_free(buddy))) {
> > + rbtree_remove(mm, block);
> > __gpu_buddy_free(mm, block, false);
> > + }
> > err_free:
> > if (err == -ENOSPC && total_allocated_on_err) {
>
^ permalink raw reply [flat|nested] 18+ messages in thread* Re: [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites
2026-05-20 10:58 ` Francois Dugast
@ 2026-05-21 16:18 ` Matthew Auld
0 siblings, 0 replies; 18+ messages in thread
From: Matthew Auld @ 2026-05-21 16:18 UTC (permalink / raw)
To: Francois Dugast; +Cc: intel-xe, dri-devel, Sashiko
On 20/05/2026 11:58, Francois Dugast wrote:
> On Mon, May 18, 2026 at 04:55:12PM +0100, Matthew Auld wrote:
>> On 18/05/2026 15:14, Francois Dugast wrote:
>>> When split_block() fails it returns before calling mark_split(), leaving
>>> the block in the FREE state and still linked in the rbtree. The four
>>> err_undo paths then call __gpu_buddy_free() without first removing the
>>> block from the tree, which leads to two distinct bugs:
>>>
>>> - If the buddy is also free, __gpu_buddy_free() merges the two siblings
>>> by calling gpu_block_free(mm, block) while block->rb is still linked
>>> in the tree. Any subsequent rbtree traversal will follow the now-
>>> dangling pointer, causing a use-after-free.
>>>
>>> - In alloc_from_freetree(), where there is no buddy guard,
>>> __gpu_buddy_free() always reaches mark_free() -> rbtree_insert() with
>>> block still in the tree, corrupting the rbtree.
>>>
>>> The same pattern is already used correctly in __force_merge(): call
>>> rbtree_remove() to unlink the block before handing it to
>>> __gpu_buddy_free(). Apply the same fix to all four err_undo sites.
>>>
>>> Reported-by: Sashiko <sashiko-bot@kernel.org>
>>> Signed-off-by: Francois Dugast <francois.dugast@intel.com>
>>> Assisted-by: GitHub Copilot:claude-sonnet-4.6
>>> ---
>>> drivers/gpu/buddy.c | 16 ++++++++++++----
>>> 1 file changed, 12 insertions(+), 4 deletions(-)
>>>
>>> diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
>>> index eb1457376307..dac2027bb64a 100644
>>> --- a/drivers/gpu/buddy.c
>>> +++ b/drivers/gpu/buddy.c
>>> @@ -737,8 +737,10 @@ __alloc_range_bias(struct gpu_buddy *mm,
>>> buddy = __get_buddy(block);
>>> if (buddy &&
>>> (gpu_buddy_block_is_free(block) &&
>>> - gpu_buddy_block_is_free(buddy)))
>>> + gpu_buddy_block_is_free(buddy))) {
>>> + rbtree_remove(mm, block);
>>> __gpu_buddy_free(mm, block, false);
>>> + }
>>> return ERR_PTR(err);
>>> }
>>> @@ -847,8 +849,10 @@ alloc_from_freetree(struct gpu_buddy *mm,
>>> return block;
>>> err_undo:
>>> - if (tmp != order)
>>> + if (tmp != order) {
>>> + rbtree_remove(mm, block);
>>
>> Actually, I think this needs the same checking like elsewhere? Say we fail
>> on the first split? Nothing was actually split, right?
>
> I think this is unnecessary: for block this is tested above with
> BUG_ON(!gpu_buddy_block_is_free(block)). If split_block() fails then it
> happens before mark_split() so block remains free. If buddy is not free
> then the merge loop is skipped in __gpu_buddy_free() but mark_free() is
> called so we do remove + re-insert.
>
> Also, the checks are added with patch #3 and the introduction of
> __gpu_buddy_undo_splits().
Right, makes sense.
>
> Francois
>
>>
>>> __gpu_buddy_free(mm, block, false);
>>> + }
>>> return ERR_PTR(err);
>>> }
>>> @@ -968,8 +972,10 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
>>> buddy = __get_buddy(block);
>>> if (buddy &&
>>> (gpu_buddy_block_is_free(block) &&
>>> - gpu_buddy_block_is_free(buddy)))
>>> + gpu_buddy_block_is_free(buddy))) {
>>> + rbtree_remove(mm, block);
>>> __gpu_buddy_free(mm, block, false);
>>> + }
>>> return ERR_PTR(err);
>>> }
>>> @@ -1054,8 +1060,10 @@ static int __alloc_range(struct gpu_buddy *mm,
>>> buddy = __get_buddy(block);
>>> if (buddy &&
>>> (gpu_buddy_block_is_free(block) &&
>>> - gpu_buddy_block_is_free(buddy)))
>>> + gpu_buddy_block_is_free(buddy))) {
>>> + rbtree_remove(mm, block);
>>> __gpu_buddy_free(mm, block, false);
>>> + }
>>> err_free:
>>> if (err == -ENOSPC && total_allocated_on_err) {
>>
^ permalink raw reply [flat|nested] 18+ messages in thread
* [PATCH v3 2/5] gpu/buddy: Remove redundant condition in alloc_from_freetree() error path
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
2026-05-18 14:14 ` [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites Francois Dugast
@ 2026-05-18 14:14 ` Francois Dugast
2026-05-18 14:14 ` [PATCH v3 3/5] gpu/buddy: Introduce __gpu_buddy_undo_splits() helper Francois Dugast
` (6 subsequent siblings)
8 siblings, 0 replies; 18+ messages in thread
From: Francois Dugast @ 2026-05-18 14:14 UTC (permalink / raw)
To: intel-xe; +Cc: dri-devel, matthew.auld, Francois Dugast
The err_undo label in alloc_from_freetree() is only reachable via a
goto from inside the `while (tmp != order)` loop, which means tmp is
guaranteed to differ from order at that point. The surrounding
`if (tmp != order)` guard was therefore always true and can be dropped
without any behavioral change.
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
---
drivers/gpu/buddy.c | 6 ++----
1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
index dac2027bb64a..9f6696f47f89 100644
--- a/drivers/gpu/buddy.c
+++ b/drivers/gpu/buddy.c
@@ -849,10 +849,8 @@ alloc_from_freetree(struct gpu_buddy *mm,
return block;
err_undo:
- if (tmp != order) {
- rbtree_remove(mm, block);
- __gpu_buddy_free(mm, block, false);
- }
+ rbtree_remove(mm, block);
+ __gpu_buddy_free(mm, block, false);
return ERR_PTR(err);
}
--
2.43.0
^ permalink raw reply related [flat|nested] 18+ messages in thread* [PATCH v3 3/5] gpu/buddy: Introduce __gpu_buddy_undo_splits() helper
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
2026-05-18 14:14 ` [PATCH v3 1/5] gpu/buddy: Fix use-after-free in split_block() call sites Francois Dugast
2026-05-18 14:14 ` [PATCH v3 2/5] gpu/buddy: Remove redundant condition in alloc_from_freetree() error path Francois Dugast
@ 2026-05-18 14:14 ` Francois Dugast
2026-05-18 15:57 ` Matthew Auld
2026-05-18 14:14 ` [PATCH v3 4/5] gpu/buddy: Track per-order free blocks with a scoreboard Francois Dugast
` (5 subsequent siblings)
8 siblings, 1 reply; 18+ messages in thread
From: Francois Dugast @ 2026-05-18 14:14 UTC (permalink / raw)
To: intel-xe; +Cc: dri-devel, matthew.auld, Francois Dugast
The pattern of merging a block back with its buddy on error paths is
duplicated across multiple locations. Extract it into a
__gpu_buddy_undo_splits() helper to avoid repetition and prepare for
future changes.
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
Suggested-by: Matthew Auld <matthew.auld@intel.com>
---
drivers/gpu/buddy.c | 43 +++++++++++++++++--------------------------
1 file changed, 17 insertions(+), 26 deletions(-)
diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
index 9f6696f47f89..8654604b87a4 100644
--- a/drivers/gpu/buddy.c
+++ b/drivers/gpu/buddy.c
@@ -650,6 +650,19 @@ static bool block_incompatible(struct gpu_buddy_block *block, unsigned int flags
return needs_clear != gpu_buddy_block_is_clear(block);
}
+static void __gpu_buddy_undo_splits(struct gpu_buddy *mm,
+ struct gpu_buddy_block *block)
+{
+ struct gpu_buddy_block *buddy = __get_buddy(block);
+
+ if (buddy &&
+ (gpu_buddy_block_is_free(block) &&
+ gpu_buddy_block_is_free(buddy))) {
+ rbtree_remove(mm, block);
+ __gpu_buddy_free(mm, block, false);
+ }
+}
+
static struct gpu_buddy_block *
__alloc_range_bias(struct gpu_buddy *mm,
u64 start, u64 end,
@@ -659,7 +672,6 @@ __alloc_range_bias(struct gpu_buddy *mm,
{
u64 req_size = mm->chunk_size << order;
struct gpu_buddy_block *block;
- struct gpu_buddy_block *buddy;
LIST_HEAD(dfs);
int err;
int i;
@@ -734,13 +746,7 @@ __alloc_range_bias(struct gpu_buddy *mm,
* bigger is better, so make sure we merge everything back before we
* free the allocated blocks.
*/
- buddy = __get_buddy(block);
- if (buddy &&
- (gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy))) {
- rbtree_remove(mm, block);
- __gpu_buddy_free(mm, block, false);
- }
+ __gpu_buddy_undo_splits(mm, block);
return ERR_PTR(err);
}
@@ -849,8 +855,7 @@ alloc_from_freetree(struct gpu_buddy *mm,
return block;
err_undo:
- rbtree_remove(mm, block);
- __gpu_buddy_free(mm, block, false);
+ __gpu_buddy_undo_splits(mm, block);
return ERR_PTR(err);
}
@@ -914,7 +919,6 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
{
struct gpu_buddy_block *block = NULL;
unsigned int order, tmp, alignment;
- struct gpu_buddy_block *buddy;
enum gpu_buddy_free_tree tree;
unsigned long pages;
int err;
@@ -967,13 +971,7 @@ gpu_buddy_offset_aligned_allocation(struct gpu_buddy *mm,
* bigger is better, so make sure we merge everything back before we
* free the allocated blocks.
*/
- buddy = __get_buddy(block);
- if (buddy &&
- (gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy))) {
- rbtree_remove(mm, block);
- __gpu_buddy_free(mm, block, false);
- }
+ __gpu_buddy_undo_splits(mm, block);
return ERR_PTR(err);
}
@@ -984,7 +982,6 @@ static int __alloc_range(struct gpu_buddy *mm,
u64 *total_allocated_on_err)
{
struct gpu_buddy_block *block;
- struct gpu_buddy_block *buddy;
u64 total_allocated = 0;
LIST_HEAD(allocated);
u64 end;
@@ -1055,13 +1052,7 @@ static int __alloc_range(struct gpu_buddy *mm,
* bigger is better, so make sure we merge everything back before we
* free the allocated blocks.
*/
- buddy = __get_buddy(block);
- if (buddy &&
- (gpu_buddy_block_is_free(block) &&
- gpu_buddy_block_is_free(buddy))) {
- rbtree_remove(mm, block);
- __gpu_buddy_free(mm, block, false);
- }
+ __gpu_buddy_undo_splits(mm, block);
err_free:
if (err == -ENOSPC && total_allocated_on_err) {
--
2.43.0
^ permalink raw reply related [flat|nested] 18+ messages in thread* [PATCH v3 4/5] gpu/buddy: Track per-order free blocks with a scoreboard
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (2 preceding siblings ...)
2026-05-18 14:14 ` [PATCH v3 3/5] gpu/buddy: Introduce __gpu_buddy_undo_splits() helper Francois Dugast
@ 2026-05-18 14:14 ` Francois Dugast
2026-05-18 15:58 ` Matthew Auld
2026-05-18 14:14 ` [PATCH v3 5/5] gpu/buddy: Track per-order used " Francois Dugast
` (4 subsequent siblings)
8 siblings, 1 reply; 18+ messages in thread
From: Francois Dugast @ 2026-05-18 14:14 UTC (permalink / raw)
To: intel-xe; +Cc: dri-devel, matthew.auld, Francois Dugast
Reporting per-order free block counts in drm_buddy_print() currently
requires walking all rbtrees, which is O(n) over the total number of
free blocks and holds the allocator lock for the duration. This becomes
expensive on large VRAM heaps with many small free fragments.
Maintain a free_scoreboard[] array indexed by order instead, so that
the count for any order is always available in O(1). The scoreboard is
kept accurate by hooking into the four places where a block's free state
changes: mark_free(), mark_allocated(), mark_split(), and the sites in
__gpu_buddy_free(), __force_merge(), and the four err_undo paths that
call rbtree_remove() directly on free blocks without going through
mark_*().
The print functions are simplified as a result: the rbtree traversal
is replaced by a direct array lookup.
v3: Update after introducing __gpu_buddy_undo_splits() helper
v2: Update after fix for use-after-free in split_block() call sites
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
Assisted-by: GitHub Copilot:claude-sonnet-4.6
---
drivers/gpu/buddy.c | 36 +++++++++++++++++++++---------------
drivers/gpu/drm/drm_buddy.c | 16 ++--------------
include/linux/gpu_buddy.h | 7 +++++++
3 files changed, 30 insertions(+), 29 deletions(-)
diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
index 8654604b87a4..de18b63fef0a 100644
--- a/drivers/gpu/buddy.c
+++ b/drivers/gpu/buddy.c
@@ -193,6 +193,8 @@ static void mark_allocated(struct gpu_buddy *mm,
block->header &= ~GPU_BUDDY_HEADER_STATE;
block->header |= GPU_BUDDY_ALLOCATED;
+ mm->free_scoreboard[gpu_buddy_block_order(block)]--;
+
rbtree_remove(mm, block);
}
@@ -204,6 +206,8 @@ static void mark_free(struct gpu_buddy *mm,
block->header &= ~GPU_BUDDY_HEADER_STATE;
block->header |= GPU_BUDDY_FREE;
+ mm->free_scoreboard[gpu_buddy_block_order(block)]++;
+
tree = get_block_tree(block);
rbtree_insert(mm, block, tree);
}
@@ -214,6 +218,8 @@ static void mark_split(struct gpu_buddy *mm,
block->header &= ~GPU_BUDDY_HEADER_STATE;
block->header |= GPU_BUDDY_SPLIT;
+ mm->free_scoreboard[gpu_buddy_block_order(block)]--;
+
rbtree_remove(mm, block);
}
@@ -271,6 +277,7 @@ static unsigned int __gpu_buddy_free(struct gpu_buddy *mm,
}
rbtree_remove(mm, buddy);
+ mm->free_scoreboard[gpu_buddy_block_order(buddy)]--;
if (force_merge && gpu_buddy_block_is_clear(buddy))
mm->clear_avail -= gpu_buddy_block_size(mm, buddy);
@@ -335,6 +342,7 @@ static int __force_merge(struct gpu_buddy *mm,
iter = rb_prev(iter);
rbtree_remove(mm, block);
+ mm->free_scoreboard[gpu_buddy_block_order(block)]--;
if (gpu_buddy_block_is_clear(block))
mm->clear_avail -= gpu_buddy_block_size(mm, block);
@@ -384,11 +392,17 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
BUG_ON(mm->max_order > GPU_BUDDY_MAX_ORDER);
+ mm->free_scoreboard = kcalloc(mm->max_order + 1,
+ sizeof(*mm->free_scoreboard),
+ GFP_KERNEL);
+ if (!mm->free_scoreboard)
+ return -ENOMEM;
+
mm->free_trees = kmalloc_array(GPU_BUDDY_MAX_FREE_TREES,
sizeof(*mm->free_trees),
GFP_KERNEL);
if (!mm->free_trees)
- return -ENOMEM;
+ goto out_free_scoreboard;
for_each_free_tree(i) {
mm->free_trees[i] = kmalloc_array(mm->max_order + 1,
@@ -450,6 +464,8 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
while (i--)
kfree(mm->free_trees[i]);
kfree(mm->free_trees);
+out_free_scoreboard:
+ kfree(mm->free_scoreboard);
return -ENOMEM;
}
EXPORT_SYMBOL(gpu_buddy_init);
@@ -488,6 +504,7 @@ void gpu_buddy_fini(struct gpu_buddy *mm)
kfree(mm->free_trees[i]);
kfree(mm->free_trees);
kfree(mm->roots);
+ kfree(mm->free_scoreboard);
}
EXPORT_SYMBOL(gpu_buddy_fini);
@@ -659,6 +676,7 @@ static void __gpu_buddy_undo_splits(struct gpu_buddy *mm,
(gpu_buddy_block_is_free(block) &&
gpu_buddy_block_is_free(buddy))) {
rbtree_remove(mm, block);
+ mm->free_scoreboard[gpu_buddy_block_order(block)]--;
__gpu_buddy_free(mm, block, false);
}
}
@@ -1487,21 +1505,9 @@ void gpu_buddy_print(struct gpu_buddy *mm)
mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
for (order = mm->max_order; order >= 0; order--) {
- struct gpu_buddy_block *block, *tmp;
- struct rb_root *root;
- u64 count = 0, free;
- unsigned int tree;
-
- for_each_free_tree(tree) {
- root = &mm->free_trees[tree][order];
-
- rbtree_postorder_for_each_entry_safe(block, tmp, root, rb) {
- BUG_ON(!gpu_buddy_block_is_free(block));
- count++;
- }
- }
+ u64 count = mm->free_scoreboard[order];
+ u64 free = count * (mm->chunk_size << order);
- free = count * (mm->chunk_size << order);
if (free < SZ_1M)
pr_info("order-%2d free: %8llu KiB, blocks: %llu\n",
order, free >> 10, count);
diff --git a/drivers/gpu/drm/drm_buddy.c b/drivers/gpu/drm/drm_buddy.c
index faa025498de4..eef995e08a37 100644
--- a/drivers/gpu/drm/drm_buddy.c
+++ b/drivers/gpu/drm/drm_buddy.c
@@ -47,23 +47,11 @@ void drm_buddy_print(struct gpu_buddy *mm, struct drm_printer *p)
mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
for (order = mm->max_order; order >= 0; order--) {
- struct gpu_buddy_block *block, *tmp;
- struct rb_root *root;
- u64 count = 0, free;
- unsigned int tree;
-
- for_each_free_tree(tree) {
- root = &mm->free_trees[tree][order];
-
- rbtree_postorder_for_each_entry_safe(block, tmp, root, rb) {
- BUG_ON(!gpu_buddy_block_is_free(block));
- count++;
- }
- }
+ u64 count = mm->free_scoreboard[order];
+ u64 free = count * (mm->chunk_size << order);
drm_printf(p, "order-%2d ", order);
- free = count * (mm->chunk_size << order);
if (free < SZ_1M)
drm_printf(p, "free: %8llu KiB", free >> 10);
else
diff --git a/include/linux/gpu_buddy.h b/include/linux/gpu_buddy.h
index 71941a039648..a28f7d7637ca 100644
--- a/include/linux/gpu_buddy.h
+++ b/include/linux/gpu_buddy.h
@@ -173,6 +173,13 @@ struct gpu_buddy {
* that fits in the remaining space.
*/
struct gpu_buddy_block **roots;
+ /*
+ * Per-order free block scoreboard: free_scoreboard[order] holds the
+ * number of blocks of that order currently in the free state.
+ * Incremented in mark_free(), decremented wherever rbtree_remove() is
+ * called on a free block.
+ */
+ u64 *free_scoreboard;
/* public: */
unsigned int n_roots;
unsigned int max_order;
--
2.43.0
^ permalink raw reply related [flat|nested] 18+ messages in thread* Re: [PATCH v3 4/5] gpu/buddy: Track per-order free blocks with a scoreboard
2026-05-18 14:14 ` [PATCH v3 4/5] gpu/buddy: Track per-order free blocks with a scoreboard Francois Dugast
@ 2026-05-18 15:58 ` Matthew Auld
0 siblings, 0 replies; 18+ messages in thread
From: Matthew Auld @ 2026-05-18 15:58 UTC (permalink / raw)
To: Francois Dugast, intel-xe; +Cc: dri-devel
On 18/05/2026 15:14, Francois Dugast wrote:
> Reporting per-order free block counts in drm_buddy_print() currently
> requires walking all rbtrees, which is O(n) over the total number of
> free blocks and holds the allocator lock for the duration. This becomes
> expensive on large VRAM heaps with many small free fragments.
>
> Maintain a free_scoreboard[] array indexed by order instead, so that
> the count for any order is always available in O(1). The scoreboard is
> kept accurate by hooking into the four places where a block's free state
> changes: mark_free(), mark_allocated(), mark_split(), and the sites in
> __gpu_buddy_free(), __force_merge(), and the four err_undo paths that
> call rbtree_remove() directly on free blocks without going through
> mark_*().
>
> The print functions are simplified as a result: the rbtree traversal
> is replaced by a direct array lookup.
>
> v3: Update after introducing __gpu_buddy_undo_splits() helper
>
> v2: Update after fix for use-after-free in split_block() call sites
>
> Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> Assisted-by: GitHub Copilot:claude-sonnet-4.6
Reviewed-by: Matthew Auld <matthew.auld@intel.com>
> ---
> drivers/gpu/buddy.c | 36 +++++++++++++++++++++---------------
> drivers/gpu/drm/drm_buddy.c | 16 ++--------------
> include/linux/gpu_buddy.h | 7 +++++++
> 3 files changed, 30 insertions(+), 29 deletions(-)
>
> diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> index 8654604b87a4..de18b63fef0a 100644
> --- a/drivers/gpu/buddy.c
> +++ b/drivers/gpu/buddy.c
> @@ -193,6 +193,8 @@ static void mark_allocated(struct gpu_buddy *mm,
> block->header &= ~GPU_BUDDY_HEADER_STATE;
> block->header |= GPU_BUDDY_ALLOCATED;
>
> + mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> +
> rbtree_remove(mm, block);
> }
>
> @@ -204,6 +206,8 @@ static void mark_free(struct gpu_buddy *mm,
> block->header &= ~GPU_BUDDY_HEADER_STATE;
> block->header |= GPU_BUDDY_FREE;
>
> + mm->free_scoreboard[gpu_buddy_block_order(block)]++;
> +
> tree = get_block_tree(block);
> rbtree_insert(mm, block, tree);
> }
> @@ -214,6 +218,8 @@ static void mark_split(struct gpu_buddy *mm,
> block->header &= ~GPU_BUDDY_HEADER_STATE;
> block->header |= GPU_BUDDY_SPLIT;
>
> + mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> +
> rbtree_remove(mm, block);
> }
>
> @@ -271,6 +277,7 @@ static unsigned int __gpu_buddy_free(struct gpu_buddy *mm,
> }
>
> rbtree_remove(mm, buddy);
> + mm->free_scoreboard[gpu_buddy_block_order(buddy)]--;
> if (force_merge && gpu_buddy_block_is_clear(buddy))
> mm->clear_avail -= gpu_buddy_block_size(mm, buddy);
>
> @@ -335,6 +342,7 @@ static int __force_merge(struct gpu_buddy *mm,
> iter = rb_prev(iter);
>
> rbtree_remove(mm, block);
> + mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> if (gpu_buddy_block_is_clear(block))
> mm->clear_avail -= gpu_buddy_block_size(mm, block);
>
> @@ -384,11 +392,17 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
>
> BUG_ON(mm->max_order > GPU_BUDDY_MAX_ORDER);
>
> + mm->free_scoreboard = kcalloc(mm->max_order + 1,
> + sizeof(*mm->free_scoreboard),
> + GFP_KERNEL);
> + if (!mm->free_scoreboard)
> + return -ENOMEM;
> +
> mm->free_trees = kmalloc_array(GPU_BUDDY_MAX_FREE_TREES,
> sizeof(*mm->free_trees),
> GFP_KERNEL);
> if (!mm->free_trees)
> - return -ENOMEM;
> + goto out_free_scoreboard;
>
> for_each_free_tree(i) {
> mm->free_trees[i] = kmalloc_array(mm->max_order + 1,
> @@ -450,6 +464,8 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
> while (i--)
> kfree(mm->free_trees[i]);
> kfree(mm->free_trees);
> +out_free_scoreboard:
> + kfree(mm->free_scoreboard);
> return -ENOMEM;
> }
> EXPORT_SYMBOL(gpu_buddy_init);
> @@ -488,6 +504,7 @@ void gpu_buddy_fini(struct gpu_buddy *mm)
> kfree(mm->free_trees[i]);
> kfree(mm->free_trees);
> kfree(mm->roots);
> + kfree(mm->free_scoreboard);
> }
> EXPORT_SYMBOL(gpu_buddy_fini);
>
> @@ -659,6 +676,7 @@ static void __gpu_buddy_undo_splits(struct gpu_buddy *mm,
> (gpu_buddy_block_is_free(block) &&
> gpu_buddy_block_is_free(buddy))) {
> rbtree_remove(mm, block);
> + mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> __gpu_buddy_free(mm, block, false);
> }
> }
> @@ -1487,21 +1505,9 @@ void gpu_buddy_print(struct gpu_buddy *mm)
> mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
>
> for (order = mm->max_order; order >= 0; order--) {
> - struct gpu_buddy_block *block, *tmp;
> - struct rb_root *root;
> - u64 count = 0, free;
> - unsigned int tree;
> -
> - for_each_free_tree(tree) {
> - root = &mm->free_trees[tree][order];
> -
> - rbtree_postorder_for_each_entry_safe(block, tmp, root, rb) {
> - BUG_ON(!gpu_buddy_block_is_free(block));
> - count++;
> - }
> - }
> + u64 count = mm->free_scoreboard[order];
> + u64 free = count * (mm->chunk_size << order);
>
> - free = count * (mm->chunk_size << order);
> if (free < SZ_1M)
> pr_info("order-%2d free: %8llu KiB, blocks: %llu\n",
> order, free >> 10, count);
> diff --git a/drivers/gpu/drm/drm_buddy.c b/drivers/gpu/drm/drm_buddy.c
> index faa025498de4..eef995e08a37 100644
> --- a/drivers/gpu/drm/drm_buddy.c
> +++ b/drivers/gpu/drm/drm_buddy.c
> @@ -47,23 +47,11 @@ void drm_buddy_print(struct gpu_buddy *mm, struct drm_printer *p)
> mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
>
> for (order = mm->max_order; order >= 0; order--) {
> - struct gpu_buddy_block *block, *tmp;
> - struct rb_root *root;
> - u64 count = 0, free;
> - unsigned int tree;
> -
> - for_each_free_tree(tree) {
> - root = &mm->free_trees[tree][order];
> -
> - rbtree_postorder_for_each_entry_safe(block, tmp, root, rb) {
> - BUG_ON(!gpu_buddy_block_is_free(block));
> - count++;
> - }
> - }
> + u64 count = mm->free_scoreboard[order];
> + u64 free = count * (mm->chunk_size << order);
>
> drm_printf(p, "order-%2d ", order);
>
> - free = count * (mm->chunk_size << order);
> if (free < SZ_1M)
> drm_printf(p, "free: %8llu KiB", free >> 10);
> else
> diff --git a/include/linux/gpu_buddy.h b/include/linux/gpu_buddy.h
> index 71941a039648..a28f7d7637ca 100644
> --- a/include/linux/gpu_buddy.h
> +++ b/include/linux/gpu_buddy.h
> @@ -173,6 +173,13 @@ struct gpu_buddy {
> * that fits in the remaining space.
> */
> struct gpu_buddy_block **roots;
> + /*
> + * Per-order free block scoreboard: free_scoreboard[order] holds the
> + * number of blocks of that order currently in the free state.
> + * Incremented in mark_free(), decremented wherever rbtree_remove() is
> + * called on a free block.
> + */
> + u64 *free_scoreboard;
> /* public: */
> unsigned int n_roots;
> unsigned int max_order;
^ permalink raw reply [flat|nested] 18+ messages in thread
* [PATCH v3 5/5] gpu/buddy: Track per-order used blocks with a scoreboard
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (3 preceding siblings ...)
2026-05-18 14:14 ` [PATCH v3 4/5] gpu/buddy: Track per-order free blocks with a scoreboard Francois Dugast
@ 2026-05-18 14:14 ` Francois Dugast
2026-05-18 16:02 ` Matthew Auld
2026-05-18 14:40 ` ✗ CI.checkpatch: warning for gpu/buddy: Per-order free and used block scoreboards (rev4) Patchwork
` (3 subsequent siblings)
8 siblings, 1 reply; 18+ messages in thread
From: Francois Dugast @ 2026-05-18 14:14 UTC (permalink / raw)
To: intel-xe; +Cc: dri-devel, matthew.auld, Francois Dugast
Extend the scoreboard approach from the previous commit to used blocks,
so drm_buddy_print() can report per-order allocation pressure in O(1).
Unlike free blocks, an allocated block can leave the allocated state
through mark_free() (normal free and gpu_buddy_block_trim()) or be
consumed directly by gpu_block_free() during coalescing. Both sites are
guarded by gpu_buddy_block_is_allocated() and paired with the increment
in mark_allocated().
v2:
- Update after fix for use-after-free in split_block() call sites
- Change goto label to out_free_used_scoreboard for clarity
- Make drm_buddy_print() and gpu_buddy_print() symmetric for used and
free
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
Assisted-by: GitHub Copilot:claude-sonnet-4.6
---
drivers/gpu/buddy.c | 39 +++++++++++++++++++++++++++----------
drivers/gpu/drm/drm_buddy.c | 18 +++++++++++------
include/linux/gpu_buddy.h | 8 ++++++++
3 files changed, 49 insertions(+), 16 deletions(-)
diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
index de18b63fef0a..f81d0d8fde15 100644
--- a/drivers/gpu/buddy.c
+++ b/drivers/gpu/buddy.c
@@ -194,6 +194,7 @@ static void mark_allocated(struct gpu_buddy *mm,
block->header |= GPU_BUDDY_ALLOCATED;
mm->free_scoreboard[gpu_buddy_block_order(block)]--;
+ mm->used_scoreboard[gpu_buddy_block_order(block)]++;
rbtree_remove(mm, block);
}
@@ -203,6 +204,9 @@ static void mark_free(struct gpu_buddy *mm,
{
enum gpu_buddy_free_tree tree;
+ if (gpu_buddy_block_is_allocated(block))
+ mm->used_scoreboard[gpu_buddy_block_order(block)]--;
+
block->header &= ~GPU_BUDDY_HEADER_STATE;
block->header |= GPU_BUDDY_FREE;
@@ -281,6 +285,9 @@ static unsigned int __gpu_buddy_free(struct gpu_buddy *mm,
if (force_merge && gpu_buddy_block_is_clear(buddy))
mm->clear_avail -= gpu_buddy_block_size(mm, buddy);
+ if (gpu_buddy_block_is_allocated(block))
+ mm->used_scoreboard[gpu_buddy_block_order(block)]--;
+
gpu_block_free(mm, block);
gpu_block_free(mm, buddy);
@@ -398,11 +405,17 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
if (!mm->free_scoreboard)
return -ENOMEM;
+ mm->used_scoreboard = kcalloc(mm->max_order + 1,
+ sizeof(*mm->used_scoreboard),
+ GFP_KERNEL);
+ if (!mm->used_scoreboard)
+ goto out_free_free_scoreboard;
+
mm->free_trees = kmalloc_array(GPU_BUDDY_MAX_FREE_TREES,
sizeof(*mm->free_trees),
GFP_KERNEL);
if (!mm->free_trees)
- goto out_free_scoreboard;
+ goto out_free_used_scoreboard;
for_each_free_tree(i) {
mm->free_trees[i] = kmalloc_array(mm->max_order + 1,
@@ -464,7 +477,9 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
while (i--)
kfree(mm->free_trees[i]);
kfree(mm->free_trees);
-out_free_scoreboard:
+out_free_used_scoreboard:
+ kfree(mm->used_scoreboard);
+out_free_free_scoreboard:
kfree(mm->free_scoreboard);
return -ENOMEM;
}
@@ -505,6 +520,7 @@ void gpu_buddy_fini(struct gpu_buddy *mm)
kfree(mm->free_trees);
kfree(mm->roots);
kfree(mm->free_scoreboard);
+ kfree(mm->used_scoreboard);
}
EXPORT_SYMBOL(gpu_buddy_fini);
@@ -1505,15 +1521,18 @@ void gpu_buddy_print(struct gpu_buddy *mm)
mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
for (order = mm->max_order; order >= 0; order--) {
- u64 count = mm->free_scoreboard[order];
- u64 free = count * (mm->chunk_size << order);
-
- if (free < SZ_1M)
- pr_info("order-%2d free: %8llu KiB, blocks: %llu\n",
- order, free >> 10, count);
+ u64 free_count = mm->free_scoreboard[order];
+ u64 used_count = mm->used_scoreboard[order];
+ u64 block_size = mm->chunk_size << order;
+ u64 free = free_count * block_size;
+ u64 used = used_count * block_size;
+
+ if (block_size < SZ_1M)
+ pr_info("order-%2d free: %8llu KiB, used: %8llu KiB, free_blocks: %llu, used_blocks: %llu\n",
+ order, free >> 10, used >> 10, free_count, used_count);
else
- pr_info("order-%2d free: %8llu MiB, blocks: %llu\n",
- order, free >> 20, count);
+ pr_info("order-%2d free: %8llu MiB, used: %8llu MiB, free_blocks: %llu, used_blocks: %llu\n",
+ order, free >> 20, used >> 20, free_count, used_count);
}
}
EXPORT_SYMBOL(gpu_buddy_print);
diff --git a/drivers/gpu/drm/drm_buddy.c b/drivers/gpu/drm/drm_buddy.c
index eef995e08a37..1536e59c6fe7 100644
--- a/drivers/gpu/drm/drm_buddy.c
+++ b/drivers/gpu/drm/drm_buddy.c
@@ -47,17 +47,23 @@ void drm_buddy_print(struct gpu_buddy *mm, struct drm_printer *p)
mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
for (order = mm->max_order; order >= 0; order--) {
- u64 count = mm->free_scoreboard[order];
- u64 free = count * (mm->chunk_size << order);
+ u64 free_count = mm->free_scoreboard[order];
+ u64 used_count = mm->used_scoreboard[order];
+ u64 block_size = mm->chunk_size << order;
+ u64 free = free_count * block_size;
+ u64 used = used_count * block_size;
drm_printf(p, "order-%2d ", order);
- if (free < SZ_1M)
- drm_printf(p, "free: %8llu KiB", free >> 10);
+ if (block_size < SZ_1M)
+ drm_printf(p, "free: %8llu KiB, used: %8llu KiB",
+ free >> 10, used >> 10);
else
- drm_printf(p, "free: %8llu MiB", free >> 20);
+ drm_printf(p, "free: %8llu MiB, used: %8llu MiB",
+ free >> 20, used >> 20);
- drm_printf(p, ", blocks: %llu\n", count);
+ drm_printf(p, ", free_blocks: %llu, used_blocks: %llu\n",
+ free_count, used_count);
}
}
EXPORT_SYMBOL(drm_buddy_print);
diff --git a/include/linux/gpu_buddy.h b/include/linux/gpu_buddy.h
index a28f7d7637ca..e037714563d8 100644
--- a/include/linux/gpu_buddy.h
+++ b/include/linux/gpu_buddy.h
@@ -180,6 +180,14 @@ struct gpu_buddy {
* called on a free block.
*/
u64 *free_scoreboard;
+ /*
+ * Per-order used block scoreboard: used_scoreboard[order] holds the
+ * number of blocks of that order currently in the allocated state.
+ * Incremented in mark_allocated(), decremented in mark_free() (guarded
+ * by gpu_buddy_block_is_allocated()) and in __gpu_buddy_free() when an
+ * allocated block is consumed directly during buddy coalescing.
+ */
+ u64 *used_scoreboard;
/* public: */
unsigned int n_roots;
unsigned int max_order;
--
2.43.0
^ permalink raw reply related [flat|nested] 18+ messages in thread* Re: [PATCH v3 5/5] gpu/buddy: Track per-order used blocks with a scoreboard
2026-05-18 14:14 ` [PATCH v3 5/5] gpu/buddy: Track per-order used " Francois Dugast
@ 2026-05-18 16:02 ` Matthew Auld
2026-05-19 15:40 ` Francois Dugast
0 siblings, 1 reply; 18+ messages in thread
From: Matthew Auld @ 2026-05-18 16:02 UTC (permalink / raw)
To: Francois Dugast, intel-xe; +Cc: dri-devel
On 18/05/2026 15:14, Francois Dugast wrote:
> Extend the scoreboard approach from the previous commit to used blocks,
> so drm_buddy_print() can report per-order allocation pressure in O(1).
>
> Unlike free blocks, an allocated block can leave the allocated state
> through mark_free() (normal free and gpu_buddy_block_trim()) or be
> consumed directly by gpu_block_free() during coalescing. Both sites are
> guarded by gpu_buddy_block_is_allocated() and paired with the increment
> in mark_allocated().
>
> v2:
> - Update after fix for use-after-free in split_block() call sites
> - Change goto label to out_free_used_scoreboard for clarity
> - Make drm_buddy_print() and gpu_buddy_print() symmetric for used and
> free
>
> Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> Assisted-by: GitHub Copilot:claude-sonnet-4.6
Could potentially also assert that used_scoreboard is empty at fini(),
as a quick sanity check that nothing got leaked/missed with the
accounting. Would also then be checked across the selftests.
Reviewed-by: Matthew Auld <matthew.auld@intel.com>
> ---
> drivers/gpu/buddy.c | 39 +++++++++++++++++++++++++++----------
> drivers/gpu/drm/drm_buddy.c | 18 +++++++++++------
> include/linux/gpu_buddy.h | 8 ++++++++
> 3 files changed, 49 insertions(+), 16 deletions(-)
>
> diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> index de18b63fef0a..f81d0d8fde15 100644
> --- a/drivers/gpu/buddy.c
> +++ b/drivers/gpu/buddy.c
> @@ -194,6 +194,7 @@ static void mark_allocated(struct gpu_buddy *mm,
> block->header |= GPU_BUDDY_ALLOCATED;
>
> mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> + mm->used_scoreboard[gpu_buddy_block_order(block)]++;
>
> rbtree_remove(mm, block);
> }
> @@ -203,6 +204,9 @@ static void mark_free(struct gpu_buddy *mm,
> {
> enum gpu_buddy_free_tree tree;
>
> + if (gpu_buddy_block_is_allocated(block))
> + mm->used_scoreboard[gpu_buddy_block_order(block)]--;
> +
> block->header &= ~GPU_BUDDY_HEADER_STATE;
> block->header |= GPU_BUDDY_FREE;
>
> @@ -281,6 +285,9 @@ static unsigned int __gpu_buddy_free(struct gpu_buddy *mm,
> if (force_merge && gpu_buddy_block_is_clear(buddy))
> mm->clear_avail -= gpu_buddy_block_size(mm, buddy);
>
> + if (gpu_buddy_block_is_allocated(block))
> + mm->used_scoreboard[gpu_buddy_block_order(block)]--;
> +
> gpu_block_free(mm, block);
> gpu_block_free(mm, buddy);
>
> @@ -398,11 +405,17 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
> if (!mm->free_scoreboard)
> return -ENOMEM;
>
> + mm->used_scoreboard = kcalloc(mm->max_order + 1,
> + sizeof(*mm->used_scoreboard),
> + GFP_KERNEL);
> + if (!mm->used_scoreboard)
> + goto out_free_free_scoreboard;
> +
> mm->free_trees = kmalloc_array(GPU_BUDDY_MAX_FREE_TREES,
> sizeof(*mm->free_trees),
> GFP_KERNEL);
> if (!mm->free_trees)
> - goto out_free_scoreboard;
> + goto out_free_used_scoreboard;
>
> for_each_free_tree(i) {
> mm->free_trees[i] = kmalloc_array(mm->max_order + 1,
> @@ -464,7 +477,9 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
> while (i--)
> kfree(mm->free_trees[i]);
> kfree(mm->free_trees);
> -out_free_scoreboard:
> +out_free_used_scoreboard:
> + kfree(mm->used_scoreboard);
> +out_free_free_scoreboard:
> kfree(mm->free_scoreboard);
> return -ENOMEM;
> }
> @@ -505,6 +520,7 @@ void gpu_buddy_fini(struct gpu_buddy *mm)
> kfree(mm->free_trees);
> kfree(mm->roots);
> kfree(mm->free_scoreboard);
> + kfree(mm->used_scoreboard);
> }
> EXPORT_SYMBOL(gpu_buddy_fini);
>
> @@ -1505,15 +1521,18 @@ void gpu_buddy_print(struct gpu_buddy *mm)
> mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
>
> for (order = mm->max_order; order >= 0; order--) {
> - u64 count = mm->free_scoreboard[order];
> - u64 free = count * (mm->chunk_size << order);
> -
> - if (free < SZ_1M)
> - pr_info("order-%2d free: %8llu KiB, blocks: %llu\n",
> - order, free >> 10, count);
> + u64 free_count = mm->free_scoreboard[order];
> + u64 used_count = mm->used_scoreboard[order];
> + u64 block_size = mm->chunk_size << order;
> + u64 free = free_count * block_size;
> + u64 used = used_count * block_size;
> +
> + if (block_size < SZ_1M)
> + pr_info("order-%2d free: %8llu KiB, used: %8llu KiB, free_blocks: %llu, used_blocks: %llu\n",
> + order, free >> 10, used >> 10, free_count, used_count);
> else
> - pr_info("order-%2d free: %8llu MiB, blocks: %llu\n",
> - order, free >> 20, count);
> + pr_info("order-%2d free: %8llu MiB, used: %8llu MiB, free_blocks: %llu, used_blocks: %llu\n",
> + order, free >> 20, used >> 20, free_count, used_count);
> }
> }
> EXPORT_SYMBOL(gpu_buddy_print);
> diff --git a/drivers/gpu/drm/drm_buddy.c b/drivers/gpu/drm/drm_buddy.c
> index eef995e08a37..1536e59c6fe7 100644
> --- a/drivers/gpu/drm/drm_buddy.c
> +++ b/drivers/gpu/drm/drm_buddy.c
> @@ -47,17 +47,23 @@ void drm_buddy_print(struct gpu_buddy *mm, struct drm_printer *p)
> mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
>
> for (order = mm->max_order; order >= 0; order--) {
> - u64 count = mm->free_scoreboard[order];
> - u64 free = count * (mm->chunk_size << order);
> + u64 free_count = mm->free_scoreboard[order];
> + u64 used_count = mm->used_scoreboard[order];
> + u64 block_size = mm->chunk_size << order;
> + u64 free = free_count * block_size;
> + u64 used = used_count * block_size;
>
> drm_printf(p, "order-%2d ", order);
>
> - if (free < SZ_1M)
> - drm_printf(p, "free: %8llu KiB", free >> 10);
> + if (block_size < SZ_1M)
> + drm_printf(p, "free: %8llu KiB, used: %8llu KiB",
> + free >> 10, used >> 10);
> else
> - drm_printf(p, "free: %8llu MiB", free >> 20);
> + drm_printf(p, "free: %8llu MiB, used: %8llu MiB",
> + free >> 20, used >> 20);
>
> - drm_printf(p, ", blocks: %llu\n", count);
> + drm_printf(p, ", free_blocks: %llu, used_blocks: %llu\n",
> + free_count, used_count);
> }
> }
> EXPORT_SYMBOL(drm_buddy_print);
> diff --git a/include/linux/gpu_buddy.h b/include/linux/gpu_buddy.h
> index a28f7d7637ca..e037714563d8 100644
> --- a/include/linux/gpu_buddy.h
> +++ b/include/linux/gpu_buddy.h
> @@ -180,6 +180,14 @@ struct gpu_buddy {
> * called on a free block.
> */
> u64 *free_scoreboard;
> + /*
> + * Per-order used block scoreboard: used_scoreboard[order] holds the
> + * number of blocks of that order currently in the allocated state.
> + * Incremented in mark_allocated(), decremented in mark_free() (guarded
> + * by gpu_buddy_block_is_allocated()) and in __gpu_buddy_free() when an
> + * allocated block is consumed directly during buddy coalescing.
> + */
> + u64 *used_scoreboard;
> /* public: */
> unsigned int n_roots;
> unsigned int max_order;
^ permalink raw reply [flat|nested] 18+ messages in thread* Re: [PATCH v3 5/5] gpu/buddy: Track per-order used blocks with a scoreboard
2026-05-18 16:02 ` Matthew Auld
@ 2026-05-19 15:40 ` Francois Dugast
0 siblings, 0 replies; 18+ messages in thread
From: Francois Dugast @ 2026-05-19 15:40 UTC (permalink / raw)
To: Matthew Auld; +Cc: intel-xe, dri-devel
On Mon, May 18, 2026 at 05:02:32PM +0100, Matthew Auld wrote:
> On 18/05/2026 15:14, Francois Dugast wrote:
> > Extend the scoreboard approach from the previous commit to used blocks,
> > so drm_buddy_print() can report per-order allocation pressure in O(1).
> >
> > Unlike free blocks, an allocated block can leave the allocated state
> > through mark_free() (normal free and gpu_buddy_block_trim()) or be
> > consumed directly by gpu_block_free() during coalescing. Both sites are
> > guarded by gpu_buddy_block_is_allocated() and paired with the increment
> > in mark_allocated().
> >
> > v2:
> > - Update after fix for use-after-free in split_block() call sites
> > - Change goto label to out_free_used_scoreboard for clarity
> > - Make drm_buddy_print() and gpu_buddy_print() symmetric for used and
> > free
> >
> > Signed-off-by: Francois Dugast <francois.dugast@intel.com>
> > Assisted-by: GitHub Copilot:claude-sonnet-4.6
>
> Could potentially also assert that used_scoreboard is empty at fini(), as a
> quick sanity check that nothing got leaked/missed with the accounting. Would
> also then be checked across the selftests.
Good idea, will do.
>
> Reviewed-by: Matthew Auld <matthew.auld@intel.com>
>
> > ---
> > drivers/gpu/buddy.c | 39 +++++++++++++++++++++++++++----------
> > drivers/gpu/drm/drm_buddy.c | 18 +++++++++++------
> > include/linux/gpu_buddy.h | 8 ++++++++
> > 3 files changed, 49 insertions(+), 16 deletions(-)
> >
> > diff --git a/drivers/gpu/buddy.c b/drivers/gpu/buddy.c
> > index de18b63fef0a..f81d0d8fde15 100644
> > --- a/drivers/gpu/buddy.c
> > +++ b/drivers/gpu/buddy.c
> > @@ -194,6 +194,7 @@ static void mark_allocated(struct gpu_buddy *mm,
> > block->header |= GPU_BUDDY_ALLOCATED;
> > mm->free_scoreboard[gpu_buddy_block_order(block)]--;
> > + mm->used_scoreboard[gpu_buddy_block_order(block)]++;
> > rbtree_remove(mm, block);
> > }
> > @@ -203,6 +204,9 @@ static void mark_free(struct gpu_buddy *mm,
> > {
> > enum gpu_buddy_free_tree tree;
> > + if (gpu_buddy_block_is_allocated(block))
> > + mm->used_scoreboard[gpu_buddy_block_order(block)]--;
> > +
> > block->header &= ~GPU_BUDDY_HEADER_STATE;
> > block->header |= GPU_BUDDY_FREE;
> > @@ -281,6 +285,9 @@ static unsigned int __gpu_buddy_free(struct gpu_buddy *mm,
> > if (force_merge && gpu_buddy_block_is_clear(buddy))
> > mm->clear_avail -= gpu_buddy_block_size(mm, buddy);
> > + if (gpu_buddy_block_is_allocated(block))
> > + mm->used_scoreboard[gpu_buddy_block_order(block)]--;
> > +
> > gpu_block_free(mm, block);
> > gpu_block_free(mm, buddy);
> > @@ -398,11 +405,17 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
> > if (!mm->free_scoreboard)
> > return -ENOMEM;
> > + mm->used_scoreboard = kcalloc(mm->max_order + 1,
> > + sizeof(*mm->used_scoreboard),
> > + GFP_KERNEL);
> > + if (!mm->used_scoreboard)
> > + goto out_free_free_scoreboard;
> > +
> > mm->free_trees = kmalloc_array(GPU_BUDDY_MAX_FREE_TREES,
> > sizeof(*mm->free_trees),
> > GFP_KERNEL);
> > if (!mm->free_trees)
> > - goto out_free_scoreboard;
> > + goto out_free_used_scoreboard;
> > for_each_free_tree(i) {
> > mm->free_trees[i] = kmalloc_array(mm->max_order + 1,
> > @@ -464,7 +477,9 @@ int gpu_buddy_init(struct gpu_buddy *mm, u64 size, u64 chunk_size)
> > while (i--)
> > kfree(mm->free_trees[i]);
> > kfree(mm->free_trees);
> > -out_free_scoreboard:
> > +out_free_used_scoreboard:
> > + kfree(mm->used_scoreboard);
> > +out_free_free_scoreboard:
> > kfree(mm->free_scoreboard);
> > return -ENOMEM;
> > }
> > @@ -505,6 +520,7 @@ void gpu_buddy_fini(struct gpu_buddy *mm)
> > kfree(mm->free_trees);
> > kfree(mm->roots);
> > kfree(mm->free_scoreboard);
> > + kfree(mm->used_scoreboard);
> > }
> > EXPORT_SYMBOL(gpu_buddy_fini);
> > @@ -1505,15 +1521,18 @@ void gpu_buddy_print(struct gpu_buddy *mm)
> > mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
> > for (order = mm->max_order; order >= 0; order--) {
> > - u64 count = mm->free_scoreboard[order];
> > - u64 free = count * (mm->chunk_size << order);
> > -
> > - if (free < SZ_1M)
> > - pr_info("order-%2d free: %8llu KiB, blocks: %llu\n",
> > - order, free >> 10, count);
> > + u64 free_count = mm->free_scoreboard[order];
> > + u64 used_count = mm->used_scoreboard[order];
> > + u64 block_size = mm->chunk_size << order;
> > + u64 free = free_count * block_size;
> > + u64 used = used_count * block_size;
> > +
> > + if (block_size < SZ_1M)
> > + pr_info("order-%2d free: %8llu KiB, used: %8llu KiB, free_blocks: %llu, used_blocks: %llu\n",
> > + order, free >> 10, used >> 10, free_count, used_count);
> > else
> > - pr_info("order-%2d free: %8llu MiB, blocks: %llu\n",
> > - order, free >> 20, count);
> > + pr_info("order-%2d free: %8llu MiB, used: %8llu MiB, free_blocks: %llu, used_blocks: %llu\n",
> > + order, free >> 20, used >> 20, free_count, used_count);
> > }
> > }
> > EXPORT_SYMBOL(gpu_buddy_print);
> > diff --git a/drivers/gpu/drm/drm_buddy.c b/drivers/gpu/drm/drm_buddy.c
> > index eef995e08a37..1536e59c6fe7 100644
> > --- a/drivers/gpu/drm/drm_buddy.c
> > +++ b/drivers/gpu/drm/drm_buddy.c
> > @@ -47,17 +47,23 @@ void drm_buddy_print(struct gpu_buddy *mm, struct drm_printer *p)
> > mm->chunk_size >> 10, mm->size >> 20, mm->avail >> 20, mm->clear_avail >> 20);
> > for (order = mm->max_order; order >= 0; order--) {
> > - u64 count = mm->free_scoreboard[order];
> > - u64 free = count * (mm->chunk_size << order);
> > + u64 free_count = mm->free_scoreboard[order];
> > + u64 used_count = mm->used_scoreboard[order];
> > + u64 block_size = mm->chunk_size << order;
> > + u64 free = free_count * block_size;
> > + u64 used = used_count * block_size;
> > drm_printf(p, "order-%2d ", order);
> > - if (free < SZ_1M)
> > - drm_printf(p, "free: %8llu KiB", free >> 10);
> > + if (block_size < SZ_1M)
> > + drm_printf(p, "free: %8llu KiB, used: %8llu KiB",
> > + free >> 10, used >> 10);
> > else
> > - drm_printf(p, "free: %8llu MiB", free >> 20);
> > + drm_printf(p, "free: %8llu MiB, used: %8llu MiB",
> > + free >> 20, used >> 20);
> > - drm_printf(p, ", blocks: %llu\n", count);
> > + drm_printf(p, ", free_blocks: %llu, used_blocks: %llu\n",
> > + free_count, used_count);
> > }
> > }
> > EXPORT_SYMBOL(drm_buddy_print);
> > diff --git a/include/linux/gpu_buddy.h b/include/linux/gpu_buddy.h
> > index a28f7d7637ca..e037714563d8 100644
> > --- a/include/linux/gpu_buddy.h
> > +++ b/include/linux/gpu_buddy.h
> > @@ -180,6 +180,14 @@ struct gpu_buddy {
> > * called on a free block.
> > */
> > u64 *free_scoreboard;
> > + /*
> > + * Per-order used block scoreboard: used_scoreboard[order] holds the
> > + * number of blocks of that order currently in the allocated state.
> > + * Incremented in mark_allocated(), decremented in mark_free() (guarded
> > + * by gpu_buddy_block_is_allocated()) and in __gpu_buddy_free() when an
> > + * allocated block is consumed directly during buddy coalescing.
> > + */
> > + u64 *used_scoreboard;
> > /* public: */
> > unsigned int n_roots;
> > unsigned int max_order;
>
^ permalink raw reply [flat|nested] 18+ messages in thread
* ✗ CI.checkpatch: warning for gpu/buddy: Per-order free and used block scoreboards (rev4)
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (4 preceding siblings ...)
2026-05-18 14:14 ` [PATCH v3 5/5] gpu/buddy: Track per-order used " Francois Dugast
@ 2026-05-18 14:40 ` Patchwork
2026-05-18 14:41 ` ✓ CI.KUnit: success " Patchwork
` (2 subsequent siblings)
8 siblings, 0 replies; 18+ messages in thread
From: Patchwork @ 2026-05-18 14:40 UTC (permalink / raw)
To: Francois Dugast; +Cc: intel-xe
== Series Details ==
Series: gpu/buddy: Per-order free and used block scoreboards (rev4)
URL : https://patchwork.freedesktop.org/series/165914/
State : warning
== Summary ==
+ KERNEL=/kernel
+ git clone https://gitlab.freedesktop.org/drm/maintainer-tools mt
Cloning into 'mt'...
warning: redirecting to https://gitlab.freedesktop.org/drm/maintainer-tools.git/
+ git -C mt rev-list -n1 origin/master
061140b9bc586ae7f40abc1249c97e1cc72d1b9d
+ cd /kernel
+ git config --global --add safe.directory /kernel
+ git log -n1
commit 6a9bcb3c868da49bb3b1bb325729dfe845e6b6d7
Author: Francois Dugast <francois.dugast@intel.com>
Date: Mon May 18 16:14:30 2026 +0200
gpu/buddy: Track per-order used blocks with a scoreboard
Extend the scoreboard approach from the previous commit to used blocks,
so drm_buddy_print() can report per-order allocation pressure in O(1).
Unlike free blocks, an allocated block can leave the allocated state
through mark_free() (normal free and gpu_buddy_block_trim()) or be
consumed directly by gpu_block_free() during coalescing. Both sites are
guarded by gpu_buddy_block_is_allocated() and paired with the increment
in mark_allocated().
v2:
- Update after fix for use-after-free in split_block() call sites
- Change goto label to out_free_used_scoreboard for clarity
- Make drm_buddy_print() and gpu_buddy_print() symmetric for used and
free
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
Assisted-by: GitHub Copilot:claude-sonnet-4.6
+ /mt/dim checkpatch dd6c69e211ead406faa36e4e2ec21f2ad8b75bbc drm-intel
646e0fe8e092 gpu/buddy: Fix use-after-free in split_block() call sites
-:24: WARNING:BAD_REPORTED_BY_LINK: Reported-by: should be immediately followed by Closes: with a URL to the report
#24:
Reported-by: Sashiko <sashiko-bot@kernel.org>
Signed-off-by: Francois Dugast <francois.dugast@intel.com>
-:26: WARNING:BAD_SIGN_OFF: Assisted-by expects 'AGENT_NAME:MODEL_VERSION [TOOL1] [TOOL2]' format
#26:
Assisted-by: GitHub Copilot:claude-sonnet-4.6
total: 0 errors, 2 warnings, 0 checks, 44 lines checked
ee737f53ae0b gpu/buddy: Remove redundant condition in alloc_from_freetree() error path
c374c837ca4e gpu/buddy: Introduce __gpu_buddy_undo_splits() helper
090bdd49ce30 gpu/buddy: Track per-order free blocks with a scoreboard
-:27: WARNING:BAD_SIGN_OFF: Assisted-by expects 'AGENT_NAME:MODEL_VERSION [TOOL1] [TOOL2]' format
#27:
Assisted-by: GitHub Copilot:claude-sonnet-4.6
total: 0 errors, 1 warnings, 0 checks, 139 lines checked
6a9bcb3c868d gpu/buddy: Track per-order used blocks with a scoreboard
-:22: WARNING:BAD_SIGN_OFF: Assisted-by expects 'AGENT_NAME:MODEL_VERSION [TOOL1] [TOOL2]' format
#22:
Assisted-by: GitHub Copilot:claude-sonnet-4.6
total: 0 errors, 1 warnings, 0 checks, 129 lines checked
^ permalink raw reply [flat|nested] 18+ messages in thread* ✓ CI.KUnit: success for gpu/buddy: Per-order free and used block scoreboards (rev4)
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (5 preceding siblings ...)
2026-05-18 14:40 ` ✗ CI.checkpatch: warning for gpu/buddy: Per-order free and used block scoreboards (rev4) Patchwork
@ 2026-05-18 14:41 ` Patchwork
2026-05-18 15:33 ` ✓ Xe.CI.BAT: " Patchwork
2026-05-18 19:50 ` ✗ Xe.CI.FULL: failure " Patchwork
8 siblings, 0 replies; 18+ messages in thread
From: Patchwork @ 2026-05-18 14:41 UTC (permalink / raw)
To: Francois Dugast; +Cc: intel-xe
== Series Details ==
Series: gpu/buddy: Per-order free and used block scoreboards (rev4)
URL : https://patchwork.freedesktop.org/series/165914/
State : success
== Summary ==
+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[14:40:02] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[14:40:07] 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=25
[14:40:48] Starting KUnit Kernel (1/1)...
[14:40:48] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[14:40:49] ================== guc_buf (11 subtests) ===================
[14:40:49] [PASSED] test_smallest
[14:40:49] [PASSED] test_largest
[14:40:49] [PASSED] test_granular
[14:40:49] [PASSED] test_unique
[14:40:49] [PASSED] test_overlap
[14:40:49] [PASSED] test_reusable
[14:40:49] [PASSED] test_too_big
[14:40:49] [PASSED] test_flush
[14:40:49] [PASSED] test_lookup
[14:40:49] [PASSED] test_data
[14:40:49] [PASSED] test_class
[14:40:49] ===================== [PASSED] guc_buf =====================
[14:40:49] =================== guc_dbm (7 subtests) ===================
[14:40:49] [PASSED] test_empty
[14:40:49] [PASSED] test_default
[14:40:49] ======================== test_size ========================
[14:40:49] [PASSED] 4
[14:40:49] [PASSED] 8
[14:40:49] [PASSED] 32
[14:40:49] [PASSED] 256
[14:40:49] ==================== [PASSED] test_size ====================
[14:40:49] ======================= test_reuse ========================
[14:40:49] [PASSED] 4
[14:40:49] [PASSED] 8
[14:40:49] [PASSED] 32
[14:40:49] [PASSED] 256
[14:40:49] =================== [PASSED] test_reuse ====================
[14:40:49] =================== test_range_overlap ====================
[14:40:49] [PASSED] 4
[14:40:49] [PASSED] 8
[14:40:49] [PASSED] 32
[14:40:49] [PASSED] 256
[14:40:49] =============== [PASSED] test_range_overlap ================
[14:40:49] =================== test_range_compact ====================
[14:40:49] [PASSED] 4
[14:40:49] [PASSED] 8
[14:40:49] [PASSED] 32
[14:40:49] [PASSED] 256
[14:40:49] =============== [PASSED] test_range_compact ================
[14:40:49] ==================== test_range_spare =====================
[14:40:49] [PASSED] 4
[14:40:49] [PASSED] 8
[14:40:49] [PASSED] 32
[14:40:49] [PASSED] 256
[14:40:49] ================ [PASSED] test_range_spare =================
[14:40:49] ===================== [PASSED] guc_dbm =====================
[14:40:49] =================== guc_idm (6 subtests) ===================
[14:40:49] [PASSED] bad_init
[14:40:49] [PASSED] no_init
[14:40:49] [PASSED] init_fini
[14:40:49] [PASSED] check_used
[14:40:49] [PASSED] check_quota
[14:40:49] [PASSED] check_all
[14:40:49] ===================== [PASSED] guc_idm =====================
[14:40:49] ================== no_relay (3 subtests) ===================
[14:40:49] [PASSED] xe_drops_guc2pf_if_not_ready
[14:40:49] [PASSED] xe_drops_guc2vf_if_not_ready
[14:40:49] [PASSED] xe_rejects_send_if_not_ready
[14:40:49] ==================== [PASSED] no_relay =====================
[14:40:49] ================== pf_relay (14 subtests) ==================
[14:40:49] [PASSED] pf_rejects_guc2pf_too_short
[14:40:49] [PASSED] pf_rejects_guc2pf_too_long
[14:40:49] [PASSED] pf_rejects_guc2pf_no_payload
[14:40:49] [PASSED] pf_fails_no_payload
[14:40:49] [PASSED] pf_fails_bad_origin
[14:40:49] [PASSED] pf_fails_bad_type
[14:40:49] [PASSED] pf_txn_reports_error
[14:40:49] [PASSED] pf_txn_sends_pf2guc
[14:40:49] [PASSED] pf_sends_pf2guc
[14:40:49] [SKIPPED] pf_loopback_nop
[14:40:49] [SKIPPED] pf_loopback_echo
[14:40:49] [SKIPPED] pf_loopback_fail
[14:40:49] [SKIPPED] pf_loopback_busy
[14:40:49] [SKIPPED] pf_loopback_retry
[14:40:49] ==================== [PASSED] pf_relay =====================
[14:40:49] ================== vf_relay (3 subtests) ===================
[14:40:49] [PASSED] vf_rejects_guc2vf_too_short
[14:40:49] [PASSED] vf_rejects_guc2vf_too_long
[14:40:49] [PASSED] vf_rejects_guc2vf_no_payload
[14:40:49] ==================== [PASSED] vf_relay =====================
[14:40:49] ================ pf_gt_config (9 subtests) =================
[14:40:49] [PASSED] fair_contexts_1vf
[14:40:49] [PASSED] fair_doorbells_1vf
[14:40:49] [PASSED] fair_ggtt_1vf
[14:40:49] ====================== fair_vram_1vf ======================
[14:40:49] [PASSED] 3.50 GiB
[14:40:49] [PASSED] 11.5 GiB
[14:40:49] [PASSED] 15.5 GiB
[14:40:49] [PASSED] 31.5 GiB
[14:40:49] [PASSED] 63.5 GiB
[14:40:49] [PASSED] 1.91 GiB
[14:40:49] ================== [PASSED] fair_vram_1vf ==================
[14:40:49] ================ fair_vram_1vf_admin_only =================
[14:40:49] [PASSED] 3.50 GiB
[14:40:49] [PASSED] 11.5 GiB
[14:40:49] [PASSED] 15.5 GiB
[14:40:49] [PASSED] 31.5 GiB
[14:40:49] [PASSED] 63.5 GiB
[14:40:49] [PASSED] 1.91 GiB
[14:40:49] ============ [PASSED] fair_vram_1vf_admin_only =============
[14:40:49] ====================== fair_contexts ======================
[14:40:49] [PASSED] 1 VF
[14:40:49] [PASSED] 2 VFs
[14:40:49] [PASSED] 3 VFs
[14:40:49] [PASSED] 4 VFs
[14:40:49] [PASSED] 5 VFs
[14:40:49] [PASSED] 6 VFs
[14:40:49] [PASSED] 7 VFs
[14:40:49] [PASSED] 8 VFs
[14:40:49] [PASSED] 9 VFs
[14:40:49] [PASSED] 10 VFs
[14:40:49] [PASSED] 11 VFs
[14:40:49] [PASSED] 12 VFs
[14:40:49] [PASSED] 13 VFs
[14:40:49] [PASSED] 14 VFs
[14:40:49] [PASSED] 15 VFs
[14:40:49] [PASSED] 16 VFs
[14:40:49] [PASSED] 17 VFs
[14:40:49] [PASSED] 18 VFs
[14:40:49] [PASSED] 19 VFs
[14:40:49] [PASSED] 20 VFs
[14:40:49] [PASSED] 21 VFs
[14:40:49] [PASSED] 22 VFs
[14:40:49] [PASSED] 23 VFs
[14:40:49] [PASSED] 24 VFs
[14:40:49] [PASSED] 25 VFs
[14:40:49] [PASSED] 26 VFs
[14:40:49] [PASSED] 27 VFs
[14:40:49] [PASSED] 28 VFs
[14:40:49] [PASSED] 29 VFs
[14:40:49] [PASSED] 30 VFs
[14:40:49] [PASSED] 31 VFs
[14:40:49] [PASSED] 32 VFs
[14:40:49] [PASSED] 33 VFs
[14:40:49] [PASSED] 34 VFs
[14:40:49] [PASSED] 35 VFs
[14:40:49] [PASSED] 36 VFs
[14:40:49] [PASSED] 37 VFs
[14:40:49] [PASSED] 38 VFs
[14:40:49] [PASSED] 39 VFs
[14:40:49] [PASSED] 40 VFs
[14:40:49] [PASSED] 41 VFs
[14:40:49] [PASSED] 42 VFs
[14:40:49] [PASSED] 43 VFs
[14:40:49] [PASSED] 44 VFs
[14:40:49] [PASSED] 45 VFs
[14:40:49] [PASSED] 46 VFs
[14:40:49] [PASSED] 47 VFs
[14:40:49] [PASSED] 48 VFs
[14:40:49] [PASSED] 49 VFs
[14:40:49] [PASSED] 50 VFs
[14:40:49] [PASSED] 51 VFs
[14:40:49] [PASSED] 52 VFs
[14:40:49] [PASSED] 53 VFs
[14:40:49] [PASSED] 54 VFs
[14:40:49] [PASSED] 55 VFs
[14:40:49] [PASSED] 56 VFs
[14:40:49] [PASSED] 57 VFs
[14:40:49] [PASSED] 58 VFs
[14:40:49] [PASSED] 59 VFs
[14:40:49] [PASSED] 60 VFs
[14:40:49] [PASSED] 61 VFs
[14:40:49] [PASSED] 62 VFs
[14:40:49] [PASSED] 63 VFs
[14:40:49] ================== [PASSED] fair_contexts ==================
[14:40:49] ===================== fair_doorbells ======================
[14:40:49] [PASSED] 1 VF
[14:40:49] [PASSED] 2 VFs
[14:40:49] [PASSED] 3 VFs
[14:40:49] [PASSED] 4 VFs
[14:40:49] [PASSED] 5 VFs
[14:40:49] [PASSED] 6 VFs
[14:40:49] [PASSED] 7 VFs
[14:40:49] [PASSED] 8 VFs
[14:40:49] [PASSED] 9 VFs
[14:40:49] [PASSED] 10 VFs
[14:40:49] [PASSED] 11 VFs
[14:40:49] [PASSED] 12 VFs
[14:40:49] [PASSED] 13 VFs
[14:40:49] [PASSED] 14 VFs
[14:40:49] [PASSED] 15 VFs
[14:40:49] [PASSED] 16 VFs
[14:40:49] [PASSED] 17 VFs
[14:40:49] [PASSED] 18 VFs
[14:40:49] [PASSED] 19 VFs
[14:40:49] [PASSED] 20 VFs
[14:40:49] [PASSED] 21 VFs
[14:40:49] [PASSED] 22 VFs
[14:40:49] [PASSED] 23 VFs
[14:40:49] [PASSED] 24 VFs
[14:40:49] [PASSED] 25 VFs
[14:40:49] [PASSED] 26 VFs
[14:40:49] [PASSED] 27 VFs
[14:40:49] [PASSED] 28 VFs
[14:40:49] [PASSED] 29 VFs
[14:40:49] [PASSED] 30 VFs
[14:40:49] [PASSED] 31 VFs
[14:40:49] [PASSED] 32 VFs
[14:40:49] [PASSED] 33 VFs
[14:40:49] [PASSED] 34 VFs
[14:40:49] [PASSED] 35 VFs
[14:40:49] [PASSED] 36 VFs
[14:40:49] [PASSED] 37 VFs
[14:40:49] [PASSED] 38 VFs
[14:40:49] [PASSED] 39 VFs
[14:40:49] [PASSED] 40 VFs
[14:40:49] [PASSED] 41 VFs
[14:40:49] [PASSED] 42 VFs
[14:40:49] [PASSED] 43 VFs
[14:40:49] [PASSED] 44 VFs
[14:40:49] [PASSED] 45 VFs
[14:40:49] [PASSED] 46 VFs
[14:40:49] [PASSED] 47 VFs
[14:40:49] [PASSED] 48 VFs
[14:40:49] [PASSED] 49 VFs
[14:40:49] [PASSED] 50 VFs
[14:40:49] [PASSED] 51 VFs
[14:40:49] [PASSED] 52 VFs
[14:40:49] [PASSED] 53 VFs
[14:40:49] [PASSED] 54 VFs
[14:40:49] [PASSED] 55 VFs
[14:40:49] [PASSED] 56 VFs
[14:40:49] [PASSED] 57 VFs
[14:40:49] [PASSED] 58 VFs
[14:40:49] [PASSED] 59 VFs
[14:40:49] [PASSED] 60 VFs
[14:40:49] [PASSED] 61 VFs
[14:40:49] [PASSED] 62 VFs
[14:40:49] [PASSED] 63 VFs
[14:40:49] ================= [PASSED] fair_doorbells ==================
[14:40:49] ======================== fair_ggtt ========================
[14:40:49] [PASSED] 1 VF
[14:40:49] [PASSED] 2 VFs
[14:40:49] [PASSED] 3 VFs
[14:40:49] [PASSED] 4 VFs
[14:40:49] [PASSED] 5 VFs
[14:40:49] [PASSED] 6 VFs
[14:40:49] [PASSED] 7 VFs
[14:40:49] [PASSED] 8 VFs
[14:40:49] [PASSED] 9 VFs
[14:40:49] [PASSED] 10 VFs
[14:40:49] [PASSED] 11 VFs
[14:40:49] [PASSED] 12 VFs
[14:40:49] [PASSED] 13 VFs
[14:40:49] [PASSED] 14 VFs
[14:40:49] [PASSED] 15 VFs
[14:40:49] [PASSED] 16 VFs
[14:40:49] [PASSED] 17 VFs
[14:40:49] [PASSED] 18 VFs
[14:40:49] [PASSED] 19 VFs
[14:40:49] [PASSED] 20 VFs
[14:40:49] [PASSED] 21 VFs
[14:40:49] [PASSED] 22 VFs
[14:40:49] [PASSED] 23 VFs
[14:40:49] [PASSED] 24 VFs
[14:40:49] [PASSED] 25 VFs
[14:40:49] [PASSED] 26 VFs
[14:40:49] [PASSED] 27 VFs
[14:40:49] [PASSED] 28 VFs
[14:40:49] [PASSED] 29 VFs
[14:40:49] [PASSED] 30 VFs
[14:40:49] [PASSED] 31 VFs
[14:40:49] [PASSED] 32 VFs
[14:40:49] [PASSED] 33 VFs
[14:40:49] [PASSED] 34 VFs
[14:40:49] [PASSED] 35 VFs
[14:40:49] [PASSED] 36 VFs
[14:40:49] [PASSED] 37 VFs
[14:40:49] [PASSED] 38 VFs
[14:40:49] [PASSED] 39 VFs
[14:40:49] [PASSED] 40 VFs
[14:40:49] [PASSED] 41 VFs
[14:40:49] [PASSED] 42 VFs
[14:40:49] [PASSED] 43 VFs
[14:40:49] [PASSED] 44 VFs
[14:40:49] [PASSED] 45 VFs
[14:40:49] [PASSED] 46 VFs
[14:40:49] [PASSED] 47 VFs
[14:40:49] [PASSED] 48 VFs
[14:40:49] [PASSED] 49 VFs
[14:40:49] [PASSED] 50 VFs
[14:40:49] [PASSED] 51 VFs
[14:40:49] [PASSED] 52 VFs
[14:40:49] [PASSED] 53 VFs
[14:40:49] [PASSED] 54 VFs
[14:40:49] [PASSED] 55 VFs
[14:40:49] [PASSED] 56 VFs
[14:40:49] [PASSED] 57 VFs
[14:40:49] [PASSED] 58 VFs
[14:40:49] [PASSED] 59 VFs
[14:40:49] [PASSED] 60 VFs
[14:40:49] [PASSED] 61 VFs
[14:40:49] [PASSED] 62 VFs
[14:40:49] [PASSED] 63 VFs
[14:40:49] ==================== [PASSED] fair_ggtt ====================
[14:40:49] ======================== fair_vram ========================
[14:40:49] [PASSED] 1 VF
[14:40:49] [PASSED] 2 VFs
[14:40:49] [PASSED] 3 VFs
[14:40:49] [PASSED] 4 VFs
[14:40:49] [PASSED] 5 VFs
[14:40:49] [PASSED] 6 VFs
[14:40:49] [PASSED] 7 VFs
[14:40:49] [PASSED] 8 VFs
[14:40:49] [PASSED] 9 VFs
[14:40:49] [PASSED] 10 VFs
[14:40:49] [PASSED] 11 VFs
[14:40:49] [PASSED] 12 VFs
[14:40:49] [PASSED] 13 VFs
[14:40:49] [PASSED] 14 VFs
[14:40:49] [PASSED] 15 VFs
[14:40:49] [PASSED] 16 VFs
[14:40:49] [PASSED] 17 VFs
[14:40:49] [PASSED] 18 VFs
[14:40:49] [PASSED] 19 VFs
[14:40:49] [PASSED] 20 VFs
[14:40:49] [PASSED] 21 VFs
[14:40:49] [PASSED] 22 VFs
[14:40:49] [PASSED] 23 VFs
[14:40:49] [PASSED] 24 VFs
[14:40:49] [PASSED] 25 VFs
[14:40:49] [PASSED] 26 VFs
[14:40:49] [PASSED] 27 VFs
[14:40:49] [PASSED] 28 VFs
[14:40:49] [PASSED] 29 VFs
[14:40:49] [PASSED] 30 VFs
[14:40:49] [PASSED] 31 VFs
[14:40:49] [PASSED] 32 VFs
[14:40:49] [PASSED] 33 VFs
[14:40:49] [PASSED] 34 VFs
[14:40:49] [PASSED] 35 VFs
[14:40:49] [PASSED] 36 VFs
[14:40:49] [PASSED] 37 VFs
[14:40:49] [PASSED] 38 VFs
[14:40:49] [PASSED] 39 VFs
[14:40:49] [PASSED] 40 VFs
[14:40:49] [PASSED] 41 VFs
[14:40:49] [PASSED] 42 VFs
[14:40:49] [PASSED] 43 VFs
[14:40:49] [PASSED] 44 VFs
[14:40:49] [PASSED] 45 VFs
[14:40:49] [PASSED] 46 VFs
[14:40:49] [PASSED] 47 VFs
[14:40:49] [PASSED] 48 VFs
[14:40:49] [PASSED] 49 VFs
[14:40:49] [PASSED] 50 VFs
[14:40:49] [PASSED] 51 VFs
[14:40:49] [PASSED] 52 VFs
[14:40:49] [PASSED] 53 VFs
[14:40:49] [PASSED] 54 VFs
[14:40:49] [PASSED] 55 VFs
[14:40:49] [PASSED] 56 VFs
[14:40:49] [PASSED] 57 VFs
[14:40:49] [PASSED] 58 VFs
[14:40:49] [PASSED] 59 VFs
[14:40:49] [PASSED] 60 VFs
[14:40:49] [PASSED] 61 VFs
[14:40:49] [PASSED] 62 VFs
[14:40:49] [PASSED] 63 VFs
[14:40:49] ==================== [PASSED] fair_vram ====================
[14:40:49] ================== [PASSED] pf_gt_config ===================
[14:40:49] ===================== lmtt (1 subtest) =====================
[14:40:49] ======================== test_ops =========================
[14:40:49] [PASSED] 2-level
[14:40:49] [PASSED] multi-level
[14:40:49] ==================== [PASSED] test_ops =====================
[14:40:49] ====================== [PASSED] lmtt =======================
[14:40:49] ================= pf_service (11 subtests) =================
[14:40:49] [PASSED] pf_negotiate_any
[14:40:49] [PASSED] pf_negotiate_base_match
[14:40:49] [PASSED] pf_negotiate_base_newer
[14:40:49] [PASSED] pf_negotiate_base_next
[14:40:49] [SKIPPED] pf_negotiate_base_older
[14:40:49] [PASSED] pf_negotiate_base_prev
[14:40:49] [PASSED] pf_negotiate_latest_match
[14:40:49] [PASSED] pf_negotiate_latest_newer
[14:40:49] [PASSED] pf_negotiate_latest_next
[14:40:49] [SKIPPED] pf_negotiate_latest_older
[14:40:49] [SKIPPED] pf_negotiate_latest_prev
[14:40:49] =================== [PASSED] pf_service ====================
[14:40:49] ================= xe_guc_g2g (2 subtests) ==================
[14:40:49] ============== xe_live_guc_g2g_kunit_default ==============
[14:40:49] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[14:40:49] ============== xe_live_guc_g2g_kunit_allmem ===============
[14:40:49] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[14:40:49] =================== [SKIPPED] xe_guc_g2g ===================
[14:40:49] =================== xe_mocs (2 subtests) ===================
[14:40:49] ================ xe_live_mocs_kernel_kunit ================
[14:40:49] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[14:40:49] ================ xe_live_mocs_reset_kunit =================
[14:40:49] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[14:40:49] ==================== [SKIPPED] xe_mocs =====================
[14:40:49] ================= xe_migrate (2 subtests) ==================
[14:40:49] ================= xe_migrate_sanity_kunit =================
[14:40:49] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[14:40:49] ================== xe_validate_ccs_kunit ==================
[14:40:49] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[14:40:49] =================== [SKIPPED] xe_migrate ===================
[14:40:49] ================== xe_dma_buf (1 subtest) ==================
[14:40:49] ==================== xe_dma_buf_kunit =====================
[14:40:49] ================ [SKIPPED] xe_dma_buf_kunit ================
[14:40:49] =================== [SKIPPED] xe_dma_buf ===================
[14:40:49] ================= xe_bo_shrink (1 subtest) =================
[14:40:49] =================== xe_bo_shrink_kunit ====================
[14:40:49] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[14:40:49] ================== [SKIPPED] xe_bo_shrink ==================
[14:40:49] ==================== xe_bo (2 subtests) ====================
[14:40:49] ================== xe_ccs_migrate_kunit ===================
[14:40:49] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[14:40:49] ==================== xe_bo_evict_kunit ====================
[14:40:49] =============== [SKIPPED] xe_bo_evict_kunit ================
[14:40:49] ===================== [SKIPPED] xe_bo ======================
[14:40:49] ==================== args (13 subtests) ====================
[14:40:49] [PASSED] count_args_test
[14:40:49] [PASSED] call_args_example
[14:40:49] [PASSED] call_args_test
[14:40:49] [PASSED] drop_first_arg_example
[14:40:49] [PASSED] drop_first_arg_test
[14:40:49] [PASSED] first_arg_example
[14:40:49] [PASSED] first_arg_test
[14:40:49] [PASSED] last_arg_example
[14:40:49] [PASSED] last_arg_test
[14:40:49] [PASSED] pick_arg_example
[14:40:49] [PASSED] if_args_example
[14:40:49] [PASSED] if_args_test
[14:40:49] [PASSED] sep_comma_example
[14:40:49] ====================== [PASSED] args =======================
[14:40:49] =================== xe_pci (3 subtests) ====================
[14:40:49] ==================== check_graphics_ip ====================
[14:40:49] [PASSED] 12.00 Xe_LP
[14:40:49] [PASSED] 12.10 Xe_LP+
[14:40:49] [PASSED] 12.55 Xe_HPG
[14:40:49] [PASSED] 12.60 Xe_HPC
[14:40:49] [PASSED] 12.70 Xe_LPG
[14:40:49] [PASSED] 12.71 Xe_LPG
[14:40:49] [PASSED] 12.74 Xe_LPG+
[14:40:49] [PASSED] 20.01 Xe2_HPG
[14:40:49] [PASSED] 20.02 Xe2_HPG
[14:40:49] [PASSED] 20.04 Xe2_LPG
[14:40:49] [PASSED] 30.00 Xe3_LPG
[14:40:49] [PASSED] 30.01 Xe3_LPG
[14:40:49] [PASSED] 30.03 Xe3_LPG
[14:40:49] [PASSED] 30.04 Xe3_LPG
[14:40:49] [PASSED] 30.05 Xe3_LPG
[14:40:49] [PASSED] 35.10 Xe3p_LPG
[14:40:49] [PASSED] 35.11 Xe3p_XPC
[14:40:49] ================ [PASSED] check_graphics_ip ================
[14:40:49] ===================== check_media_ip ======================
[14:40:49] [PASSED] 12.00 Xe_M
[14:40:49] [PASSED] 12.55 Xe_HPM
[14:40:49] [PASSED] 13.00 Xe_LPM+
[14:40:49] [PASSED] 13.01 Xe2_HPM
[14:40:49] [PASSED] 20.00 Xe2_LPM
[14:40:49] [PASSED] 30.00 Xe3_LPM
[14:40:49] [PASSED] 30.02 Xe3_LPM
[14:40:49] [PASSED] 35.00 Xe3p_LPM
[14:40:49] [PASSED] 35.03 Xe3p_HPM
[14:40:49] ================= [PASSED] check_media_ip ==================
[14:40:49] =================== check_platform_desc ===================
[14:40:49] [PASSED] 0x9A60 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A68 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A70 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A40 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A49 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A59 (TIGERLAKE)
[14:40:49] [PASSED] 0x9A78 (TIGERLAKE)
[14:40:49] [PASSED] 0x9AC0 (TIGERLAKE)
[14:40:49] [PASSED] 0x9AC9 (TIGERLAKE)
[14:40:49] [PASSED] 0x9AD9 (TIGERLAKE)
[14:40:49] [PASSED] 0x9AF8 (TIGERLAKE)
[14:40:49] [PASSED] 0x4C80 (ROCKETLAKE)
[14:40:49] [PASSED] 0x4C8A (ROCKETLAKE)
[14:40:49] [PASSED] 0x4C8B (ROCKETLAKE)
[14:40:49] [PASSED] 0x4C8C (ROCKETLAKE)
[14:40:49] [PASSED] 0x4C90 (ROCKETLAKE)
[14:40:49] [PASSED] 0x4C9A (ROCKETLAKE)
[14:40:49] [PASSED] 0x4680 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4682 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4688 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x468A (ALDERLAKE_S)
[14:40:49] [PASSED] 0x468B (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4690 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4692 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4693 (ALDERLAKE_S)
[14:40:49] [PASSED] 0x46A0 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46A1 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46A2 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46A3 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46A6 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46A8 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46AA (ALDERLAKE_P)
[14:40:49] [PASSED] 0x462A (ALDERLAKE_P)
[14:40:49] [PASSED] 0x4626 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x4628 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46B0 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46B1 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46B2 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46B3 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46C0 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46C1 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46C2 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46C3 (ALDERLAKE_P)
[14:40:49] [PASSED] 0x46D0 (ALDERLAKE_N)
[14:40:49] [PASSED] 0x46D1 (ALDERLAKE_N)
[14:40:49] [PASSED] 0x46D2 (ALDERLAKE_N)
[14:40:49] [PASSED] 0x46D3 (ALDERLAKE_N)
[14:40:49] [PASSED] 0x46D4 (ALDERLAKE_N)
[14:40:49] [PASSED] 0xA721 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7A1 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7A9 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7AC (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7AD (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA720 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7A0 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7A8 (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7AA (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA7AB (ALDERLAKE_P)
[14:40:49] [PASSED] 0xA780 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA781 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA782 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA783 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA788 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA789 (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA78A (ALDERLAKE_S)
[14:40:49] [PASSED] 0xA78B (ALDERLAKE_S)
[14:40:49] [PASSED] 0x4905 (DG1)
[14:40:49] [PASSED] 0x4906 (DG1)
[14:40:49] [PASSED] 0x4907 (DG1)
[14:40:49] [PASSED] 0x4908 (DG1)
[14:40:49] [PASSED] 0x4909 (DG1)
[14:40:49] [PASSED] 0x56C0 (DG2)
[14:40:49] [PASSED] 0x56C2 (DG2)
[14:40:49] [PASSED] 0x56C1 (DG2)
[14:40:49] [PASSED] 0x7D51 (METEORLAKE)
[14:40:49] [PASSED] 0x7DD1 (METEORLAKE)
[14:40:49] [PASSED] 0x7D41 (METEORLAKE)
[14:40:49] [PASSED] 0x7D67 (METEORLAKE)
[14:40:49] [PASSED] 0xB640 (METEORLAKE)
[14:40:49] [PASSED] 0x56A0 (DG2)
[14:40:49] [PASSED] 0x56A1 (DG2)
[14:40:49] [PASSED] 0x56A2 (DG2)
[14:40:49] [PASSED] 0x56BE (DG2)
[14:40:49] [PASSED] 0x56BF (DG2)
[14:40:49] [PASSED] 0x5690 (DG2)
[14:40:49] [PASSED] 0x5691 (DG2)
[14:40:49] [PASSED] 0x5692 (DG2)
[14:40:49] [PASSED] 0x56A5 (DG2)
[14:40:49] [PASSED] 0x56A6 (DG2)
[14:40:49] [PASSED] 0x56B0 (DG2)
[14:40:49] [PASSED] 0x56B1 (DG2)
[14:40:49] [PASSED] 0x56BA (DG2)
[14:40:49] [PASSED] 0x56BB (DG2)
[14:40:49] [PASSED] 0x56BC (DG2)
[14:40:49] [PASSED] 0x56BD (DG2)
[14:40:49] [PASSED] 0x5693 (DG2)
[14:40:49] [PASSED] 0x5694 (DG2)
[14:40:49] [PASSED] 0x5695 (DG2)
[14:40:49] [PASSED] 0x56A3 (DG2)
[14:40:49] [PASSED] 0x56A4 (DG2)
[14:40:49] [PASSED] 0x56B2 (DG2)
[14:40:49] [PASSED] 0x56B3 (DG2)
[14:40:49] [PASSED] 0x5696 (DG2)
[14:40:49] [PASSED] 0x5697 (DG2)
[14:40:49] [PASSED] 0xB69 (PVC)
[14:40:49] [PASSED] 0xB6E (PVC)
[14:40:49] [PASSED] 0xBD4 (PVC)
[14:40:49] [PASSED] 0xBD5 (PVC)
[14:40:49] [PASSED] 0xBD6 (PVC)
[14:40:49] [PASSED] 0xBD7 (PVC)
[14:40:49] [PASSED] 0xBD8 (PVC)
[14:40:49] [PASSED] 0xBD9 (PVC)
[14:40:49] [PASSED] 0xBDA (PVC)
[14:40:49] [PASSED] 0xBDB (PVC)
[14:40:49] [PASSED] 0xBE0 (PVC)
[14:40:49] [PASSED] 0xBE1 (PVC)
[14:40:49] [PASSED] 0xBE5 (PVC)
[14:40:49] [PASSED] 0x7D40 (METEORLAKE)
[14:40:49] [PASSED] 0x7D45 (METEORLAKE)
[14:40:49] [PASSED] 0x7D55 (METEORLAKE)
[14:40:49] [PASSED] 0x7D60 (METEORLAKE)
[14:40:49] [PASSED] 0x7DD5 (METEORLAKE)
[14:40:49] [PASSED] 0x6420 (LUNARLAKE)
[14:40:49] [PASSED] 0x64A0 (LUNARLAKE)
[14:40:49] [PASSED] 0x64B0 (LUNARLAKE)
[14:40:49] [PASSED] 0xE202 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE209 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE20B (BATTLEMAGE)
[14:40:49] [PASSED] 0xE20C (BATTLEMAGE)
[14:40:49] [PASSED] 0xE20D (BATTLEMAGE)
[14:40:49] [PASSED] 0xE210 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE211 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE212 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE216 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE220 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE221 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE222 (BATTLEMAGE)
[14:40:49] [PASSED] 0xE223 (BATTLEMAGE)
[14:40:49] [PASSED] 0xB080 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB081 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB082 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB083 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB084 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB085 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB086 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB087 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB08F (PANTHERLAKE)
[14:40:49] [PASSED] 0xB090 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB0A0 (PANTHERLAKE)
[14:40:49] [PASSED] 0xB0B0 (PANTHERLAKE)
[14:40:49] [PASSED] 0xFD80 (PANTHERLAKE)
[14:40:49] [PASSED] 0xFD81 (PANTHERLAKE)
[14:40:49] [PASSED] 0xD740 (NOVALAKE_S)
[14:40:49] [PASSED] 0xD741 (NOVALAKE_S)
[14:40:49] [PASSED] 0xD742 (NOVALAKE_S)
[14:40:49] [PASSED] 0xD743 (NOVALAKE_S)
[14:40:49] [PASSED] 0xD744 (NOVALAKE_S)
[14:40:49] [PASSED] 0xD745 (NOVALAKE_S)
[14:40:49] [PASSED] 0x674C (CRESCENTISLAND)
[14:40:49] [PASSED] 0x674D (CRESCENTISLAND)
[14:40:49] [PASSED] 0x674E (CRESCENTISLAND)
[14:40:49] [PASSED] 0x674F (CRESCENTISLAND)
[14:40:49] [PASSED] 0x6750 (CRESCENTISLAND)
[14:40:49] [PASSED] 0xD750 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD751 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD752 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD753 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD754 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD755 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD756 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD757 (NOVALAKE_P)
[14:40:49] [PASSED] 0xD75F (NOVALAKE_P)
[14:40:49] =============== [PASSED] check_platform_desc ===============
[14:40:49] ===================== [PASSED] xe_pci ======================
[14:40:49] =================== xe_rtp (2 subtests) ====================
[14:40:49] =============== xe_rtp_process_to_sr_tests ================
[14:40:49] [PASSED] coalesce-same-reg
[14:40:49] [PASSED] no-match-no-add
[14:40:49] [PASSED] match-or
[14:40:49] [PASSED] match-or-xfail
[14:40:49] [PASSED] no-match-no-add-multiple-rules
[14:40:49] [PASSED] two-regs-two-entries
[14:40:49] [PASSED] clr-one-set-other
[14:40:49] [PASSED] set-field
[14:40:49] [PASSED] conflict-duplicate
[14:40:49] [PASSED] conflict-not-disjoint
[14:40:49] [PASSED] conflict-reg-type
[14:40:49] [PASSED] bad-mcr-reg-forced-to-regular
[14:40:49] [PASSED] bad-regular-reg-forced-to-mcr
[14:40:49] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[14:40:49] ================== xe_rtp_process_tests ===================
[14:40:49] [PASSED] active1
[14:40:49] [PASSED] active2
[14:40:49] [PASSED] active-inactive
[14:40:49] [PASSED] inactive-active
[14:40:49] [PASSED] inactive-1st_or_active-inactive
[14:40:49] [PASSED] inactive-2nd_or_active-inactive
[14:40:49] [PASSED] inactive-last_or_active-inactive
[14:40:49] [PASSED] inactive-no_or_active-inactive
[14:40:49] ============== [PASSED] xe_rtp_process_tests ===============
[14:40:49] ===================== [PASSED] xe_rtp ======================
[14:40:49] ==================== xe_wa (1 subtest) =====================
[14:40:49] ======================== xe_wa_gt =========================
[14:40:49] [PASSED] TIGERLAKE B0
[14:40:49] [PASSED] DG1 A0
[14:40:49] [PASSED] DG1 B0
[14:40:49] [PASSED] ALDERLAKE_S A0
[14:40:49] [PASSED] ALDERLAKE_S B0
[14:40:49] [PASSED] ALDERLAKE_S C0
[14:40:49] [PASSED] ALDERLAKE_S D0
[14:40:49] [PASSED] ALDERLAKE_P A0
[14:40:49] [PASSED] ALDERLAKE_P B0
[14:40:49] [PASSED] ALDERLAKE_P C0
[14:40:49] [PASSED] ALDERLAKE_S RPLS D0
[14:40:49] [PASSED] ALDERLAKE_P RPLU E0
[14:40:49] [PASSED] DG2 G10 C0
[14:40:49] [PASSED] DG2 G11 B1
[14:40:49] [PASSED] DG2 G12 A1
[14:40:49] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[14:40:49] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[14:40:49] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[14:40:49] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[14:40:49] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[14:40:49] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[14:40:49] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[14:40:49] ==================== [PASSED] xe_wa_gt =====================
[14:40:49] ====================== [PASSED] xe_wa ======================
[14:40:49] ============================================================
[14:40:49] Testing complete. Ran 603 tests: passed: 585, skipped: 18
[14:40:49] Elapsed time: 46.748s total, 4.602s configuring, 41.479s building, 0.640s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[14:40:49] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[14:40:51] 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=25
[14:41:21] Starting KUnit Kernel (1/1)...
[14:41:21] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[14:41:21] ============ drm_test_pick_cmdline (2 subtests) ============
[14:41:21] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[14:41:21] =============== drm_test_pick_cmdline_named ===============
[14:41:21] [PASSED] NTSC
[14:41:21] [PASSED] NTSC-J
[14:41:21] [PASSED] PAL
[14:41:21] [PASSED] PAL-M
[14:41:21] =========== [PASSED] drm_test_pick_cmdline_named ===========
[14:41:21] ============== [PASSED] drm_test_pick_cmdline ==============
[14:41:21] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[14:41:21] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[14:41:21] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[14:41:21] =========== drm_validate_clone_mode (2 subtests) ===========
[14:41:21] ============== drm_test_check_in_clone_mode ===============
[14:41:21] [PASSED] in_clone_mode
[14:41:21] [PASSED] not_in_clone_mode
[14:41:21] ========== [PASSED] drm_test_check_in_clone_mode ===========
[14:41:21] =============== drm_test_check_valid_clones ===============
[14:41:21] [PASSED] not_in_clone_mode
[14:41:21] [PASSED] valid_clone
[14:41:21] [PASSED] invalid_clone
[14:41:21] =========== [PASSED] drm_test_check_valid_clones ===========
[14:41:21] ============= [PASSED] drm_validate_clone_mode =============
[14:41:21] ============= drm_validate_modeset (1 subtest) =============
[14:41:21] [PASSED] drm_test_check_connector_changed_modeset
[14:41:21] ============== [PASSED] drm_validate_modeset ===============
[14:41:21] ====== drm_test_bridge_get_current_state (2 subtests) ======
[14:41:21] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[14:41:21] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[14:41:21] ======== [PASSED] drm_test_bridge_get_current_state ========
[14:41:21] ====== drm_test_bridge_helper_reset_crtc (3 subtests) ======
[14:41:21] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[14:41:21] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[14:41:21] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[14:41:21] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[14:41:21] ============== drm_bridge_alloc (2 subtests) ===============
[14:41:21] [PASSED] drm_test_drm_bridge_alloc_basic
[14:41:21] [PASSED] drm_test_drm_bridge_alloc_get_put
[14:41:21] ================ [PASSED] drm_bridge_alloc =================
[14:41:21] ============= drm_cmdline_parser (40 subtests) =============
[14:41:21] [PASSED] drm_test_cmdline_force_d_only
[14:41:21] [PASSED] drm_test_cmdline_force_D_only_dvi
[14:41:21] [PASSED] drm_test_cmdline_force_D_only_hdmi
[14:41:21] [PASSED] drm_test_cmdline_force_D_only_not_digital
[14:41:21] [PASSED] drm_test_cmdline_force_e_only
[14:41:21] [PASSED] drm_test_cmdline_res
[14:41:21] [PASSED] drm_test_cmdline_res_vesa
[14:41:21] [PASSED] drm_test_cmdline_res_vesa_rblank
[14:41:21] [PASSED] drm_test_cmdline_res_rblank
[14:41:21] [PASSED] drm_test_cmdline_res_bpp
[14:41:21] [PASSED] drm_test_cmdline_res_refresh
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[14:41:21] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[14:41:21] [PASSED] drm_test_cmdline_res_margins_force_on
[14:41:21] [PASSED] drm_test_cmdline_res_vesa_margins
[14:41:21] [PASSED] drm_test_cmdline_name
[14:41:21] [PASSED] drm_test_cmdline_name_bpp
[14:41:21] [PASSED] drm_test_cmdline_name_option
[14:41:21] [PASSED] drm_test_cmdline_name_bpp_option
[14:41:21] [PASSED] drm_test_cmdline_rotate_0
[14:41:21] [PASSED] drm_test_cmdline_rotate_90
[14:41:21] [PASSED] drm_test_cmdline_rotate_180
[14:41:21] [PASSED] drm_test_cmdline_rotate_270
[14:41:21] [PASSED] drm_test_cmdline_hmirror
[14:41:21] [PASSED] drm_test_cmdline_vmirror
[14:41:21] [PASSED] drm_test_cmdline_margin_options
[14:41:21] [PASSED] drm_test_cmdline_multiple_options
[14:41:21] [PASSED] drm_test_cmdline_bpp_extra_and_option
[14:41:21] [PASSED] drm_test_cmdline_extra_and_option
[14:41:21] [PASSED] drm_test_cmdline_freestanding_options
[14:41:21] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[14:41:21] [PASSED] drm_test_cmdline_panel_orientation
[14:41:21] ================ drm_test_cmdline_invalid =================
[14:41:21] [PASSED] margin_only
[14:41:21] [PASSED] interlace_only
[14:41:21] [PASSED] res_missing_x
[14:41:21] [PASSED] res_missing_y
[14:41:21] [PASSED] res_bad_y
[14:41:21] [PASSED] res_missing_y_bpp
[14:41:21] [PASSED] res_bad_bpp
[14:41:21] [PASSED] res_bad_refresh
[14:41:21] [PASSED] res_bpp_refresh_force_on_off
[14:41:21] [PASSED] res_invalid_mode
[14:41:21] [PASSED] res_bpp_wrong_place_mode
[14:41:21] [PASSED] name_bpp_refresh
[14:41:21] [PASSED] name_refresh
[14:41:21] [PASSED] name_refresh_wrong_mode
[14:41:21] [PASSED] name_refresh_invalid_mode
[14:41:21] [PASSED] rotate_multiple
[14:41:21] [PASSED] rotate_invalid_val
[14:41:21] [PASSED] rotate_truncated
[14:41:21] [PASSED] invalid_option
[14:41:21] [PASSED] invalid_tv_option
[14:41:21] [PASSED] truncated_tv_option
[14:41:21] ============ [PASSED] drm_test_cmdline_invalid =============
[14:41:21] =============== drm_test_cmdline_tv_options ===============
[14:41:21] [PASSED] NTSC
[14:41:21] [PASSED] NTSC_443
[14:41:21] [PASSED] NTSC_J
[14:41:21] [PASSED] PAL
[14:41:21] [PASSED] PAL_M
[14:41:21] [PASSED] PAL_N
[14:41:21] [PASSED] SECAM
[14:41:21] [PASSED] MONO_525
[14:41:21] [PASSED] MONO_625
[14:41:21] =========== [PASSED] drm_test_cmdline_tv_options ===========
[14:41:21] =============== [PASSED] drm_cmdline_parser ================
[14:41:21] ========== drmm_connector_hdmi_init (20 subtests) ==========
[14:41:21] [PASSED] drm_test_connector_hdmi_init_valid
[14:41:21] [PASSED] drm_test_connector_hdmi_init_bpc_8
[14:41:21] [PASSED] drm_test_connector_hdmi_init_bpc_10
[14:41:21] [PASSED] drm_test_connector_hdmi_init_bpc_12
[14:41:21] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[14:41:21] [PASSED] drm_test_connector_hdmi_init_bpc_null
[14:41:21] [PASSED] drm_test_connector_hdmi_init_formats_empty
[14:41:21] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[14:41:21] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[14:41:21] [PASSED] supported_formats=0x9 yuv420_allowed=1
[14:41:21] [PASSED] supported_formats=0x9 yuv420_allowed=0
[14:41:21] [PASSED] supported_formats=0x5 yuv420_allowed=1
[14:41:21] [PASSED] supported_formats=0x5 yuv420_allowed=0
[14:41:21] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[14:41:21] [PASSED] drm_test_connector_hdmi_init_null_ddc
[14:41:21] [PASSED] drm_test_connector_hdmi_init_null_product
[14:41:21] [PASSED] drm_test_connector_hdmi_init_null_vendor
[14:41:21] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[14:41:21] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[14:41:21] [PASSED] drm_test_connector_hdmi_init_product_valid
[14:41:21] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[14:41:21] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[14:41:21] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[14:41:21] ========= drm_test_connector_hdmi_init_type_valid =========
[14:41:21] [PASSED] HDMI-A
[14:41:21] [PASSED] HDMI-B
[14:41:21] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[14:41:21] ======== drm_test_connector_hdmi_init_type_invalid ========
[14:41:21] [PASSED] Unknown
[14:41:21] [PASSED] VGA
[14:41:21] [PASSED] DVI-I
[14:41:21] [PASSED] DVI-D
[14:41:21] [PASSED] DVI-A
[14:41:21] [PASSED] Composite
[14:41:21] [PASSED] SVIDEO
[14:41:21] [PASSED] LVDS
[14:41:21] [PASSED] Component
[14:41:21] [PASSED] DIN
[14:41:21] [PASSED] DP
[14:41:21] [PASSED] TV
[14:41:21] [PASSED] eDP
[14:41:21] [PASSED] Virtual
[14:41:21] [PASSED] DSI
[14:41:21] [PASSED] DPI
[14:41:21] [PASSED] Writeback
[14:41:21] [PASSED] SPI
[14:41:21] [PASSED] USB
[14:41:21] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[14:41:21] ============ [PASSED] drmm_connector_hdmi_init =============
[14:41:21] ============= drmm_connector_init (3 subtests) =============
[14:41:21] [PASSED] drm_test_drmm_connector_init
[14:41:21] [PASSED] drm_test_drmm_connector_init_null_ddc
[14:41:21] ========= drm_test_drmm_connector_init_type_valid =========
[14:41:21] [PASSED] Unknown
[14:41:21] [PASSED] VGA
[14:41:21] [PASSED] DVI-I
[14:41:21] [PASSED] DVI-D
[14:41:21] [PASSED] DVI-A
[14:41:21] [PASSED] Composite
[14:41:21] [PASSED] SVIDEO
[14:41:21] [PASSED] LVDS
[14:41:21] [PASSED] Component
[14:41:21] [PASSED] DIN
[14:41:21] [PASSED] DP
[14:41:21] [PASSED] HDMI-A
[14:41:21] [PASSED] HDMI-B
[14:41:21] [PASSED] TV
[14:41:21] [PASSED] eDP
[14:41:21] [PASSED] Virtual
[14:41:21] [PASSED] DSI
[14:41:21] [PASSED] DPI
[14:41:21] [PASSED] Writeback
[14:41:21] [PASSED] SPI
[14:41:21] [PASSED] USB
[14:41:21] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[14:41:21] =============== [PASSED] drmm_connector_init ===============
[14:41:21] ========= drm_connector_dynamic_init (6 subtests) ==========
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_init
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_init_properties
[14:41:21] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[14:41:21] [PASSED] Unknown
[14:41:21] [PASSED] VGA
[14:41:21] [PASSED] DVI-I
[14:41:21] [PASSED] DVI-D
[14:41:21] [PASSED] DVI-A
[14:41:21] [PASSED] Composite
[14:41:21] [PASSED] SVIDEO
[14:41:21] [PASSED] LVDS
[14:41:21] [PASSED] Component
[14:41:21] [PASSED] DIN
[14:41:21] [PASSED] DP
[14:41:21] [PASSED] HDMI-A
[14:41:21] [PASSED] HDMI-B
[14:41:21] [PASSED] TV
[14:41:21] [PASSED] eDP
[14:41:21] [PASSED] Virtual
[14:41:21] [PASSED] DSI
[14:41:21] [PASSED] DPI
[14:41:21] [PASSED] Writeback
[14:41:21] [PASSED] SPI
[14:41:21] [PASSED] USB
[14:41:21] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[14:41:21] ======== drm_test_drm_connector_dynamic_init_name =========
[14:41:21] [PASSED] Unknown
[14:41:21] [PASSED] VGA
[14:41:21] [PASSED] DVI-I
[14:41:21] [PASSED] DVI-D
[14:41:21] [PASSED] DVI-A
[14:41:21] [PASSED] Composite
[14:41:21] [PASSED] SVIDEO
[14:41:21] [PASSED] LVDS
[14:41:21] [PASSED] Component
[14:41:21] [PASSED] DIN
[14:41:21] [PASSED] DP
[14:41:21] [PASSED] HDMI-A
[14:41:21] [PASSED] HDMI-B
[14:41:21] [PASSED] TV
[14:41:21] [PASSED] eDP
[14:41:21] [PASSED] Virtual
[14:41:21] [PASSED] DSI
[14:41:21] [PASSED] DPI
[14:41:21] [PASSED] Writeback
[14:41:21] [PASSED] SPI
[14:41:21] [PASSED] USB
[14:41:21] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[14:41:21] =========== [PASSED] drm_connector_dynamic_init ============
[14:41:21] ==== drm_connector_dynamic_register_early (4 subtests) =====
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[14:41:21] ====== [PASSED] drm_connector_dynamic_register_early =======
[14:41:21] ======= drm_connector_dynamic_register (7 subtests) ========
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[14:41:21] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[14:41:21] ========= [PASSED] drm_connector_dynamic_register ==========
[14:41:21] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[14:41:21] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[14:41:21] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[14:41:21] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[14:41:21] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[14:41:21] ========== drm_test_get_tv_mode_from_name_valid ===========
[14:41:21] [PASSED] NTSC
[14:41:21] [PASSED] NTSC-443
[14:41:21] [PASSED] NTSC-J
[14:41:21] [PASSED] PAL
[14:41:21] [PASSED] PAL-M
[14:41:21] [PASSED] PAL-N
[14:41:21] [PASSED] SECAM
[14:41:21] [PASSED] Mono
[14:41:21] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[14:41:21] [PASSED] drm_test_get_tv_mode_from_name_truncated
[14:41:21] ============ [PASSED] drm_get_tv_mode_from_name ============
[14:41:21] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[14:41:21] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[14:41:21] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[14:41:21] [PASSED] VIC 96
[14:41:21] [PASSED] VIC 97
[14:41:21] [PASSED] VIC 101
[14:41:21] [PASSED] VIC 102
[14:41:21] [PASSED] VIC 106
[14:41:21] [PASSED] VIC 107
[14:41:21] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[14:41:21] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[14:41:21] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[14:41:21] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[14:41:21] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[14:41:21] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[14:41:21] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[14:41:21] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[14:41:21] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[14:41:21] [PASSED] Automatic
[14:41:21] [PASSED] Full
[14:41:21] [PASSED] Limited 16:235
[14:41:21] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[14:41:21] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[14:41:21] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[14:41:21] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[14:41:21] === drm_test_drm_hdmi_connector_get_output_format_name ====
[14:41:21] [PASSED] RGB
[14:41:21] [PASSED] YUV 4:2:0
[14:41:21] [PASSED] YUV 4:2:2
[14:41:21] [PASSED] YUV 4:4:4
[14:41:21] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[14:41:21] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[14:41:21] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[14:41:21] ============= drm_damage_helper (21 subtests) ==============
[14:41:21] [PASSED] drm_test_damage_iter_no_damage
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_src_moved
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_not_visible
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[14:41:21] [PASSED] drm_test_damage_iter_no_damage_no_fb
[14:41:21] [PASSED] drm_test_damage_iter_simple_damage
[14:41:21] [PASSED] drm_test_damage_iter_single_damage
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_outside_src
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_src_moved
[14:41:21] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[14:41:21] [PASSED] drm_test_damage_iter_damage
[14:41:21] [PASSED] drm_test_damage_iter_damage_one_intersect
[14:41:21] [PASSED] drm_test_damage_iter_damage_one_outside
[14:41:21] [PASSED] drm_test_damage_iter_damage_src_moved
[14:41:21] [PASSED] drm_test_damage_iter_damage_not_visible
[14:41:21] ================ [PASSED] drm_damage_helper ================
[14:41:21] ============== drm_dp_mst_helper (3 subtests) ==============
[14:41:21] ============== drm_test_dp_mst_calc_pbn_mode ==============
[14:41:21] [PASSED] Clock 154000 BPP 30 DSC disabled
[14:41:21] [PASSED] Clock 234000 BPP 30 DSC disabled
[14:41:21] [PASSED] Clock 297000 BPP 24 DSC disabled
[14:41:21] [PASSED] Clock 332880 BPP 24 DSC enabled
[14:41:21] [PASSED] Clock 324540 BPP 24 DSC enabled
[14:41:21] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[14:41:21] ============== drm_test_dp_mst_calc_pbn_div ===============
[14:41:21] [PASSED] Link rate 2000000 lane count 4
[14:41:21] [PASSED] Link rate 2000000 lane count 2
[14:41:21] [PASSED] Link rate 2000000 lane count 1
[14:41:21] [PASSED] Link rate 1350000 lane count 4
[14:41:21] [PASSED] Link rate 1350000 lane count 2
[14:41:21] [PASSED] Link rate 1350000 lane count 1
[14:41:21] [PASSED] Link rate 1000000 lane count 4
[14:41:21] [PASSED] Link rate 1000000 lane count 2
[14:41:21] [PASSED] Link rate 1000000 lane count 1
[14:41:21] [PASSED] Link rate 810000 lane count 4
[14:41:21] [PASSED] Link rate 810000 lane count 2
[14:41:21] [PASSED] Link rate 810000 lane count 1
[14:41:21] [PASSED] Link rate 540000 lane count 4
[14:41:21] [PASSED] Link rate 540000 lane count 2
[14:41:21] [PASSED] Link rate 540000 lane count 1
[14:41:21] [PASSED] Link rate 270000 lane count 4
[14:41:21] [PASSED] Link rate 270000 lane count 2
[14:41:21] [PASSED] Link rate 270000 lane count 1
[14:41:21] [PASSED] Link rate 162000 lane count 4
[14:41:21] [PASSED] Link rate 162000 lane count 2
[14:41:21] [PASSED] Link rate 162000 lane count 1
[14:41:21] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[14:41:21] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[14:41:21] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[14:41:21] [PASSED] DP_POWER_UP_PHY with port number
[14:41:21] [PASSED] DP_POWER_DOWN_PHY with port number
[14:41:21] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[14:41:21] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[14:41:21] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[14:41:21] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[14:41:21] [PASSED] DP_QUERY_PAYLOAD with port number
[14:41:21] [PASSED] DP_QUERY_PAYLOAD with VCPI
[14:41:21] [PASSED] DP_REMOTE_DPCD_READ with port number
[14:41:21] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[14:41:21] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[14:41:21] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[14:41:21] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[14:41:21] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[14:41:21] [PASSED] DP_REMOTE_I2C_READ with port number
[14:41:21] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[14:41:21] [PASSED] DP_REMOTE_I2C_READ with transactions array
[14:41:21] [PASSED] DP_REMOTE_I2C_WRITE with port number
[14:41:21] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[14:41:21] [PASSED] DP_REMOTE_I2C_WRITE with data array
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[14:41:21] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[14:41:21] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[14:41:21] ================ [PASSED] drm_dp_mst_helper ================
[14:41:21] ================== drm_exec (7 subtests) ===================
[14:41:21] [PASSED] sanitycheck
[14:41:21] [PASSED] test_lock
[14:41:21] [PASSED] test_lock_unlock
[14:41:21] [PASSED] test_duplicates
[14:41:21] [PASSED] test_prepare
[14:41:21] [PASSED] test_prepare_array
[14:41:21] [PASSED] test_multiple_loops
[14:41:21] ==================== [PASSED] drm_exec =====================
[14:41:21] =========== drm_format_helper_test (17 subtests) ===========
[14:41:21] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[14:41:21] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[14:41:21] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[14:41:21] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[14:41:21] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[14:41:21] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[14:41:21] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[14:41:21] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[14:41:21] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[14:41:21] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[14:41:21] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[14:41:21] ============== drm_test_fb_xrgb8888_to_mono ===============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[14:41:21] ==================== drm_test_fb_swab =====================
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ================ [PASSED] drm_test_fb_swab =================
[14:41:21] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[14:41:21] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[14:41:21] [PASSED] single_pixel_source_buffer
[14:41:21] [PASSED] single_pixel_clip_rectangle
[14:41:21] [PASSED] well_known_colors
[14:41:21] [PASSED] destination_pitch
[14:41:21] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[14:41:21] ================= drm_test_fb_clip_offset =================
[14:41:21] [PASSED] pass through
[14:41:21] [PASSED] horizontal offset
[14:41:21] [PASSED] vertical offset
[14:41:21] [PASSED] horizontal and vertical offset
[14:41:21] [PASSED] horizontal offset (custom pitch)
[14:41:21] [PASSED] vertical offset (custom pitch)
[14:41:21] [PASSED] horizontal and vertical offset (custom pitch)
[14:41:21] ============= [PASSED] drm_test_fb_clip_offset =============
[14:41:21] =================== drm_test_fb_memcpy ====================
[14:41:21] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[14:41:21] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[14:41:21] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[14:41:21] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[14:41:21] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[14:41:21] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[14:41:21] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[14:41:21] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[14:41:21] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[14:41:21] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[14:41:21] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[14:41:21] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[14:41:21] =============== [PASSED] drm_test_fb_memcpy ================
[14:41:21] ============= [PASSED] drm_format_helper_test ==============
[14:41:21] ================= drm_format (18 subtests) =================
[14:41:21] [PASSED] drm_test_format_block_width_invalid
[14:41:21] [PASSED] drm_test_format_block_width_one_plane
[14:41:21] [PASSED] drm_test_format_block_width_two_plane
[14:41:21] [PASSED] drm_test_format_block_width_three_plane
[14:41:21] [PASSED] drm_test_format_block_width_tiled
[14:41:21] [PASSED] drm_test_format_block_height_invalid
[14:41:21] [PASSED] drm_test_format_block_height_one_plane
[14:41:21] [PASSED] drm_test_format_block_height_two_plane
[14:41:21] [PASSED] drm_test_format_block_height_three_plane
[14:41:21] [PASSED] drm_test_format_block_height_tiled
[14:41:21] [PASSED] drm_test_format_min_pitch_invalid
[14:41:21] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[14:41:21] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[14:41:21] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[14:41:21] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[14:41:21] [PASSED] drm_test_format_min_pitch_two_plane
[14:41:21] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[14:41:21] [PASSED] drm_test_format_min_pitch_tiled
[14:41:21] =================== [PASSED] drm_format ====================
[14:41:21] ============== drm_framebuffer (10 subtests) ===============
[14:41:21] ========== drm_test_framebuffer_check_src_coords ==========
[14:41:21] [PASSED] Success: source fits into fb
[14:41:21] [PASSED] Fail: overflowing fb with x-axis coordinate
[14:41:21] [PASSED] Fail: overflowing fb with y-axis coordinate
[14:41:21] [PASSED] Fail: overflowing fb with source width
[14:41:21] [PASSED] Fail: overflowing fb with source height
[14:41:21] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[14:41:21] [PASSED] drm_test_framebuffer_cleanup
[14:41:21] =============== drm_test_framebuffer_create ===============
[14:41:21] [PASSED] ABGR8888 normal sizes
[14:41:21] [PASSED] ABGR8888 max sizes
[14:41:21] [PASSED] ABGR8888 pitch greater than min required
[14:41:21] [PASSED] ABGR8888 pitch less than min required
[14:41:21] [PASSED] ABGR8888 Invalid width
[14:41:21] [PASSED] ABGR8888 Invalid buffer handle
[14:41:21] [PASSED] No pixel format
[14:41:21] [PASSED] ABGR8888 Width 0
[14:41:21] [PASSED] ABGR8888 Height 0
[14:41:21] [PASSED] ABGR8888 Out of bound height * pitch combination
[14:41:21] [PASSED] ABGR8888 Large buffer offset
[14:41:21] [PASSED] ABGR8888 Buffer offset for inexistent plane
[14:41:21] [PASSED] ABGR8888 Invalid flag
[14:41:21] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[14:41:21] [PASSED] ABGR8888 Valid buffer modifier
[14:41:21] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[14:41:21] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] NV12 Normal sizes
[14:41:21] [PASSED] NV12 Max sizes
[14:41:21] [PASSED] NV12 Invalid pitch
[14:41:21] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[14:41:21] [PASSED] NV12 different modifier per-plane
[14:41:21] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[14:41:21] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] NV12 Modifier for inexistent plane
[14:41:21] [PASSED] NV12 Handle for inexistent plane
[14:41:21] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[14:41:21] [PASSED] YVU420 Normal sizes
[14:41:21] [PASSED] YVU420 Max sizes
[14:41:21] [PASSED] YVU420 Invalid pitch
[14:41:21] [PASSED] YVU420 Different pitches
[14:41:21] [PASSED] YVU420 Different buffer offsets/pitches
[14:41:21] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[14:41:21] [PASSED] YVU420 Valid modifier
[14:41:21] [PASSED] YVU420 Different modifiers per plane
[14:41:21] [PASSED] YVU420 Modifier for inexistent plane
[14:41:21] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[14:41:21] [PASSED] X0L2 Normal sizes
[14:41:21] [PASSED] X0L2 Max sizes
[14:41:21] [PASSED] X0L2 Invalid pitch
[14:41:21] [PASSED] X0L2 Pitch greater than minimum required
[14:41:21] [PASSED] X0L2 Handle for inexistent plane
[14:41:21] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[14:41:21] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[14:41:21] [PASSED] X0L2 Valid modifier
[14:41:21] [PASSED] X0L2 Modifier for inexistent plane
[14:41:21] =========== [PASSED] drm_test_framebuffer_create ===========
[14:41:21] [PASSED] drm_test_framebuffer_free
[14:41:21] [PASSED] drm_test_framebuffer_init
[14:41:21] [PASSED] drm_test_framebuffer_init_bad_format
[14:41:21] [PASSED] drm_test_framebuffer_init_dev_mismatch
[14:41:21] [PASSED] drm_test_framebuffer_lookup
[14:41:21] [PASSED] drm_test_framebuffer_lookup_inexistent
[14:41:21] [PASSED] drm_test_framebuffer_modifiers_not_supported
[14:41:21] ================= [PASSED] drm_framebuffer =================
[14:41:21] ================ drm_gem_shmem (8 subtests) ================
[14:41:21] [PASSED] drm_gem_shmem_test_obj_create
[14:41:21] [PASSED] drm_gem_shmem_test_obj_create_private
[14:41:21] [PASSED] drm_gem_shmem_test_pin_pages
[14:41:21] [PASSED] drm_gem_shmem_test_vmap
[14:41:21] [PASSED] drm_gem_shmem_test_get_sg_table
[14:41:21] [PASSED] drm_gem_shmem_test_get_pages_sgt
[14:41:21] [PASSED] drm_gem_shmem_test_madvise
[14:41:21] [PASSED] drm_gem_shmem_test_purge
[14:41:21] ================== [PASSED] drm_gem_shmem ==================
[14:41:21] === drm_atomic_helper_connector_hdmi_check (27 subtests) ===
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[14:41:21] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[14:41:21] [PASSED] Automatic
[14:41:21] [PASSED] Full
[14:41:21] [PASSED] Limited 16:235
[14:41:21] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[14:41:21] [PASSED] drm_test_check_disable_connector
[14:41:21] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[14:41:21] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[14:41:21] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[14:41:21] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[14:41:21] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[14:41:21] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[14:41:21] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[14:41:21] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[14:41:21] [PASSED] drm_test_check_output_bpc_dvi
[14:41:21] [PASSED] drm_test_check_output_bpc_format_vic_1
[14:41:21] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[14:41:21] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[14:41:21] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[14:41:21] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[14:41:21] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[14:41:21] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[14:41:21] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[14:41:21] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[14:41:21] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[14:41:21] [PASSED] drm_test_check_broadcast_rgb_value
[14:41:21] [PASSED] drm_test_check_bpc_8_value
[14:41:21] [PASSED] drm_test_check_bpc_10_value
[14:41:21] [PASSED] drm_test_check_bpc_12_value
[14:41:21] [PASSED] drm_test_check_format_value
[14:41:21] [PASSED] drm_test_check_tmds_char_value
[14:41:21] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[14:41:21] = drm_atomic_helper_connector_hdmi_mode_valid (4 subtests) =
[14:41:21] [PASSED] drm_test_check_mode_valid
[14:41:21] [PASSED] drm_test_check_mode_valid_reject
[14:41:21] [PASSED] drm_test_check_mode_valid_reject_rate
[14:41:21] [PASSED] drm_test_check_mode_valid_reject_max_clock
[14:41:21] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[14:41:21] = drm_atomic_helper_connector_hdmi_infoframes (5 subtests) =
[14:41:21] [PASSED] drm_test_check_infoframes
[14:41:21] [PASSED] drm_test_check_reject_avi_infoframe
[14:41:21] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_8
[14:41:21] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_10
[14:41:21] [PASSED] drm_test_check_reject_audio_infoframe
[14:41:21] === [PASSED] drm_atomic_helper_connector_hdmi_infoframes ===
[14:41:21] ================= drm_managed (2 subtests) =================
[14:41:21] [PASSED] drm_test_managed_release_action
[14:41:21] [PASSED] drm_test_managed_run_action
[14:41:21] =================== [PASSED] drm_managed ===================
[14:41:21] =================== drm_mm (6 subtests) ====================
[14:41:21] [PASSED] drm_test_mm_init
[14:41:21] [PASSED] drm_test_mm_debug
[14:41:21] [PASSED] drm_test_mm_align32
[14:41:21] [PASSED] drm_test_mm_align64
[14:41:21] [PASSED] drm_test_mm_lowest
[14:41:21] [PASSED] drm_test_mm_highest
[14:41:21] ===================== [PASSED] drm_mm ======================
[14:41:21] ============= drm_modes_analog_tv (5 subtests) =============
[14:41:21] [PASSED] drm_test_modes_analog_tv_mono_576i
[14:41:21] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[14:41:21] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[14:41:21] [PASSED] drm_test_modes_analog_tv_pal_576i
[14:41:21] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[14:41:21] =============== [PASSED] drm_modes_analog_tv ===============
[14:41:21] ============== drm_plane_helper (2 subtests) ===============
[14:41:21] =============== drm_test_check_plane_state ================
[14:41:21] [PASSED] clipping_simple
[14:41:21] [PASSED] clipping_rotate_reflect
[14:41:21] [PASSED] positioning_simple
[14:41:21] [PASSED] upscaling
[14:41:21] [PASSED] downscaling
[14:41:21] [PASSED] rounding1
[14:41:21] [PASSED] rounding2
[14:41:21] [PASSED] rounding3
[14:41:21] [PASSED] rounding4
[14:41:21] =========== [PASSED] drm_test_check_plane_state ============
[14:41:21] =========== drm_test_check_invalid_plane_state ============
[14:41:21] [PASSED] positioning_invalid
[14:41:21] [PASSED] upscaling_invalid
[14:41:21] [PASSED] downscaling_invalid
[14:41:21] ======= [PASSED] drm_test_check_invalid_plane_state ========
[14:41:21] ================ [PASSED] drm_plane_helper =================
[14:41:21] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[14:41:21] ====== drm_test_connector_helper_tv_get_modes_check =======
[14:41:21] [PASSED] None
[14:41:21] [PASSED] PAL
[14:41:21] [PASSED] NTSC
[14:41:21] [PASSED] Both, NTSC Default
[14:41:21] [PASSED] Both, PAL Default
[14:41:21] [PASSED] Both, NTSC Default, with PAL on command-line
[14:41:21] [PASSED] Both, PAL Default, with NTSC on command-line
[14:41:21] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[14:41:21] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[14:41:21] ================== drm_rect (9 subtests) ===================
[14:41:21] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[14:41:21] [PASSED] drm_test_rect_clip_scaled_not_clipped
[14:41:21] [PASSED] drm_test_rect_clip_scaled_clipped
[14:41:21] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[14:41:21] ================= drm_test_rect_intersect =================
[14:41:21] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[14:41:21] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[14:41:21] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[14:41:21] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[14:41:21] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[14:41:21] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[14:41:21] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[14:41:21] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[14:41:21] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[14:41:21] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[14:41:21] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[14:41:21] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[14:41:21] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[14:41:21] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[14:41:21] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[14:41:21] ============= [PASSED] drm_test_rect_intersect =============
[14:41:21] ================ drm_test_rect_calc_hscale ================
[14:41:21] [PASSED] normal use
[14:41:21] [PASSED] out of max range
[14:41:21] [PASSED] out of min range
[14:41:21] [PASSED] zero dst
[14:41:21] [PASSED] negative src
[14:41:21] [PASSED] negative dst
[14:41:21] ============ [PASSED] drm_test_rect_calc_hscale ============
[14:41:21] ================ drm_test_rect_calc_vscale ================
[14:41:21] [PASSED] normal use
[14:41:21] [PASSED] out of max range
[14:41:21] [PASSED] out of min range
[14:41:21] [PASSED] zero dst
[14:41:21] [PASSED] negative src
[14:41:21] [PASSED] negative dst
[14:41:21] ============ [PASSED] drm_test_rect_calc_vscale ============
[14:41:21] ================== drm_test_rect_rotate ===================
[14:41:21] [PASSED] reflect-x
[14:41:21] [PASSED] reflect-y
[14:41:21] [PASSED] rotate-0
[14:41:21] [PASSED] rotate-90
[14:41:21] [PASSED] rotate-180
[14:41:21] [PASSED] rotate-270
[14:41:21] ============== [PASSED] drm_test_rect_rotate ===============
[14:41:21] ================ drm_test_rect_rotate_inv =================
[14:41:21] [PASSED] reflect-x
[14:41:21] [PASSED] reflect-y
[14:41:21] [PASSED] rotate-0
[14:41:21] [PASSED] rotate-90
[14:41:21] [PASSED] rotate-180
[14:41:21] [PASSED] rotate-270
[14:41:21] ============ [PASSED] drm_test_rect_rotate_inv =============
[14:41:21] ==================== [PASSED] drm_rect =====================
[14:41:21] ============ drm_sysfb_modeset_test (1 subtest) ============
[14:41:21] ============ drm_test_sysfb_build_fourcc_list =============
[14:41:21] [PASSED] no native formats
[14:41:21] [PASSED] XRGB8888 as native format
[14:41:21] [PASSED] remove duplicates
[14:41:21] [PASSED] convert alpha formats
[14:41:21] [PASSED] random formats
[14:41:21] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[14:41:21] ============= [PASSED] drm_sysfb_modeset_test ==============
[14:41:21] ================== drm_fixp (2 subtests) ===================
[14:41:21] [PASSED] drm_test_int2fixp
[14:41:21] [PASSED] drm_test_sm2fixp
[14:41:21] ==================== [PASSED] drm_fixp =====================
[14:41:21] ============================================================
[14:41:21] Testing complete. Ran 621 tests: passed: 621
[14:41:21] Elapsed time: 32.052s total, 1.724s configuring, 30.163s building, 0.134s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[14:41:21] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[14:41:23] 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=25
[14:41:33] Starting KUnit Kernel (1/1)...
[14:41:33] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[14:41:33] ================= ttm_device (5 subtests) ==================
[14:41:33] [PASSED] ttm_device_init_basic
[14:41:33] [PASSED] ttm_device_init_multiple
[14:41:33] [PASSED] ttm_device_fini_basic
[14:41:33] [PASSED] ttm_device_init_no_vma_man
[14:41:33] ================== ttm_device_init_pools ==================
[14:41:33] [PASSED] No DMA allocations, no DMA32 required
[14:41:33] [PASSED] DMA allocations, DMA32 required
[14:41:33] [PASSED] No DMA allocations, DMA32 required
[14:41:33] [PASSED] DMA allocations, no DMA32 required
[14:41:33] ============== [PASSED] ttm_device_init_pools ==============
[14:41:33] =================== [PASSED] ttm_device ====================
[14:41:33] ================== ttm_pool (8 subtests) ===================
[14:41:33] ================== ttm_pool_alloc_basic ===================
[14:41:33] [PASSED] One page
[14:41:33] [PASSED] More than one page
[14:41:33] [PASSED] Above the allocation limit
[14:41:33] [PASSED] One page, with coherent DMA mappings enabled
[14:41:33] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[14:41:33] ============== [PASSED] ttm_pool_alloc_basic ===============
[14:41:33] ============== ttm_pool_alloc_basic_dma_addr ==============
[14:41:33] [PASSED] One page
[14:41:33] [PASSED] More than one page
[14:41:33] [PASSED] Above the allocation limit
[14:41:33] [PASSED] One page, with coherent DMA mappings enabled
[14:41:33] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[14:41:33] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[14:41:33] [PASSED] ttm_pool_alloc_order_caching_match
[14:41:33] [PASSED] ttm_pool_alloc_caching_mismatch
[14:41:33] [PASSED] ttm_pool_alloc_order_mismatch
[14:41:33] [PASSED] ttm_pool_free_dma_alloc
[14:41:33] [PASSED] ttm_pool_free_no_dma_alloc
[14:41:33] [PASSED] ttm_pool_fini_basic
[14:41:33] ==================== [PASSED] ttm_pool =====================
[14:41:33] ================ ttm_resource (8 subtests) =================
[14:41:33] ================= ttm_resource_init_basic =================
[14:41:33] [PASSED] Init resource in TTM_PL_SYSTEM
[14:41:33] [PASSED] Init resource in TTM_PL_VRAM
[14:41:33] [PASSED] Init resource in a private placement
[14:41:33] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[14:41:33] ============= [PASSED] ttm_resource_init_basic =============
[14:41:33] [PASSED] ttm_resource_init_pinned
[14:41:33] [PASSED] ttm_resource_fini_basic
[14:41:33] [PASSED] ttm_resource_manager_init_basic
[14:41:33] [PASSED] ttm_resource_manager_usage_basic
[14:41:33] [PASSED] ttm_resource_manager_set_used_basic
[14:41:33] [PASSED] ttm_sys_man_alloc_basic
[14:41:33] [PASSED] ttm_sys_man_free_basic
[14:41:33] ================== [PASSED] ttm_resource ===================
[14:41:33] =================== ttm_tt (15 subtests) ===================
[14:41:33] ==================== ttm_tt_init_basic ====================
[14:41:33] [PASSED] Page-aligned size
[14:41:33] [PASSED] Extra pages requested
[14:41:33] ================ [PASSED] ttm_tt_init_basic ================
[14:41:33] [PASSED] ttm_tt_init_misaligned
[14:41:33] [PASSED] ttm_tt_fini_basic
[14:41:33] [PASSED] ttm_tt_fini_sg
[14:41:33] [PASSED] ttm_tt_fini_shmem
[14:41:33] [PASSED] ttm_tt_create_basic
[14:41:33] [PASSED] ttm_tt_create_invalid_bo_type
[14:41:33] [PASSED] ttm_tt_create_ttm_exists
[14:41:33] [PASSED] ttm_tt_create_failed
[14:41:33] [PASSED] ttm_tt_destroy_basic
[14:41:33] [PASSED] ttm_tt_populate_null_ttm
[14:41:33] [PASSED] ttm_tt_populate_populated_ttm
[14:41:33] [PASSED] ttm_tt_unpopulate_basic
[14:41:33] [PASSED] ttm_tt_unpopulate_empty_ttm
[14:41:33] [PASSED] ttm_tt_swapin_basic
[14:41:33] ===================== [PASSED] ttm_tt ======================
[14:41:33] =================== ttm_bo (14 subtests) ===================
[14:41:33] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[14:41:33] [PASSED] Cannot be interrupted and sleeps
[14:41:33] [PASSED] Cannot be interrupted, locks straight away
[14:41:33] [PASSED] Can be interrupted, sleeps
[14:41:33] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[14:41:33] [PASSED] ttm_bo_reserve_locked_no_sleep
[14:41:33] [PASSED] ttm_bo_reserve_no_wait_ticket
[14:41:33] [PASSED] ttm_bo_reserve_double_resv
[14:41:33] [PASSED] ttm_bo_reserve_interrupted
[14:41:33] [PASSED] ttm_bo_reserve_deadlock
[14:41:33] [PASSED] ttm_bo_unreserve_basic
[14:41:33] [PASSED] ttm_bo_unreserve_pinned
[14:41:33] [PASSED] ttm_bo_unreserve_bulk
[14:41:33] [PASSED] ttm_bo_fini_basic
[14:41:33] [PASSED] ttm_bo_fini_shared_resv
[14:41:33] [PASSED] ttm_bo_pin_basic
[14:41:33] [PASSED] ttm_bo_pin_unpin_resource
[14:41:33] [PASSED] ttm_bo_multiple_pin_one_unpin
[14:41:33] ===================== [PASSED] ttm_bo ======================
[14:41:33] ============== ttm_bo_validate (22 subtests) ===============
[14:41:33] ============== ttm_bo_init_reserved_sys_man ===============
[14:41:33] [PASSED] Buffer object for userspace
[14:41:33] [PASSED] Kernel buffer object
[14:41:33] [PASSED] Shared buffer object
[14:41:33] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[14:41:33] ============== ttm_bo_init_reserved_mock_man ==============
[14:41:33] [PASSED] Buffer object for userspace
[14:41:33] [PASSED] Kernel buffer object
[14:41:33] [PASSED] Shared buffer object
[14:41:33] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[14:41:33] [PASSED] ttm_bo_init_reserved_resv
[14:41:33] ================== ttm_bo_validate_basic ==================
[14:41:33] [PASSED] Buffer object for userspace
[14:41:33] [PASSED] Kernel buffer object
[14:41:33] [PASSED] Shared buffer object
[14:41:33] ============== [PASSED] ttm_bo_validate_basic ==============
[14:41:33] [PASSED] ttm_bo_validate_invalid_placement
[14:41:33] ============= ttm_bo_validate_same_placement ==============
[14:41:33] [PASSED] System manager
[14:41:33] [PASSED] VRAM manager
[14:41:33] ========= [PASSED] ttm_bo_validate_same_placement ==========
[14:41:33] [PASSED] ttm_bo_validate_failed_alloc
[14:41:33] [PASSED] ttm_bo_validate_pinned
[14:41:33] [PASSED] ttm_bo_validate_busy_placement
[14:41:33] ================ ttm_bo_validate_multihop =================
[14:41:33] [PASSED] Buffer object for userspace
[14:41:33] [PASSED] Kernel buffer object
[14:41:33] [PASSED] Shared buffer object
[14:41:33] ============ [PASSED] ttm_bo_validate_multihop =============
[14:41:33] ========== ttm_bo_validate_no_placement_signaled ==========
[14:41:33] [PASSED] Buffer object in system domain, no page vector
[14:41:33] [PASSED] Buffer object in system domain with an existing page vector
[14:41:33] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[14:41:33] ======== ttm_bo_validate_no_placement_not_signaled ========
[14:41:33] [PASSED] Buffer object for userspace
[14:41:33] [PASSED] Kernel buffer object
[14:41:33] [PASSED] Shared buffer object
[14:41:33] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[14:41:33] [PASSED] ttm_bo_validate_move_fence_signaled
[14:41:33] ========= ttm_bo_validate_move_fence_not_signaled =========
[14:41:33] [PASSED] Waits for GPU
[14:41:33] [PASSED] Tries to lock straight away
[14:41:33] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[14:41:33] [PASSED] ttm_bo_validate_swapout
[14:41:33] [PASSED] ttm_bo_validate_happy_evict
[14:41:33] [PASSED] ttm_bo_validate_all_pinned_evict
[14:41:33] [PASSED] ttm_bo_validate_allowed_only_evict
[14:41:33] [PASSED] ttm_bo_validate_deleted_evict
[14:41:33] [PASSED] ttm_bo_validate_busy_domain_evict
[14:41:33] [PASSED] ttm_bo_validate_evict_gutting
[14:41:33] [PASSED] ttm_bo_validate_recrusive_evict
[14:41:33] ================= [PASSED] ttm_bo_validate =================
[14:41:33] ============================================================
[14:41:33] Testing complete. Ran 102 tests: passed: 102
[14:41:33] Elapsed time: 11.962s total, 1.787s configuring, 9.960s building, 0.176s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 18+ messages in thread* ✓ Xe.CI.BAT: success for gpu/buddy: Per-order free and used block scoreboards (rev4)
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (6 preceding siblings ...)
2026-05-18 14:41 ` ✓ CI.KUnit: success " Patchwork
@ 2026-05-18 15:33 ` Patchwork
2026-05-18 19:50 ` ✗ Xe.CI.FULL: failure " Patchwork
8 siblings, 0 replies; 18+ messages in thread
From: Patchwork @ 2026-05-18 15:33 UTC (permalink / raw)
To: Francois Dugast; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 973 bytes --]
== Series Details ==
Series: gpu/buddy: Per-order free and used block scoreboards (rev4)
URL : https://patchwork.freedesktop.org/series/165914/
State : success
== Summary ==
CI Bug Log - changes from xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d_BAT -> xe-pw-165914v4_BAT
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (13 -> 13)
------------------------------
No changes in participating hosts
Changes
-------
No changes found
Build changes
-------------
* Linux: xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d -> xe-pw-165914v4
IGT_8917: 65d691069f26fc2a42c79e2364241320b85d48bc @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d: d4e758a33a21b1ff270bb6fa2ffd9210353eb76d
xe-pw-165914v4: 165914v4
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/index.html
[-- Attachment #2: Type: text/html, Size: 1521 bytes --]
^ permalink raw reply [flat|nested] 18+ messages in thread* ✗ Xe.CI.FULL: failure for gpu/buddy: Per-order free and used block scoreboards (rev4)
2026-05-18 14:14 [PATCH v3 0/5] gpu/buddy: Per-order free and used block scoreboards Francois Dugast
` (7 preceding siblings ...)
2026-05-18 15:33 ` ✓ Xe.CI.BAT: " Patchwork
@ 2026-05-18 19:50 ` Patchwork
8 siblings, 0 replies; 18+ messages in thread
From: Patchwork @ 2026-05-18 19:50 UTC (permalink / raw)
To: Francois Dugast; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 35351 bytes --]
== Series Details ==
Series: gpu/buddy: Per-order free and used block scoreboards (rev4)
URL : https://patchwork.freedesktop.org/series/165914/
State : failure
== Summary ==
CI Bug Log - changes from xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d_FULL -> xe-pw-165914v4_FULL
====================================================
Summary
-------
**FAILURE**
Serious unknown changes coming with xe-pw-165914v4_FULL absolutely need to be
verified manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-165914v4_FULL, 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.
Participating hosts (2 -> 2)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-165914v4_FULL:
### IGT changes ###
#### Possible regressions ####
* igt@xe_pm@s4-vm-bind-prefetch:
- shard-bmg: [PASS][1] -> [INCOMPLETE][2]
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-5/igt@xe_pm@s4-vm-bind-prefetch.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_pm@s4-vm-bind-prefetch.html
Known issues
------------
Here are the changes found in xe-pw-165914v4_FULL that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_big_fb@linear-max-hw-stride-64bpp-rotate-0-hflip:
- shard-bmg: NOTRUN -> [SKIP][3] ([Intel XE#7059] / [Intel XE#7085])
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_big_fb@linear-max-hw-stride-64bpp-rotate-0-hflip.html
* igt@kms_big_fb@x-tiled-16bpp-rotate-90:
- shard-bmg: NOTRUN -> [SKIP][4] ([Intel XE#2327]) +3 other tests skip
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@kms_big_fb@x-tiled-16bpp-rotate-90.html
* igt@kms_big_fb@y-tiled-16bpp-rotate-270:
- shard-bmg: NOTRUN -> [SKIP][5] ([Intel XE#1124]) +1 other test skip
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_big_fb@y-tiled-16bpp-rotate-270.html
* igt@kms_big_fb@y-tiled-max-hw-stride-64bpp-rotate-0-hflip:
- shard-lnl: NOTRUN -> [SKIP][6] ([Intel XE#1124]) +1 other test skip
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_big_fb@y-tiled-max-hw-stride-64bpp-rotate-0-hflip.html
* igt@kms_bw@connected-linear-tiling-2-displays-target-3840x2160p:
- shard-bmg: NOTRUN -> [SKIP][7] ([Intel XE#7679]) +1 other test skip
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_bw@connected-linear-tiling-2-displays-target-3840x2160p.html
* igt@kms_ccs@bad-aux-stride-yf-tiled-ccs:
- shard-bmg: NOTRUN -> [SKIP][8] ([Intel XE#2887]) +2 other tests skip
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_ccs@bad-aux-stride-yf-tiled-ccs.html
* igt@kms_ccs@bad-rotation-90-4-tiled-lnl-ccs@pipe-c-dp-2:
- shard-bmg: NOTRUN -> [SKIP][9] ([Intel XE#2652]) +8 other tests skip
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_ccs@bad-rotation-90-4-tiled-lnl-ccs@pipe-c-dp-2.html
* igt@kms_ccs@crc-primary-rotation-180-y-tiled-gen12-rc-ccs-cc:
- shard-lnl: NOTRUN -> [SKIP][10] ([Intel XE#2887]) +2 other tests skip
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_ccs@crc-primary-rotation-180-y-tiled-gen12-rc-ccs-cc.html
* igt@kms_ccs@crc-primary-suspend-y-tiled-gen12-rc-ccs-cc:
- shard-bmg: NOTRUN -> [SKIP][11] ([Intel XE#3432])
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_ccs@crc-primary-suspend-y-tiled-gen12-rc-ccs-cc.html
* igt@kms_chamelium_color@ctm-0-25:
- shard-lnl: NOTRUN -> [SKIP][12] ([Intel XE#306] / [Intel XE#7358])
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_chamelium_color@ctm-0-25.html
* igt@kms_chamelium_frames@dp-crc-single:
- shard-bmg: NOTRUN -> [SKIP][13] ([Intel XE#2252]) +4 other tests skip
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_chamelium_frames@dp-crc-single.html
* igt@kms_chamelium_hpd@dp-hpd-after-suspend:
- shard-lnl: NOTRUN -> [SKIP][14] ([Intel XE#373])
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_chamelium_hpd@dp-hpd-after-suspend.html
* igt@kms_chamelium_sharpness_filter@filter-basic:
- shard-bmg: NOTRUN -> [SKIP][15] ([Intel XE#6507])
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_chamelium_sharpness_filter@filter-basic.html
* igt@kms_content_protection@content-type-change:
- shard-bmg: NOTRUN -> [SKIP][16] ([Intel XE#7642])
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_content_protection@content-type-change.html
* igt@kms_cursor_crc@cursor-onscreen-512x170:
- shard-lnl: NOTRUN -> [SKIP][17] ([Intel XE#2321] / [Intel XE#7355])
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_cursor_crc@cursor-onscreen-512x170.html
* igt@kms_cursor_crc@cursor-random-max-size:
- shard-lnl: NOTRUN -> [SKIP][18] ([Intel XE#1424])
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_cursor_crc@cursor-random-max-size.html
* igt@kms_cursor_crc@cursor-sliding-512x170:
- shard-bmg: NOTRUN -> [SKIP][19] ([Intel XE#2321] / [Intel XE#7355])
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_cursor_crc@cursor-sliding-512x170.html
* igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size:
- shard-bmg: [PASS][20] -> [INCOMPLETE][21] ([Intel XE#7935])
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-5/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-2/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
* igt@kms_cursor_legacy@cursorb-vs-flipa-varying-size:
- shard-lnl: NOTRUN -> [SKIP][22] ([Intel XE#309] / [Intel XE#7343])
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_cursor_legacy@cursorb-vs-flipa-varying-size.html
* igt@kms_cursor_legacy@short-busy-flip-before-cursor-atomic-transitions:
- shard-lnl: NOTRUN -> [SKIP][23] ([Intel XE#323] / [Intel XE#6035])
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_cursor_legacy@short-busy-flip-before-cursor-atomic-transitions.html
* igt@kms_dirtyfb@fbc-dirtyfb-ioctl:
- shard-bmg: NOTRUN -> [SKIP][24] ([Intel XE#4210] / [Intel XE#7467])
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-5/igt@kms_dirtyfb@fbc-dirtyfb-ioctl.html
* igt@kms_flip@2x-flip-vs-panning-interruptible:
- shard-lnl: NOTRUN -> [SKIP][25] ([Intel XE#1421])
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_flip@2x-flip-vs-panning-interruptible.html
* igt@kms_flip@flip-vs-expired-vblank-interruptible:
- shard-bmg: [PASS][26] -> [FAIL][27] ([Intel XE#3321]) +1 other test fail
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-5/igt@kms_flip@flip-vs-expired-vblank-interruptible.html
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-2/igt@kms_flip@flip-vs-expired-vblank-interruptible.html
* igt@kms_flip_scaled_crc@flip-32bpp-yuv-linear-to-32bpp-yuv-linear-reflect-x:
- shard-bmg: NOTRUN -> [SKIP][28] ([Intel XE#7179])
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-5/igt@kms_flip_scaled_crc@flip-32bpp-yuv-linear-to-32bpp-yuv-linear-reflect-x.html
* igt@kms_flip_scaled_crc@flip-64bpp-yftile-to-32bpp-yftile-upscaling:
- shard-bmg: NOTRUN -> [SKIP][29] ([Intel XE#7178] / [Intel XE#7351])
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@kms_flip_scaled_crc@flip-64bpp-yftile-to-32bpp-yftile-upscaling.html
* igt@kms_frontbuffer_tracking@drrs-1p-primscrn-cur-indfb-onoff:
- shard-lnl: NOTRUN -> [SKIP][30] ([Intel XE#6312] / [Intel XE#651]) +2 other tests skip
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@drrs-1p-primscrn-cur-indfb-onoff.html
* igt@kms_frontbuffer_tracking@drrs-1p-primscrn-spr-indfb-fullscreen:
- shard-bmg: NOTRUN -> [SKIP][31] ([Intel XE#2311]) +18 other tests skip
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_frontbuffer_tracking@drrs-1p-primscrn-spr-indfb-fullscreen.html
* igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-render:
- shard-lnl: NOTRUN -> [SKIP][32] ([Intel XE#656] / [Intel XE#7905]) +2 other tests skip
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@drrshdr-2p-primscrn-pri-indfb-draw-blt:
- shard-lnl: NOTRUN -> [SKIP][33] ([Intel XE#7905]) +6 other tests skip
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_frontbuffer_tracking@drrshdr-2p-primscrn-pri-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@fbc-2p-primscrn-indfb-plflip-blt:
- shard-bmg: NOTRUN -> [SKIP][34] ([Intel XE#4141]) +5 other tests skip
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-indfb-plflip-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-argb161616f-draw-blt:
- shard-lnl: NOTRUN -> [SKIP][35] ([Intel XE#7061] / [Intel XE#7356]) +1 other test skip
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@fbcdrrs-argb161616f-draw-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrshdr-rgb565-draw-blt:
- shard-lnl: NOTRUN -> [SKIP][36] ([Intel XE#6312])
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@fbcdrrshdr-rgb565-draw-blt.html
* igt@kms_frontbuffer_tracking@fbcpsr-2p-pri-indfb-multidraw:
- shard-bmg: NOTRUN -> [SKIP][37] ([Intel XE#2313]) +17 other tests skip
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_frontbuffer_tracking@fbcpsr-2p-pri-indfb-multidraw.html
* igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-primscrn-cur-indfb-draw-mmap-wc:
- shard-lnl: NOTRUN -> [SKIP][38] ([Intel XE#7865]) +4 other tests skip
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-primscrn-cur-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbcpsrhdr-tiling-y:
- shard-lnl: NOTRUN -> [SKIP][39] ([Intel XE#7399])
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_frontbuffer_tracking@fbcpsrhdr-tiling-y.html
* igt@kms_frontbuffer_tracking@hdr-abgr161616f-draw-mmap-wc:
- shard-bmg: NOTRUN -> [SKIP][40] ([Intel XE#7061]) +1 other test skip
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_frontbuffer_tracking@hdr-abgr161616f-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@psr-argb161616f-draw-mmap-wc:
- shard-bmg: NOTRUN -> [SKIP][41] ([Intel XE#7061] / [Intel XE#7356]) +1 other test skip
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_frontbuffer_tracking@psr-argb161616f-draw-mmap-wc.html
* igt@kms_hdmi_inject@inject-audio:
- shard-bmg: NOTRUN -> [SKIP][42] ([Intel XE#7308])
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@kms_hdmi_inject@inject-audio.html
* igt@kms_hdr@static-toggle-dpms@pipe-a-hdmi-a-3-xrgb2101010:
- shard-bmg: [PASS][43] -> [SKIP][44] ([Intel XE#7915]) +3 other tests skip
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-10/igt@kms_hdr@static-toggle-dpms@pipe-a-hdmi-a-3-xrgb2101010.html
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-7/igt@kms_hdr@static-toggle-dpms@pipe-a-hdmi-a-3-xrgb2101010.html
* igt@kms_multipipe_modeset@basic-max-pipe-crc-check:
- shard-bmg: NOTRUN -> [SKIP][45] ([Intel XE#7591])
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_multipipe_modeset@basic-max-pipe-crc-check.html
* igt@kms_plane@pixel-format-4-tiled-lnl-ccs-modifier:
- shard-bmg: NOTRUN -> [SKIP][46] ([Intel XE#7283]) +1 other test skip
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@kms_plane@pixel-format-4-tiled-lnl-ccs-modifier.html
* igt@kms_plane_lowres@tiling-4:
- shard-lnl: NOTRUN -> [SKIP][47] ([Intel XE#599] / [Intel XE#7382]) +3 other tests skip
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_plane_lowres@tiling-4.html
* igt@kms_pm_backlight@fade-with-suspend:
- shard-bmg: NOTRUN -> [SKIP][48] ([Intel XE#7376] / [Intel XE#7760] / [Intel XE#870])
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_pm_backlight@fade-with-suspend.html
* igt@kms_pm_dc@dc5-dpms-negative:
- shard-lnl: NOTRUN -> [SKIP][49] ([Intel XE#1131])
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_pm_dc@dc5-dpms-negative.html
* igt@kms_psr2_sf@fbc-pr-cursor-plane-move-continuous-exceed-sf:
- shard-bmg: NOTRUN -> [SKIP][50] ([Intel XE#1489]) +2 other tests skip
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_psr2_sf@fbc-pr-cursor-plane-move-continuous-exceed-sf.html
* igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf:
- shard-lnl: NOTRUN -> [SKIP][51] ([Intel XE#2893] / [Intel XE#4608] / [Intel XE#7304])
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf.html
* igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf@pipe-a-edp-1:
- shard-lnl: NOTRUN -> [SKIP][52] ([Intel XE#4608])
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf@pipe-a-edp-1.html
* igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf@pipe-b-edp-1:
- shard-lnl: NOTRUN -> [SKIP][53] ([Intel XE#4608] / [Intel XE#7304])
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf@pipe-b-edp-1.html
* igt@kms_psr@fbc-pr-cursor-plane-onoff:
- shard-bmg: NOTRUN -> [SKIP][54] ([Intel XE#2234] / [Intel XE#2850]) +5 other tests skip
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_psr@fbc-pr-cursor-plane-onoff.html
* igt@kms_psr@fbc-psr2-dpms:
- shard-lnl: NOTRUN -> [SKIP][55] ([Intel XE#1406] / [Intel XE#7345])
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_psr@fbc-psr2-dpms.html
* igt@kms_psr@fbc-psr2-dpms@edp-1:
- shard-lnl: NOTRUN -> [SKIP][56] ([Intel XE#1406] / [Intel XE#4609])
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_psr@fbc-psr2-dpms@edp-1.html
* igt@kms_psr@pr-primary-blt:
- shard-lnl: NOTRUN -> [SKIP][57] ([Intel XE#1406])
[57]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_psr@pr-primary-blt.html
* igt@kms_rotation_crc@primary-4-tiled-reflect-x-180:
- shard-lnl: NOTRUN -> [SKIP][58] ([Intel XE#3414] / [Intel XE#3904] / [Intel XE#7342])
[58]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@kms_rotation_crc@primary-4-tiled-reflect-x-180.html
* igt@kms_sharpness_filter@invalid-filter-with-scaling-mode:
- shard-bmg: NOTRUN -> [SKIP][59] ([Intel XE#6503])
[59]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_sharpness_filter@invalid-filter-with-scaling-mode.html
* igt@kms_vrr@seamless-rr-switch-vrr:
- shard-bmg: NOTRUN -> [SKIP][60] ([Intel XE#1499]) +1 other test skip
[60]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@kms_vrr@seamless-rr-switch-vrr.html
* igt@xe_compute@ccs-mode-compute-kernel:
- shard-bmg: NOTRUN -> [SKIP][61] ([Intel XE#6599])
[61]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_compute@ccs-mode-compute-kernel.html
* igt@xe_eudebug@basic-vm-bind-ufence-delay-ack:
- shard-lnl: NOTRUN -> [SKIP][62] ([Intel XE#7636]) +2 other tests skip
[62]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_eudebug@basic-vm-bind-ufence-delay-ack.html
* igt@xe_eudebug_online@writes-caching-vram-bb-vram-target-vram:
- shard-bmg: NOTRUN -> [SKIP][63] ([Intel XE#7636]) +4 other tests skip
[63]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@xe_eudebug_online@writes-caching-vram-bb-vram-target-vram.html
* igt@xe_evict@evict-large-external:
- shard-lnl: NOTRUN -> [SKIP][64] ([Intel XE#6540] / [Intel XE#688]) +1 other test skip
[64]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@xe_evict@evict-large-external.html
* igt@xe_evict@evict-mixed-many-threads-small:
- shard-bmg: [PASS][65] -> [INCOMPLETE][66] ([Intel XE#6321])
[65]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-9/igt@xe_evict@evict-mixed-many-threads-small.html
[66]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-8/igt@xe_evict@evict-mixed-many-threads-small.html
* igt@xe_exec_balancer@once-virtual-userptr-invalidate-race:
- shard-lnl: NOTRUN -> [SKIP][67] ([Intel XE#7482]) +3 other tests skip
[67]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_exec_balancer@once-virtual-userptr-invalidate-race.html
* igt@xe_exec_basic@multigpu-once-bindexecqueue-userptr-rebind:
- shard-bmg: NOTRUN -> [SKIP][68] ([Intel XE#2322] / [Intel XE#7372]) +3 other tests skip
[68]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_exec_basic@multigpu-once-bindexecqueue-userptr-rebind.html
* igt@xe_exec_basic@multigpu-once-userptr-invalidate:
- shard-lnl: NOTRUN -> [SKIP][69] ([Intel XE#1392])
[69]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_exec_basic@multigpu-once-userptr-invalidate.html
* igt@xe_exec_fault_mode@many-execqueues-multi-queue-invalid-userptr-fault:
- shard-bmg: NOTRUN -> [SKIP][70] ([Intel XE#7136]) +2 other tests skip
[70]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-5/igt@xe_exec_fault_mode@many-execqueues-multi-queue-invalid-userptr-fault.html
* igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate-prefetch:
- shard-lnl: NOTRUN -> [SKIP][71] ([Intel XE#7136])
[71]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate-prefetch.html
* igt@xe_exec_multi_queue@few-execs-preempt-mode-fault-basic:
- shard-bmg: NOTRUN -> [SKIP][72] ([Intel XE#6874]) +9 other tests skip
[72]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@xe_exec_multi_queue@few-execs-preempt-mode-fault-basic.html
* igt@xe_exec_multi_queue@many-queues-preempt-mode-userptr:
- shard-lnl: NOTRUN -> [SKIP][73] ([Intel XE#6874]) +2 other tests skip
[73]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_exec_multi_queue@many-queues-preempt-mode-userptr.html
* igt@xe_exec_reset@cm-multi-queue-cat-error-on-secondary:
- shard-bmg: NOTRUN -> [SKIP][74] ([Intel XE#7866]) +1 other test skip
[74]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-5/igt@xe_exec_reset@cm-multi-queue-cat-error-on-secondary.html
* igt@xe_exec_system_allocator@many-stride-new-prefetch:
- shard-bmg: NOTRUN -> [INCOMPLETE][75] ([Intel XE#7098])
[75]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_exec_system_allocator@many-stride-new-prefetch.html
* igt@xe_exec_threads@threads-multi-queue-rebind:
- shard-bmg: NOTRUN -> [SKIP][76] ([Intel XE#7138]) +1 other test skip
[76]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_exec_threads@threads-multi-queue-rebind.html
* igt@xe_fault_injection@exec-queue-create-fail-xe_pxp_exec_queue_add:
- shard-bmg: NOTRUN -> [SKIP][77] ([Intel XE#6281] / [Intel XE#7426])
[77]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_fault_injection@exec-queue-create-fail-xe_pxp_exec_queue_add.html
* igt@xe_gt_freq@freq_suspend:
- shard-lnl: NOTRUN -> [SKIP][78] ([Intel XE#584] / [Intel XE#7369])
[78]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_gt_freq@freq_suspend.html
* igt@xe_multigpu_svm@mgpu-coherency-basic:
- shard-bmg: NOTRUN -> [SKIP][79] ([Intel XE#6964])
[79]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_multigpu_svm@mgpu-coherency-basic.html
* igt@xe_multigpu_svm@mgpu-migration-prefetch:
- shard-lnl: NOTRUN -> [SKIP][80] ([Intel XE#6964])
[80]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_multigpu_svm@mgpu-migration-prefetch.html
* igt@xe_page_reclaim@binds-full-pd:
- shard-bmg: NOTRUN -> [SKIP][81] ([Intel XE#7793])
[81]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_page_reclaim@binds-full-pd.html
* igt@xe_page_reclaim@pat-index-xd:
- shard-lnl: NOTRUN -> [SKIP][82] ([Intel XE#7793])
[82]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_page_reclaim@pat-index-xd.html
* igt@xe_pat@pat-index-xelp:
- shard-bmg: NOTRUN -> [SKIP][83] ([Intel XE#2245] / [Intel XE#7590])
[83]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@xe_pat@pat-index-xelp.html
* igt@xe_pm@d3cold-basic:
- shard-bmg: NOTRUN -> [SKIP][84] ([Intel XE#2284] / [Intel XE#7370])
[84]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@xe_pm@d3cold-basic.html
* igt@xe_pm@s2idle-d3hot-basic-exec:
- shard-bmg: [PASS][85] -> [ABORT][86] ([Intel XE#7893])
[85]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-9/igt@xe_pm@s2idle-d3hot-basic-exec.html
[86]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-7/igt@xe_pm@s2idle-d3hot-basic-exec.html
* igt@xe_query@multigpu-query-invalid-cs-cycles:
- shard-bmg: NOTRUN -> [SKIP][87] ([Intel XE#944]) +1 other test skip
[87]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@xe_query@multigpu-query-invalid-cs-cycles.html
* igt@xe_sriov_vram@vf-access-after-resize-up:
- shard-lnl: NOTRUN -> [SKIP][88] ([Intel XE#6376] / [Intel XE#7330] / [Intel XE#7422])
[88]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-3/igt@xe_sriov_vram@vf-access-after-resize-up.html
* igt@xe_vm@overcommit-nonfault-vram-no-lr:
- shard-lnl: NOTRUN -> [SKIP][89] ([Intel XE#7892])
[89]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@xe_vm@overcommit-nonfault-vram-no-lr.html
#### Possible fixes ####
* igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs:
- shard-bmg: [INCOMPLETE][90] ([Intel XE#7084]) -> [PASS][91] +1 other test pass
[90]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-2/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs.html
[91]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-5/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs.html
* igt@kms_cursor_legacy@flip-vs-cursor-legacy:
- shard-bmg: [FAIL][92] ([Intel XE#7571]) -> [PASS][93]
[92]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-6/igt@kms_cursor_legacy@flip-vs-cursor-legacy.html
[93]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-4/igt@kms_cursor_legacy@flip-vs-cursor-legacy.html
* igt@kms_flip@2x-flip-vs-absolute-wf_vblank@ad-dp2-hdmi-a3:
- shard-bmg: [INCOMPLETE][94] -> [PASS][95] +1 other test pass
[94]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-2/igt@kms_flip@2x-flip-vs-absolute-wf_vblank@ad-dp2-hdmi-a3.html
[95]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-6/igt@kms_flip@2x-flip-vs-absolute-wf_vblank@ad-dp2-hdmi-a3.html
* igt@kms_plane_scaling@planes-unity-scaling-downscale-factor-0-75@pipe-c:
- shard-lnl: [INCOMPLETE][96] -> [PASS][97] +1 other test pass
[96]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-lnl-7/igt@kms_plane_scaling@planes-unity-scaling-downscale-factor-0-75@pipe-c.html
[97]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-lnl-8/igt@kms_plane_scaling@planes-unity-scaling-downscale-factor-0-75@pipe-c.html
* igt@xe_exec_system_allocator@process-many-large-malloc-busy-nomemset:
- shard-bmg: [ABORT][98] -> [PASS][99]
[98]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-1/igt@xe_exec_system_allocator@process-many-large-malloc-busy-nomemset.html
[99]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-3/igt@xe_exec_system_allocator@process-many-large-malloc-busy-nomemset.html
#### Warnings ####
* igt@kms_tiled_display@basic-test-pattern-with-chamelium:
- shard-bmg: [SKIP][100] ([Intel XE#2509] / [Intel XE#7437]) -> [SKIP][101] ([Intel XE#2426] / [Intel XE#5848])
[100]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d/shard-bmg-10/igt@kms_tiled_display@basic-test-pattern-with-chamelium.html
[101]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/shard-bmg-7/igt@kms_tiled_display@basic-test-pattern-with-chamelium.html
[Intel XE#1124]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1124
[Intel XE#1131]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1131
[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#1421]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1421
[Intel XE#1424]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1424
[Intel XE#1489]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1489
[Intel XE#1499]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1499
[Intel XE#2234]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2234
[Intel XE#2245]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2245
[Intel XE#2252]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2252
[Intel XE#2284]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2284
[Intel XE#2311]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2311
[Intel XE#2313]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2313
[Intel XE#2321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2321
[Intel XE#2322]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2322
[Intel XE#2327]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2327
[Intel XE#2426]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2426
[Intel XE#2509]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2509
[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#2887]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2887
[Intel XE#2893]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2893
[Intel XE#306]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/306
[Intel XE#309]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/309
[Intel XE#323]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/323
[Intel XE#3321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3321
[Intel XE#3414]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3414
[Intel XE#3432]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3432
[Intel XE#373]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/373
[Intel XE#3904]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3904
[Intel XE#4141]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4141
[Intel XE#4210]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4210
[Intel XE#4608]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4608
[Intel XE#4609]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4609
[Intel XE#584]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/584
[Intel XE#5848]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5848
[Intel XE#599]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/599
[Intel XE#6035]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6035
[Intel XE#6281]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6281
[Intel XE#6312]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6312
[Intel XE#6321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6321
[Intel XE#6376]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6376
[Intel XE#6503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6503
[Intel XE#6507]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6507
[Intel XE#651]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/651
[Intel XE#6540]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6540
[Intel XE#656]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/656
[Intel XE#6599]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6599
[Intel XE#6874]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6874
[Intel XE#688]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/688
[Intel XE#6964]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6964
[Intel XE#7059]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7059
[Intel XE#7061]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7061
[Intel XE#7084]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7084
[Intel XE#7085]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7085
[Intel XE#7098]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7098
[Intel XE#7136]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7136
[Intel XE#7138]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7138
[Intel XE#7178]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7178
[Intel XE#7179]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7179
[Intel XE#7283]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7283
[Intel XE#7304]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7304
[Intel XE#7308]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7308
[Intel XE#7330]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7330
[Intel XE#7342]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7342
[Intel XE#7343]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7343
[Intel XE#7345]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7345
[Intel XE#7351]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7351
[Intel XE#7355]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7355
[Intel XE#7356]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7356
[Intel XE#7358]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7358
[Intel XE#7369]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7369
[Intel XE#7370]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7370
[Intel XE#7372]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7372
[Intel XE#7376]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7376
[Intel XE#7382]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7382
[Intel XE#7399]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7399
[Intel XE#7422]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7422
[Intel XE#7426]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7426
[Intel XE#7437]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7437
[Intel XE#7467]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7467
[Intel XE#7482]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7482
[Intel XE#7571]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7571
[Intel XE#7590]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7590
[Intel XE#7591]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7591
[Intel XE#7636]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7636
[Intel XE#7642]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7642
[Intel XE#7679]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7679
[Intel XE#7760]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7760
[Intel XE#7793]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7793
[Intel XE#7865]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7865
[Intel XE#7866]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7866
[Intel XE#7892]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7892
[Intel XE#7893]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7893
[Intel XE#7905]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7905
[Intel XE#7915]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7915
[Intel XE#7935]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7935
[Intel XE#870]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/870
[Intel XE#944]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/944
Build changes
-------------
* Linux: xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d -> xe-pw-165914v4
IGT_8917: 65d691069f26fc2a42c79e2364241320b85d48bc @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5081-d4e758a33a21b1ff270bb6fa2ffd9210353eb76d: d4e758a33a21b1ff270bb6fa2ffd9210353eb76d
xe-pw-165914v4: 165914v4
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-165914v4/index.html
[-- Attachment #2: Type: text/html, Size: 39117 bytes --]
^ permalink raw reply [flat|nested] 18+ messages in thread