Patch "drm: test: Fix 32-bit issue in drm_buddy_test" has been added to the 6.2-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    drm: test: Fix 32-bit issue in drm_buddy_test

to the 6.2-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     drm-test-fix-32-bit-issue-in-drm_buddy_test.patch
and it can be found in the queue-6.2 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 622ca6d7d202e95669ad77e49fc88abe8779f927
Author: David Gow <davidgow@xxxxxxxxxx>
Date:   Wed Mar 29 14:55:34 2023 +0800

    drm: test: Fix 32-bit issue in drm_buddy_test
    
    [ Upstream commit 25bbe844ef5c4fb4d7d8dcaa0080f922b7cd3a16 ]
    
    The drm_buddy_test KUnit tests verify that returned blocks have sizes
    which are powers of two using is_power_of_2(). However, is_power_of_2()
    operations on a 'long', but the block size is a u64. So on systems where
    long is 32-bit, this can sometimes fail even on correctly sized blocks.
    
    This only reproduces randomly, as the parameters passed to the buddy
    allocator in this test are random. The seed 0xb2e06022 reproduced it
    fine here.
    
    For now, just hardcode an is_power_of_2() implementation using
    x & (x - 1).
    
    Signed-off-by: David Gow <davidgow@xxxxxxxxxx>
    Acked-by: Christian König <christian.koenig@xxxxxxx>
    Reviewed-by: Maíra Canal <mcanal@xxxxxxxxxx>
    Reviewed-by: Arunpravin Paneer Selvam <arunpravin.paneerselvam@xxxxxxx>
    Link: https://patchwork.freedesktop.org/patch/msgid/20230329065532.2122295-2-davidgow@xxxxxxxxxx
    Signed-off-by: Christian König <christian.koenig@xxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/gpu/drm/tests/drm_buddy_test.c b/drivers/gpu/drm/tests/drm_buddy_test.c
index f8ee714df3967..09ee6f6af896b 100644
--- a/drivers/gpu/drm/tests/drm_buddy_test.c
+++ b/drivers/gpu/drm/tests/drm_buddy_test.c
@@ -89,7 +89,8 @@ static int check_block(struct kunit *test, struct drm_buddy *mm,
 		err = -EINVAL;
 	}
 
-	if (!is_power_of_2(block_size)) {
+	/* We can't use is_power_of_2() for a u64 on 32-bit systems. */
+	if (block_size & (block_size - 1)) {
 		kunit_err(test, "block size not power of two\n");
 		err = -EINVAL;
 	}



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux