On 2017/10/14 9:01, Rafael J. Wysocki wrote:
> On Saturday, September 30, 2017 9:20:33 AM CEST Aubrey Li wrote:
>> Introduce irq timings output as a factor to predict the duration
>> of the coming idle
>>
>> @@ -342,13 +343,27 @@ void cpuidle_entry_end(void)
>>  void cpuidle_predict(void)
>>  {
>>      struct cpuidle_device *dev = cpuidle_get_device();
>> -    unsigned int overhead_threshold;
>> +    unsigned int idle_interval, overhead_threshold;
>> +    u64 now, next_evt;
>>  
>>      if (!dev)
>>              return;
>>  
>>      overhead_threshold = dev->idle_stat.overhead * sysctl_fast_idle_ratio;
>>  
>> +    /*
>> +     * check irq timings if the next event is coming soon
>> +     */
>> +    now = local_clock();
>> +    local_irq_disable();
>> +    next_evt = irq_timings_next_event(now);
>> +    local_irq_enable();
>> +    idle_interval = div_u64(next_evt - now, NSEC_PER_USEC);
> 
> Another division ...
> 
okay, will replace with >>10 if micro-second is agreed to be the comparing unit

Thanks,
-Aubrey

Reply via email to