]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
remoteproc: pru: Fix potential NULL pointer dereference in pru_rproc_set_ctable()
authorZhen Ni <zhen.ni@easystack.cn>
Tue, 23 Sep 2025 11:21:09 +0000 (19:21 +0800)
committerMathieu Poirier <mathieu.poirier@linaro.org>
Tue, 23 Sep 2025 17:49:58 +0000 (11:49 -0600)
pru_rproc_set_ctable() accessed rproc->priv before the IS_ERR_OR_NULL
check, which could lead to a null pointer dereference. Move the pru
assignment, ensuring we never dereference a NULL rproc pointer.

Fixes: 102853400321 ("remoteproc: pru: Add pru_rproc_set_ctable() function")
Cc: stable@vger.kernel.org
Signed-off-by: Zhen Ni <zhen.ni@easystack.cn>
Link: https://lore.kernel.org/r/20250923112109.1165126-1-zhen.ni@easystack.cn
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
drivers/remoteproc/pru_rproc.c

index 842e4b6cc5f9fcd9654683da9ffc15e594824c78..5e3eb7b86a0e34de34ca3abef1542f663183bf96 100644 (file)
@@ -340,7 +340,7 @@ EXPORT_SYMBOL_GPL(pru_rproc_put);
  */
 int pru_rproc_set_ctable(struct rproc *rproc, enum pru_ctable_idx c, u32 addr)
 {
-       struct pru_rproc *pru = rproc->priv;
+       struct pru_rproc *pru;
        unsigned int reg;
        u32 mask, set;
        u16 idx;
@@ -352,6 +352,7 @@ int pru_rproc_set_ctable(struct rproc *rproc, enum pru_ctable_idx c, u32 addr)
        if (!rproc->dev.parent || !is_pru_rproc(rproc->dev.parent))
                return -ENODEV;
 
+       pru = rproc->priv;
        /* pointer is 16 bit and index is 8-bit so mask out the rest */
        idx_mask = (c >= PRU_C28) ? 0xFFFF : 0xFF;