]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
irqchip/qcom-pdc: Tighten ioremap clamp to single DRV region size
authorMukesh Ojha <mukesh.ojha@oss.qualcomm.com>
Wed, 27 May 2026 09:54:24 +0000 (15:24 +0530)
committerThomas Gleixner <tglx@kernel.org>
Wed, 3 Jun 2026 16:27:05 +0000 (18:27 +0200)
The QCOM_PDC_SIZE constant (0x30000) was introduced to work around old
sm8150 DTs that described a too-small PDC register region, causing the
driver to silently expand the ioremap to cover three DRV regions. Now
that the preceding DT fixes have corrected all platforms to describe only
the APSS DRV region (0x10000), the oversized clamp is no longer needed.

Replace QCOM_PDC_SIZE with PDC_DRV_SIZE (0x10000) in the clamp so the
minimum mapped size matches a single DRV region. The clamp and warning
are intentionally kept to preserve backward compatibility with any old
DTs that may still describe a smaller region.

While at it, rename PDC_DRV_OFFSET to PDC_DRV_SIZE since the constant
represents the size of a DRV region and is used as both the ioremap
minimum size and the offset to the previous DRV region.

Signed-off-by: Mukesh Ojha <mukesh.ojha@oss.qualcomm.com>
Signed-off-by: Thomas Gleixner <tglx@kernel.org>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Link: https://patch.msgid.link/20260527095426.2324504-3-mukesh.ojha@oss.qualcomm.com
drivers/irqchip/qcom-pdc.c

index 5f0da15b6fc2ca3545fbe6d39272e4e73359df12..0b82306f8dd80533150150009647ab40927178df 100644 (file)
@@ -21,7 +21,7 @@
 #include <linux/types.h>
 
 #define PDC_MAX_GPIO_IRQS      256
-#define PDC_DRV_OFFSET         0x10000
+#define PDC_DRV_SIZE           0x10000
 
 /* Valid only on HW version < 3.2 */
 #define IRQ_ENABLE_BANK                0x10
@@ -357,7 +357,6 @@ static int pdc_setup_pin_mapping(struct device_node *np)
        return 0;
 }
 
-#define QCOM_PDC_SIZE 0x30000
 
 static int qcom_pdc_probe(struct platform_device *pdev, struct device_node *parent)
 {
@@ -371,7 +370,7 @@ static int qcom_pdc_probe(struct platform_device *pdev, struct device_node *pare
        if (of_address_to_resource(node, 0, &res))
                return -EINVAL;
 
-       res_size = max_t(resource_size_t, resource_size(&res), QCOM_PDC_SIZE);
+       res_size = max_t(resource_size_t, resource_size(&res), PDC_DRV_SIZE);
        if (res_size > resource_size(&res))
                pr_warn("%pOF: invalid reg size, please fix DT\n", node);
 
@@ -384,7 +383,7 @@ static int qcom_pdc_probe(struct platform_device *pdev, struct device_node *pare
         * region with the expected offset to preserve support for old DTs.
         */
        if (of_device_is_compatible(node, "qcom,x1e80100-pdc")) {
-               pdc_prev_base = ioremap(res.start - PDC_DRV_OFFSET, IRQ_ENABLE_BANK_MAX);
+               pdc_prev_base = ioremap(res.start - PDC_DRV_SIZE, IRQ_ENABLE_BANK_MAX);
                if (!pdc_prev_base) {
                        pr_err("%pOF: unable to map previous PDC DRV region\n", node);
                        return -ENXIO;