Linux ARM-MSM sub-architecture
 help / color / mirror / Atom feed
From: Dan Carpenter <dan.carpenter@linaro.org>
To: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Cc: linux-arm-msm@vger.kernel.org
Subject: [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver
Date: Thu, 7 Aug 2025 18:58:09 +0300	[thread overview]
Message-ID: <aJTNEQsRFjrFknG9@stanley.mountain> (raw)

Hello Krzysztof Kozlowski,

Commit b9c2ae6cac40 ("soc: qcom: icc-bwmon: Add bandwidth monitoring
driver") from Jul 4, 2022 (linux-next), leads to the following Smatch
static checker warning:

	drivers/soc/qcom/icc-bwmon.c:693 bwmon_intr_thread()
	error: 'target_opp' dereferencing possible ERR_PTR()

drivers/soc/qcom/icc-bwmon.c
    645 static irqreturn_t bwmon_intr_thread(int irq, void *dev_id)
    646 {
    647         struct icc_bwmon *bwmon = dev_id;
    648         unsigned int irq_enable = 0;
    649         struct dev_pm_opp *opp, *target_opp;
    650         unsigned int bw_kbps, up_kbps, down_kbps, meas_kbps;
    651 
    652         bw_kbps = bwmon->target_kbps;
    653         meas_kbps = bwmon->target_kbps;
    654 
    655         target_opp = dev_pm_opp_find_bw_ceil(bwmon->dev, &bw_kbps, 0);
    656         if (IS_ERR(target_opp) && PTR_ERR(target_opp) == -ERANGE)
    657                 target_opp = dev_pm_opp_find_bw_floor(bwmon->dev, &bw_kbps, 0);

Smatch thinks both dev_pm_opp_find_bw_ceil() and dev_pm_opp_find_bw_floor()
can return error pointers.

    658 
    659         bwmon->target_kbps = bw_kbps;
    660 
    661         bw_kbps--;
    662         opp = dev_pm_opp_find_bw_floor(bwmon->dev, &bw_kbps, 0);
    663         if (IS_ERR(opp) && PTR_ERR(opp) == -ERANGE)
    664                 down_kbps = bwmon->target_kbps;
    665         else
    666                 down_kbps = bw_kbps;
    667 
    668         up_kbps = bwmon->target_kbps + 1;
    669 
    670         if (bwmon->target_kbps >= bwmon->max_bw_kbps)
    671                 irq_enable = BIT(1);
    672         else if (bwmon->target_kbps <= bwmon->min_bw_kbps)
    673                 irq_enable = BIT(3);
    674         else
    675                 irq_enable = BWMON_IRQ_ENABLE_MASK;
    676 
    677         bwmon_set_threshold(bwmon, bwmon->regs[F_THRESHOLD_HIGH],
    678                             up_kbps);
    679         bwmon_set_threshold(bwmon, bwmon->regs[F_THRESHOLD_MED],
    680                             down_kbps);
    681         bwmon_clear_counters(bwmon, false);
    682         bwmon_clear_irq(bwmon);
    683         bwmon_enable(bwmon, irq_enable);
    684 
    685         trace_qcom_bwmon_update(dev_name(bwmon->dev), meas_kbps, up_kbps, down_kbps);
    686         if (bwmon->target_kbps == bwmon->current_kbps)
    687                 goto out;
    688 
    689         dev_pm_opp_set_opp(bwmon->dev, target_opp);
    690         bwmon->current_kbps = bwmon->target_kbps;
    691 
    692 out:
--> 693         dev_pm_opp_put(target_opp);
    694         if (!IS_ERR(opp))
    695                 dev_pm_opp_put(opp);
    696 
    697         return IRQ_HANDLED;
    698 }

regards,
dan carpenter

             reply	other threads:[~2025-08-07 15:58 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-08-07 15:58 Dan Carpenter [this message]
2025-08-14  6:19 ` [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver Krzysztof Kozlowski

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=aJTNEQsRFjrFknG9@stanley.mountain \
    --to=dan.carpenter@linaro.org \
    --cc=krzysztof.kozlowski@linaro.org \
    --cc=linux-arm-msm@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox