On Fri, Feb 23, 2018 at 12:28:51PM +0100, Daniel Lezcano wrote:
> On 23/02/2018 08:34, Viresh Kumar wrote:
> > On 21-02-18, 16:29, Daniel Lezcano wrote:

> [ ... ]
> 
> >> +static s64 cpuidle_cooling_runtime(struct cpuidle_cooling_device 
> >> *idle_cdev)
> >> +{
> >> +  s64 next_wakeup;
> >> +  int state = idle_cdev->state;
> >> +
> >> +  /*
> >> +   * The function must never be called when there is no
> >> +   * mitigation because:
> >> +   * - that does not make sense
> >> +   * - we end up with a division by zero
> >> +   */
> >> +  BUG_ON(!state);
> > 
> > As there is no locking in place, we can surely hit this case. What if
> > the state changed to 0 right before this routine was called ?
> > 
> > I would suggest we should just return 0 in that case and get away with
> > the BUG_ON().

Here if 'state' equals to 0 and we return 0, then the return value will
be same with when 'state' = 100; this lets the return value confused.

I think for 'state' = 0, should we return -1 so indicate the hrtimer
will not be set for this case?

Thanks,
Leo Yan

Reply via email to