]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
drm/panfrost: Clamp lock region to Bifrost minimum
authorAlyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Tue, 24 Aug 2021 17:30:27 +0000 (13:30 -0400)
committerSteven Price <steven.price@arm.com>
Wed, 25 Aug 2021 14:40:19 +0000 (15:40 +0100)
When locking a region, we currently clamp to a PAGE_SIZE as the minimum
lock region. While this is valid for Midgard, it is invalid for Bifrost,
where the minimum locking size is 8x larger than the 4k page size. Add a
hardware definition for the minimum lock region size (corresponding to
KBASE_LOCK_REGION_MIN_SIZE_LOG2 in kbase) and respect it.

Signed-off-by: Alyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Tested-by: Chris Morgan <macromorgan@hotmail.com>
Reviewed-by: Steven Price <steven.price@arm.com>
Reviewed-by: Rob Herring <robh@kernel.org>
Cc: <stable@vger.kernel.org>
Signed-off-by: Steven Price <steven.price@arm.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210824173028.7528-4-alyssa.rosenzweig@collabora.com
drivers/gpu/drm/panfrost/panfrost_mmu.c
drivers/gpu/drm/panfrost/panfrost_regs.h

index 3a795273e505390a9421ee8c44bc09eb341fca92..dfe5f1d2976367e71248ac7f3b044ecf6803387a 100644 (file)
@@ -66,7 +66,7 @@ static void lock_region(struct panfrost_device *pfdev, u32 as_nr,
        /* The size is encoded as ceil(log2) minus(1), which may be calculated
         * with fls. The size must be clamped to hardware bounds.
         */
-       size = max_t(u64, size, PAGE_SIZE);
+       size = max_t(u64, size, AS_LOCK_REGION_MIN_SIZE);
        region_width = fls64(size - 1) - 1;
        region |= region_width;
 
index 1940ff86e49ad7ad8b470571d8b983eb72026d72..6c5a11ef1ee87f0c829cb49aae2f93fcd052cd9b 100644 (file)
 #define AS_FAULTSTATUS_ACCESS_TYPE_READ                (0x2 << 8)
 #define AS_FAULTSTATUS_ACCESS_TYPE_WRITE       (0x3 << 8)
 
+#define AS_LOCK_REGION_MIN_SIZE                 (1ULL << 15)
+
 #define gpu_write(dev, reg, data) writel(data, dev->iomem + reg)
 #define gpu_read(dev, reg) readl(dev->iomem + reg)