Kconfig 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. #
  2. # Timer subsystem related configuration options
  3. #
  4. # Options selectable by arch Kconfig
  5. # Watchdog function for clocksources to detect instabilities
  6. config CLOCKSOURCE_WATCHDOG
  7. bool
  8. # Architecture has extra clocksource data
  9. config ARCH_CLOCKSOURCE_DATA
  10. bool
  11. # Platforms has a persistent clock
  12. config ALWAYS_USE_PERSISTENT_CLOCK
  13. bool
  14. default n
  15. # Timekeeping vsyscall support
  16. config GENERIC_TIME_VSYSCALL
  17. bool
  18. # Timekeeping vsyscall support
  19. config GENERIC_TIME_VSYSCALL_OLD
  20. bool
  21. # ktime_t scalar 64bit nsec representation
  22. config KTIME_SCALAR
  23. bool
  24. # Old style timekeeping
  25. config ARCH_USES_GETTIMEOFFSET
  26. bool
  27. # The generic clock events infrastructure
  28. config GENERIC_CLOCKEVENTS
  29. bool
  30. # Migration helper. Builds, but does not invoke
  31. config GENERIC_CLOCKEVENTS_BUILD
  32. bool
  33. default y
  34. depends on GENERIC_CLOCKEVENTS
  35. # Architecture can handle broadcast in a driver-agnostic way
  36. config ARCH_HAS_TICK_BROADCAST
  37. bool
  38. # Clockevents broadcasting infrastructure
  39. config GENERIC_CLOCKEVENTS_BROADCAST
  40. bool
  41. depends on GENERIC_CLOCKEVENTS
  42. # Automatically adjust the min. reprogramming time for
  43. # clock event device
  44. config GENERIC_CLOCKEVENTS_MIN_ADJUST
  45. bool
  46. # Generic update of CMOS clock
  47. config GENERIC_CMOS_UPDATE
  48. bool
  49. if GENERIC_CLOCKEVENTS
  50. menu "Timers subsystem"
  51. # Core internal switch. Selected by NO_HZ / HIGH_RES_TIMERS. This is
  52. # only related to the tick functionality. Oneshot clockevent devices
  53. # are supported independ of this.
  54. config TICK_ONESHOT
  55. bool
  56. config NO_HZ
  57. bool "Tickless System (Dynamic Ticks)"
  58. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  59. select TICK_ONESHOT
  60. help
  61. This option enables a tickless system: timer interrupts will
  62. only trigger on an as-needed basis both when the system is
  63. busy and when the system is idle.
  64. config NO_HZ_EXTENDED
  65. bool "Full dynticks system"
  66. depends on NO_HZ && RCU_USER_QS && VIRT_CPU_ACCOUNTING_GEN && RCU_NOCB_CPU && SMP
  67. select CONTEXT_TRACKING_FORCE
  68. help
  69. Adaptively try to shutdown the tick whenever possible, even when
  70. the CPU is running tasks. Typically this requires running a single
  71. task on the CPU. Chances for running tickless are maximized when
  72. the task mostly runs in userspace and has few kernel activity.
  73. You need to fill up the nohz_extended boot parameter with the
  74. desired range of dynticks CPUs.
  75. This is implemented at the expense of some overhead in user <-> kernel
  76. transitions: syscalls, exceptions and interrupts. Even when it's
  77. dynamically off.
  78. Say N.
  79. config HIGH_RES_TIMERS
  80. bool "High Resolution Timer Support"
  81. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  82. select TICK_ONESHOT
  83. help
  84. This option enables high resolution timer support. If your
  85. hardware is not capable then this option only increases
  86. the size of the kernel image.
  87. endmenu
  88. endif