linux-arm-msm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver
@ 2025-08-07 15:58 Dan Carpenter
  2025-08-14  6:19 ` Krzysztof Kozlowski
  0 siblings, 1 reply; 2+ messages in thread
From: Dan Carpenter @ 2025-08-07 15:58 UTC (permalink / raw)
  To: Krzysztof Kozlowski; +Cc: linux-arm-msm

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

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver
  2025-08-07 15:58 [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver Dan Carpenter
@ 2025-08-14  6:19 ` Krzysztof Kozlowski
  0 siblings, 0 replies; 2+ messages in thread
From: Krzysztof Kozlowski @ 2025-08-14  6:19 UTC (permalink / raw)
  To: Dan Carpenter; +Cc: linux-arm-msm

On 07/08/2025 17:58, Dan Carpenter wrote:
> 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.
Indeed, thanks. I'll fix it.

Best regards,
Krzysztof

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-08-14  6:19 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-07 15:58 [bug report] soc: qcom: icc-bwmon: Add bandwidth monitoring driver Dan Carpenter
2025-08-14  6:19 ` Krzysztof Kozlowski

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).