Hi Qiao,

Thank you for the patch! Yet something to improve:

[auto build test ERROR on tip/timers/nohz]
[also build test ERROR on v4.15]
[if your patch is applied to the wrong git tree, please drop us a note to help 
improve the system]

url:    
https://github.com/0day-ci/linux/commits/Qiao-Zhou/tick-broadcast-set-next-event-of-bc-to-KTIME_MAX/20180205-093126
config: x86_64-randconfig-x017-201805 (attached as .config)
compiler: gcc-7 (Debian 7.2.0-12) 7.2.1 20171025
reproduce:
        # save the attached .config to linux build tree
        make ARCH=x86_64 

All errors (new ones prefixed by >>):

   kernel/time/tick-broadcast.c: In function 'tick_handle_oneshot_broadcast':
>> kernel/time/tick-broadcast.c:669:18: error: request for member 'tv64' in 
>> something not a structure or union
      dev->next_event.tv64 = KTIME_MAX;
                     ^

vim +/tv64 +669 kernel/time/tick-broadcast.c

   595  
   596  /*
   597   * Handle oneshot mode broadcasting
   598   */
   599  static void tick_handle_oneshot_broadcast(struct clock_event_device 
*dev)
   600  {
   601          struct tick_device *td;
   602          ktime_t now, next_event;
   603          int cpu, next_cpu = 0;
   604          bool bc_local;
   605  
   606          raw_spin_lock(&tick_broadcast_lock);
   607          dev->next_event = KTIME_MAX;
   608          next_event = KTIME_MAX;
   609          cpumask_clear(tmpmask);
   610          now = ktime_get();
   611          /* Find all expired events */
   612          for_each_cpu(cpu, tick_broadcast_oneshot_mask) {
   613                  td = &per_cpu(tick_cpu_device, cpu);
   614                  if (td->evtdev->next_event <= now) {
   615                          cpumask_set_cpu(cpu, tmpmask);
   616                          /*
   617                           * Mark the remote cpu in the pending mask, so
   618                           * it can avoid reprogramming the cpu local
   619                           * timer in tick_broadcast_oneshot_control().
   620                           */
   621                          cpumask_set_cpu(cpu, 
tick_broadcast_pending_mask);
   622                  } else if (td->evtdev->next_event < next_event) {
   623                          next_event = td->evtdev->next_event;
   624                          next_cpu = cpu;
   625                  }
   626          }
   627  
   628          /*
   629           * Remove the current cpu from the pending mask. The event is
   630           * delivered immediately in tick_do_broadcast() !
   631           */
   632          cpumask_clear_cpu(smp_processor_id(), 
tick_broadcast_pending_mask);
   633  
   634          /* Take care of enforced broadcast requests */
   635          cpumask_or(tmpmask, tmpmask, tick_broadcast_force_mask);
   636          cpumask_clear(tick_broadcast_force_mask);
   637  
   638          /*
   639           * Sanity check. Catch the case where we try to broadcast to
   640           * offline cpus.
   641           */
   642          if (WARN_ON_ONCE(!cpumask_subset(tmpmask, cpu_online_mask)))
   643                  cpumask_and(tmpmask, tmpmask, cpu_online_mask);
   644  
   645          /*
   646           * Wakeup the cpus which have an expired event.
   647           */
   648          bc_local = tick_do_broadcast(tmpmask);
   649  
   650          /*
   651           * Two reasons for reprogram:
   652           *
   653           * - The global event did not expire any CPU local
   654           * events. This happens in dyntick mode, as the maximum PIT
   655           * delta is quite small.
   656           *
   657           * - There are pending events on sleeping CPUs which were not
   658           * in the event mask
   659           */
   660          if (next_event != KTIME_MAX)
   661                  tick_broadcast_set_event(dev, next_cpu, next_event);
   662          else
   663                  /*
   664                   * not program broadcast timer, but set the value to 
show that
   665                   * the next event is not set, which is used in
   666                   * __tick_broadcast_oneshot_control in idle 
tick_broadcast
   667                   * enter/exit control flow.
   668                   */
 > 669                  dev->next_event.tv64 = KTIME_MAX;
   670  
   671          raw_spin_unlock(&tick_broadcast_lock);
   672  
   673          if (bc_local) {
   674                  td = this_cpu_ptr(&tick_cpu_device);
   675                  td->evtdev->event_handler(td->evtdev);
   676          }
   677  }
   678  

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation

Attachment: .config.gz
Description: application/gzip

Reply via email to