firmware: cs_dsp: Move lockdep asserts to avoid potential null pointer
authorCharles Keepax <ckeepax@opensource.cirrus.com>
Tue, 30 Nov 2021 10:28:42 +0000 (10:28 +0000)
committerMark Brown <broonie@kernel.org>
Tue, 30 Nov 2021 13:08:12 +0000 (13:08 +0000)
Move the lockdep asserts until after the ctl pointer has been checked
for NULL, to avoid potentially NULL pointer dereferences.

Fixes: fb2f364fb5b9 ("firmware: cs_dsp: Add lockdep asserts to interface functions")
Reported-by: kernel test robot <lkp@intel.com>
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20211130102842.26410-1-ckeepax@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/firmware/cirrus/cs_dsp.c

index 3814cbb..5af8171 100644 (file)
@@ -759,11 +759,11 @@ int cs_dsp_coeff_write_ctrl(struct cs_dsp_coeff_ctl *ctl,
 {
        int ret = 0;
 
-       lockdep_assert_held(&ctl->dsp->pwr_lock);
-
        if (!ctl)
                return -ENOENT;
 
+       lockdep_assert_held(&ctl->dsp->pwr_lock);
+
        if (len + off * sizeof(u32) > ctl->len)
                return -EINVAL;
 
@@ -827,11 +827,11 @@ int cs_dsp_coeff_read_ctrl(struct cs_dsp_coeff_ctl *ctl,
 {
        int ret = 0;
 
-       lockdep_assert_held(&ctl->dsp->pwr_lock);
-
        if (!ctl)
                return -ENOENT;
 
+       lockdep_assert_held(&ctl->dsp->pwr_lock);
+
        if (len + off * sizeof(u32) > ctl->len)
                return -EINVAL;