MIPS: eBPF: Fix icache flush end address
[linux/fpc-iii.git] / drivers / clocksource / Kconfig
blobd9c8a779dd7d6c4ed67ba0ce157afad373637455
1 menu "Clock Source drivers"
2         depends on GENERIC_CLOCKEVENTS
4 config TIMER_OF
5         bool
6         select TIMER_PROBE
8 config TIMER_ACPI
9         bool
10         select TIMER_PROBE
12 config TIMER_PROBE
13         bool
15 config CLKSRC_I8253
16         bool
18 config CLKEVT_I8253
19         bool
21 config I8253_LOCK
22         bool
24 config OMAP_DM_TIMER
25         bool
27 config CLKBLD_I8253
28         def_bool y if CLKSRC_I8253 || CLKEVT_I8253 || I8253_LOCK
30 config CLKSRC_MMIO
31         bool
33 config BCM2835_TIMER
34         bool "BCM2835 timer driver" if COMPILE_TEST
35         select CLKSRC_MMIO
36         help
37           Enables the support for the BCM2835 timer driver.
39 config BCM_KONA_TIMER
40         bool "BCM mobile timer driver" if COMPILE_TEST
41         select CLKSRC_MMIO
42         help
43           Enables the support for the BCM Kona mobile timer driver.
45 config DIGICOLOR_TIMER
46         bool "Digicolor timer driver" if COMPILE_TEST
47         select CLKSRC_MMIO
48         depends on HAS_IOMEM
49         help
50           Enables the support for the digicolor timer driver.
52 config DW_APB_TIMER
53         bool "DW APB timer driver" if COMPILE_TEST
54         help
55           Enables the support for the dw_apb timer.
57 config DW_APB_TIMER_OF
58         bool
59         select DW_APB_TIMER
60         select TIMER_OF
62 config FTTMR010_TIMER
63         bool "Faraday Technology timer driver" if COMPILE_TEST
64         depends on HAS_IOMEM
65         select CLKSRC_MMIO
66         select TIMER_OF
67         select MFD_SYSCON
68         help
69           Enables support for the Faraday Technology timer block
70           FTTMR010.
72 config ROCKCHIP_TIMER
73         bool "Rockchip timer driver" if COMPILE_TEST
74         depends on ARM || ARM64
75         select TIMER_OF
76         select CLKSRC_MMIO
77         help
78           Enables the support for the rockchip timer driver.
80 config ARMADA_370_XP_TIMER
81         bool "Armada 370 and XP timer driver" if COMPILE_TEST
82         depends on ARM
83         select TIMER_OF
84         select CLKSRC_MMIO
85         help
86           Enables the support for the Armada 370 and XP timer driver.
88 config MESON6_TIMER
89         bool "Meson6 timer driver" if COMPILE_TEST
90         select CLKSRC_MMIO
91         help
92           Enables the support for the Meson6 timer driver.
94 config ORION_TIMER
95         bool "Orion timer driver" if COMPILE_TEST
96         depends on ARM
97         select TIMER_OF
98         select CLKSRC_MMIO
99         help
100           Enables the support for the Orion timer driver
102 config OWL_TIMER
103         bool "Owl timer driver" if COMPILE_TEST
104         select CLKSRC_MMIO
105         help
106           Enables the support for the Actions Semi Owl timer driver.
108 config SUN4I_TIMER
109         bool "Sun4i timer driver" if COMPILE_TEST
110         depends on HAS_IOMEM
111         select CLKSRC_MMIO
112         select TIMER_OF
113         help
114           Enables support for the Sun4i timer.
116 config SUN5I_HSTIMER
117         bool "Sun5i timer driver" if COMPILE_TEST
118         select CLKSRC_MMIO
119         depends on COMMON_CLK
120         help
121           Enables support the Sun5i timer.
123 config TEGRA_TIMER
124         bool "Tegra timer driver" if COMPILE_TEST
125         select CLKSRC_MMIO
126         depends on ARM
127         help
128           Enables support for the Tegra driver.
130 config VT8500_TIMER
131         bool "VT8500 timer driver" if COMPILE_TEST
132         depends on HAS_IOMEM
133         help
134           Enables support for the VT8500 driver.
136 config NPCM7XX_TIMER
137         bool "NPCM7xx timer driver" if COMPILE_TEST
138         depends on HAS_IOMEM
139         select CLKSRC_MMIO
140         help
141           Enable 24-bit TIMER0 and TIMER1 counters in the NPCM7xx architecture,
142           While TIMER0 serves as clockevent and TIMER1 serves as clocksource.
144 config CADENCE_TTC_TIMER
145         bool "Cadence TTC timer driver" if COMPILE_TEST
146         depends on COMMON_CLK
147         help
148           Enables support for the cadence ttc driver.
150 config ASM9260_TIMER
151         bool "ASM9260 timer driver" if COMPILE_TEST
152         select CLKSRC_MMIO
153         select TIMER_OF
154         help
155           Enables support for the ASM9260 timer.
157 config CLKSRC_NOMADIK_MTU
158         bool "Nomakdik clocksource driver" if COMPILE_TEST
159         depends on ARM
160         select CLKSRC_MMIO
161         help
162           Support for Multi Timer Unit. MTU provides access
163           to multiple interrupt generating programmable
164           32-bit free running decrementing counters.
166 config CLKSRC_NOMADIK_MTU_SCHED_CLOCK
167         bool
168         depends on CLKSRC_NOMADIK_MTU
169         help
170           Use the Multi Timer Unit as the sched_clock.
172 config CLKSRC_DBX500_PRCMU
173         bool "Clocksource PRCMU Timer" if COMPILE_TEST
174         depends on HAS_IOMEM
175         help
176           Use the always on PRCMU Timer as clocksource
178 config CLPS711X_TIMER
179         bool "Cirrus logic timer driver" if COMPILE_TEST
180         select CLKSRC_MMIO
181         help
182           Enables support for the Cirrus Logic PS711 timer.
184 config ATLAS7_TIMER
185         bool "Atlas7 timer driver" if COMPILE_TEST
186         select CLKSRC_MMIO
187         help
188           Enables support for the Atlas7 timer.
190 config MXS_TIMER
191         bool "Mxs timer driver" if COMPILE_TEST
192         select CLKSRC_MMIO
193         select STMP_DEVICE
194         help
195           Enables support for the Mxs timer.
197 config PRIMA2_TIMER
198         bool "Prima2 timer driver" if COMPILE_TEST
199         select CLKSRC_MMIO
200         help
201           Enables support for the Prima2 timer.
203 config U300_TIMER
204         bool "U300 timer driver" if COMPILE_TEST
205         depends on ARM
206         select CLKSRC_MMIO
207         help
208           Enables support for the U300 timer.
210 config NSPIRE_TIMER
211         bool "NSpire timer driver" if COMPILE_TEST
212         select CLKSRC_MMIO
213         help
214           Enables support for the Nspire timer.
216 config KEYSTONE_TIMER
217         bool "Keystone timer driver" if COMPILE_TEST
218         depends on ARM || ARM64
219         select CLKSRC_MMIO
220         help
221           Enables support for the Keystone timer.
223 config INTEGRATOR_AP_TIMER
224         bool "Integrator-ap timer driver" if COMPILE_TEST
225         select CLKSRC_MMIO
226         help
227           Enables support for the Integrator-ap timer.
229 config CLKSRC_DBX500_PRCMU_SCHED_CLOCK
230         bool "Clocksource PRCMU Timer sched_clock"
231         depends on (CLKSRC_DBX500_PRCMU && !CLKSRC_NOMADIK_MTU_SCHED_CLOCK)
232         default y
233         help
234           Use the always on PRCMU Timer as sched_clock
236 config CLKSRC_EFM32
237         bool "Clocksource for Energy Micro's EFM32 SoCs" if !ARCH_EFM32
238         depends on OF && ARM && (ARCH_EFM32 || COMPILE_TEST)
239         select CLKSRC_MMIO
240         default ARCH_EFM32
241         help
242           Support to use the timers of EFM32 SoCs as clock source and clock
243           event device.
245 config CLKSRC_LPC32XX
246         bool "Clocksource for LPC32XX" if COMPILE_TEST
247         depends on HAS_IOMEM
248         depends on ARM
249         select CLKSRC_MMIO
250         select TIMER_OF
251         help
252           Support for the LPC32XX clocksource.
254 config CLKSRC_PISTACHIO
255         bool "Clocksource for Pistachio SoC" if COMPILE_TEST
256         depends on HAS_IOMEM
257         select TIMER_OF
258         help
259           Enables the clocksource for the Pistachio SoC.
261 config CLKSRC_TI_32K
262         bool "Texas Instruments 32.768 Hz Clocksource" if COMPILE_TEST
263         depends on GENERIC_SCHED_CLOCK
264         select TIMER_OF if OF
265         help
266           This option enables support for Texas Instruments 32.768 Hz clocksource
267           available on many OMAP-like platforms.
269 config CLKSRC_NPS
270         bool "NPS400 clocksource driver" if COMPILE_TEST
271         depends on !PHYS_ADDR_T_64BIT
272         select CLKSRC_MMIO
273         select TIMER_OF if OF
274         help
275           NPS400 clocksource support.
276           Got 64 bit counter with update rate up to 1000MHz.
277           This counter is accessed via couple of 32 bit memory mapped registers.
279 config CLKSRC_STM32
280         bool "Clocksource for STM32 SoCs" if !ARCH_STM32
281         depends on OF && ARM && (ARCH_STM32 || COMPILE_TEST)
282         select CLKSRC_MMIO
283         select TIMER_OF
285 config CLKSRC_MPS2
286         bool "Clocksource for MPS2 SoCs" if COMPILE_TEST
287         depends on GENERIC_SCHED_CLOCK
288         select CLKSRC_MMIO
289         select TIMER_OF
291 config ARC_TIMERS
292         bool "Support for 32-bit TIMERn counters in ARC Cores" if COMPILE_TEST
293         depends on GENERIC_SCHED_CLOCK
294         select TIMER_OF
295         help
296           These are legacy 32-bit TIMER0 and TIMER1 counters found on all ARC cores
297           (ARC700 as well as ARC HS38).
298           TIMER0 serves as clockevent while TIMER1 provides clocksource
300 config ARC_TIMERS_64BIT
301         bool "Support for 64-bit counters in ARC HS38 cores" if COMPILE_TEST
302         depends on ARC_TIMERS
303         select TIMER_OF
304         help
305           This enables 2 different 64-bit timers: RTC (for UP) and GFRC (for SMP)
306           RTC is implemented inside the core, while GFRC sits outside the core in
307           ARConnect IP block. Driver automatically picks one of them for clocksource
308           as appropriate.
310 config ARM_ARCH_TIMER
311         bool
312         select TIMER_OF if OF
313         select TIMER_ACPI if ACPI
315 config ARM_ARCH_TIMER_EVTSTREAM
316         bool "Enable ARM architected timer event stream generation by default"
317         default y if ARM_ARCH_TIMER
318         depends on ARM_ARCH_TIMER
319         help
320           This option enables support by default for event stream generation
321           based on the ARM architected timer. It is used for waking up CPUs
322           executing the wfe instruction at a frequency represented as a
323           power-of-2 divisor of the clock rate. The behaviour can also be
324           overridden on the command line using the
325           clocksource.arm_arch_timer.evtstream parameter.
326           The main use of the event stream is wfe-based timeouts of userspace
327           locking implementations. It might also be useful for imposing timeout
328           on wfe to safeguard against any programming errors in case an expected
329           event is not generated.
330           This must be disabled for hardware validation purposes to detect any
331           hardware anomalies of missing events.
333 config ARM_ARCH_TIMER_OOL_WORKAROUND
334         bool
336 config FSL_ERRATUM_A008585
337         bool "Workaround for Freescale/NXP Erratum A-008585"
338         default y
339         depends on ARM_ARCH_TIMER && ARM64
340         select ARM_ARCH_TIMER_OOL_WORKAROUND
341         help
342           This option enables a workaround for Freescale/NXP Erratum
343           A-008585 ("ARM generic timer may contain an erroneous
344           value").  The workaround will only be active if the
345           fsl,erratum-a008585 property is found in the timer node.
347 config HISILICON_ERRATUM_161010101
348         bool "Workaround for Hisilicon Erratum 161010101"
349         default y
350         select ARM_ARCH_TIMER_OOL_WORKAROUND
351         depends on ARM_ARCH_TIMER && ARM64
352         help
353           This option enables a workaround for Hisilicon Erratum
354           161010101. The workaround will be active if the hisilicon,erratum-161010101
355           property is found in the timer node.
357 config ARM64_ERRATUM_858921
358         bool "Workaround for Cortex-A73 erratum 858921"
359         default y
360         select ARM_ARCH_TIMER_OOL_WORKAROUND
361         depends on ARM_ARCH_TIMER && ARM64
362         help
363           This option enables a workaround applicable to Cortex-A73
364           (all versions), whose counter may return incorrect values.
365           The workaround will be dynamically enabled when an affected
366           core is detected.
368 config ARM_GLOBAL_TIMER
369         bool "Support for the ARM global timer" if COMPILE_TEST
370         select TIMER_OF if OF
371         depends on ARM
372         help
373           This options enables support for the ARM global timer unit
375 config ARM_TIMER_SP804
376         bool "Support for Dual Timer SP804 module"
377         depends on GENERIC_SCHED_CLOCK && CLKDEV_LOOKUP
378         select CLKSRC_MMIO
379         select TIMER_OF if OF
381 config CLKSRC_ARM_GLOBAL_TIMER_SCHED_CLOCK
382         bool
383         depends on ARM_GLOBAL_TIMER
384         default y
385         help
386          Use ARM global timer clock source as sched_clock
388 config ARMV7M_SYSTICK
389         bool "Support for the ARMv7M system time" if COMPILE_TEST
390         select TIMER_OF if OF
391         select CLKSRC_MMIO
392         help
393           This options enables support for the ARMv7M system timer unit
395 config ATMEL_PIT
396         select TIMER_OF if OF
397         def_bool SOC_AT91SAM9 || SOC_SAMA5
399 config ATMEL_ST
400         bool "Atmel ST timer support" if COMPILE_TEST
401         depends on HAS_IOMEM
402         select TIMER_OF
403         select MFD_SYSCON
404         help
405           Support for the Atmel ST timer.
407 config CLKSRC_EXYNOS_MCT
408         bool "Exynos multi core timer driver" if COMPILE_TEST
409         depends on ARM || ARM64
410         help
411           Support for Multi Core Timer controller on Exynos SoCs.
413 config CLKSRC_SAMSUNG_PWM
414         bool "PWM timer driver for Samsung S3C, S5P" if COMPILE_TEST
415         depends on HAS_IOMEM
416         help
417           This is a new clocksource driver for the PWM timer found in
418           Samsung S3C, S5P and Exynos SoCs, replacing an earlier driver
419           for all devicetree enabled platforms. This driver will be
420           needed only on systems that do not have the Exynos MCT available.
422 config FSL_FTM_TIMER
423         bool "Freescale FlexTimer Module driver" if COMPILE_TEST
424         depends on HAS_IOMEM
425         select CLKSRC_MMIO
426         help
427           Support for Freescale FlexTimer Module (FTM) timer.
429 config VF_PIT_TIMER
430         bool
431         select CLKSRC_MMIO
432         help
433           Support for Period Interrupt Timer on Freescale Vybrid Family SoCs.
435 config OXNAS_RPS_TIMER
436         bool "Oxford Semiconductor OXNAS RPS Timers driver" if COMPILE_TEST
437         select TIMER_OF
438         select CLKSRC_MMIO
439         help
440           This enables support for the Oxford Semiconductor OXNAS RPS timers.
442 config SYS_SUPPORTS_SH_CMT
443         bool
445 config MTK_TIMER
446         bool "Mediatek timer driver" if COMPILE_TEST
447         depends on HAS_IOMEM
448         select TIMER_OF
449         select CLKSRC_MMIO
450         help
451           Support for Mediatek timer driver.
453 config SPRD_TIMER
454         bool "Spreadtrum timer driver" if EXPERT
455         depends on HAS_IOMEM
456         depends on (ARCH_SPRD || COMPILE_TEST)
457         default ARCH_SPRD
458         select TIMER_OF
459         help
460           Enables support for the Spreadtrum timer driver.
462 config SYS_SUPPORTS_SH_MTU2
463         bool
465 config SYS_SUPPORTS_SH_TMU
466         bool
468 config SYS_SUPPORTS_EM_STI
469         bool
471 config CLKSRC_JCORE_PIT
472         bool "J-Core PIT timer driver" if COMPILE_TEST
473         depends on OF
474         depends on HAS_IOMEM
475         select CLKSRC_MMIO
476         help
477           This enables build of clocksource and clockevent driver for
478           the integrated PIT in the J-Core synthesizable, open source SoC.
480 config SH_TIMER_CMT
481         bool "Renesas CMT timer driver" if COMPILE_TEST
482         depends on HAS_IOMEM
483         default SYS_SUPPORTS_SH_CMT
484         help
485           This enables build of a clocksource and clockevent driver for
486           the Compare Match Timer (CMT) hardware available in 16/32/48-bit
487           variants on a wide range of Mobile and Automotive SoCs from Renesas.
489 config SH_TIMER_MTU2
490         bool "Renesas MTU2 timer driver" if COMPILE_TEST
491         depends on HAS_IOMEM
492         default SYS_SUPPORTS_SH_MTU2
493         help
494           This enables build of a clockevent driver for the Multi-Function
495           Timer Pulse Unit 2 (MTU2) hardware available on SoCs from Renesas.
496           This hardware comes with 16 bit-timer registers.
498 config RENESAS_OSTM
499         bool "Renesas OSTM timer driver" if COMPILE_TEST
500         select CLKSRC_MMIO
501         help
502           Enables the support for the Renesas OSTM.
504 config SH_TIMER_TMU
505         bool "Renesas TMU timer driver" if COMPILE_TEST
506         depends on HAS_IOMEM
507         default SYS_SUPPORTS_SH_TMU
508         help
509           This enables build of a clocksource and clockevent driver for
510           the 32-bit Timer Unit (TMU) hardware available on a wide range
511           SoCs from Renesas.
513 config EM_TIMER_STI
514         bool "Renesas STI timer driver" if COMPILE_TEST
515         depends on HAS_IOMEM
516         default SYS_SUPPORTS_EM_STI
517         help
518           This enables build of a clocksource and clockevent driver for
519           the 48-bit System Timer (STI) hardware available on a SoCs
520           such as EMEV2 from former NEC Electronics.
522 config CLKSRC_QCOM
523         bool "Qualcomm MSM timer" if COMPILE_TEST
524         depends on ARM
525         select TIMER_OF
526         help
527           This enables the clocksource and the per CPU clockevent driver for the
528           Qualcomm SoCs.
530 config CLKSRC_VERSATILE
531         bool "ARM Versatile (Express) reference platforms clock source" if COMPILE_TEST
532         depends on GENERIC_SCHED_CLOCK && !ARCH_USES_GETTIMEOFFSET
533         select TIMER_OF
534         default y if MFD_VEXPRESS_SYSREG
535         help
536           This option enables clock source based on free running
537           counter available in the "System Registers" block of
538           ARM Versatile, RealView and Versatile Express reference
539           platforms.
541 config CLKSRC_MIPS_GIC
542         bool
543         depends on MIPS_GIC
544         select TIMER_OF
546 config CLKSRC_TANGO_XTAL
547         bool "Clocksource for Tango SoC" if COMPILE_TEST
548         depends on ARM
549         select TIMER_OF
550         select CLKSRC_MMIO
551         help
552           This enables the clocksource for Tango SoC
554 config CLKSRC_PXA
555         bool "Clocksource for PXA or SA-11x0 platform" if COMPILE_TEST
556         depends on HAS_IOMEM
557         select CLKSRC_MMIO
558         help
559           This enables OST0 support available on PXA and SA-11x0
560           platforms.
562 config H8300_TMR8
563         bool "Clockevent timer for the H8300 platform" if COMPILE_TEST
564         depends on HAS_IOMEM
565         help
566           This enables the 8 bits timer for the H8300 platform.
568 config H8300_TMR16
569         bool "Clockevent timer for the H83069 platform" if COMPILE_TEST
570         depends on HAS_IOMEM
571         help
572           This enables the 16 bits timer for the H8300 platform with the
573           H83069 cpu.
575 config H8300_TPU
576         bool "Clocksource for the H8300 platform" if COMPILE_TEST
577         depends on HAS_IOMEM
578         help
579           This enables the clocksource for the H8300 platform with the
580           H8S2678 cpu.
582 config CLKSRC_IMX_GPT
583         bool "Clocksource using i.MX GPT" if COMPILE_TEST
584         depends on ARM && CLKDEV_LOOKUP
585         select CLKSRC_MMIO
587 config CLKSRC_IMX_TPM
588         bool "Clocksource using i.MX TPM" if COMPILE_TEST
589         depends on ARM && CLKDEV_LOOKUP
590         select CLKSRC_MMIO
591         help
592           Enable this option to use IMX Timer/PWM Module (TPM) timer as
593           clocksource.
595 config CLKSRC_ST_LPC
596         bool "Low power clocksource found in the LPC" if COMPILE_TEST
597         select TIMER_OF if OF
598         depends on HAS_IOMEM
599         select CLKSRC_MMIO
600         help
601           Enable this option to use the Low Power controller timer
602           as clocksource.
604 config ATCPIT100_TIMER
605         bool "ATCPIT100 timer driver"
606         depends on NDS32 || COMPILE_TEST
607         depends on HAS_IOMEM
608         select TIMER_OF
609         default NDS32
610         help
611           This option enables support for the Andestech ATCPIT100 timers.
613 config RISCV_TIMER
614         bool "Timer for the RISC-V platform"
615         depends on RISCV
616         default y
617         select TIMER_PROBE
618         select TIMER_OF
619         help
620           This enables the per-hart timer built into all RISC-V systems, which
621           is accessed via both the SBI and the rdcycle instruction.  This is
622           required for all RISC-V systems.
624 config CSKY_MP_TIMER
625         bool "SMP Timer for the C-SKY platform" if COMPILE_TEST
626         depends on CSKY
627         select TIMER_OF
628         help
629           Say yes here to enable C-SKY SMP timer driver used for C-SKY SMP
630           system.
631           csky,mptimer is not only used in SMP system, it also could be used
632           single core system. It's not a mmio reg and it use mtcr/mfcr instruction.
634 config GX6605S_TIMER
635         bool "Gx6605s SOC system timer driver" if COMPILE_TEST
636         depends on CSKY
637         select CLKSRC_MMIO
638         select TIMER_OF
639         help
640           This option enables support for gx6605s SOC's timer.
642 endmenu