Kconfig 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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_COMMON / 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_COMMON
  57. bool
  58. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  59. select TICK_ONESHOT
  60. config NO_HZ
  61. bool "Tickless System (Dynamic Ticks)"
  62. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  63. select NO_HZ_COMMON
  64. help
  65. This option enables a tickless system: timer interrupts will
  66. only trigger on an as-needed basis both when the system is
  67. busy and when the system is idle.
  68. config NO_HZ_EXTENDED
  69. bool "Full dynticks system"
  70. # NO_HZ_COMMON dependency
  71. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  72. # RCU_USER_QS
  73. depends on HAVE_CONTEXT_TRACKING && SMP
  74. # RCU_NOCB_CPU dependency
  75. depends on TREE_RCU || TREE_PREEMPT_RCU
  76. depends on VIRT_CPU_ACCOUNTING_GEN
  77. select NO_HZ_COMMON
  78. select RCU_USER_QS
  79. select RCU_NOCB_CPU
  80. select CONTEXT_TRACKING_FORCE
  81. help
  82. Adaptively try to shutdown the tick whenever possible, even when
  83. the CPU is running tasks. Typically this requires running a single
  84. task on the CPU. Chances for running tickless are maximized when
  85. the task mostly runs in userspace and has few kernel activity.
  86. You need to fill up the nohz_extended boot parameter with the
  87. desired range of dynticks CPUs.
  88. This is implemented at the expense of some overhead in user <-> kernel
  89. transitions: syscalls, exceptions and interrupts. Even when it's
  90. dynamically off.
  91. Say N.
  92. config HIGH_RES_TIMERS
  93. bool "High Resolution Timer Support"
  94. depends on !ARCH_USES_GETTIMEOFFSET && GENERIC_CLOCKEVENTS
  95. select TICK_ONESHOT
  96. help
  97. This option enables high resolution timer support. If your
  98. hardware is not capable then this option only increases
  99. the size of the kernel image.
  100. endmenu
  101. endif