blob: 915b2af160c16d65263a237cb46e0e1a3f19187f [file] [log] [blame]
Thomas Choufb798b12015-10-09 13:46:34 +08001menu "Timer Support"
2
3config TIMER
Bin Meng8a7b8642015-11-13 00:11:14 -08004 bool "Enable driver model for timer drivers"
Thomas Choufb798b12015-10-09 13:46:34 +08005 depends on DM
6 help
Bin Meng8a7b8642015-11-13 00:11:14 -08007 Enable driver model for timer access. It uses the same API as
8 lib/time.c, but now implemented by the uclass. The first timer
Thomas Choufb798b12015-10-09 13:46:34 +08009 will be used. The timer is usually a 32 bits free-running up
10 counter. There may be no real tick, and no timer interrupt.
11
Philipp Tomsich4fac4ea2017-07-28 17:38:42 +020012config SPL_TIMER
13 bool "Enable driver model for timer drivers in SPL"
14 depends on TIMER && SPL
15 help
16 Enable support for timer drivers in SPL. These can be used to get
17 a timer value when in SPL, or perhaps for implementing a delay
18 function. This enables the drivers in drivers/timer as part of an
19 SPL build.
20
21config TPL_TIMER
22 bool "Enable driver model for timer drivers in TPL"
23 depends on TIMER && TPL
24 help
25 Enable support for timer drivers in TPL. These can be used to get
26 a timer value when in TPL, or perhaps for implementing a delay
27 function. This enables the drivers in drivers/timer as part of an
28 TPL build.
29
Simon Glasse7ca7da2022-04-30 00:56:53 -060030config VPL_TIMER
31 bool "Enable driver model for timer drivers in VPL"
32 depends on TIMER && VPL
33 default y if TPL_TIMER
34 help
35 Enable support for timer drivers in VPL. These can be used to get
36 a timer value when in VPL, or perhaps for implementing a delay
37 function. This enables the drivers in drivers/timer as part of an
38 TPL build.
39
Simon Glass32f6c172016-02-24 09:14:49 -070040config TIMER_EARLY
41 bool "Allow timer to be used early in U-Boot"
42 depends on TIMER
Simon Glass6abd89b2018-09-02 17:02:24 -060043 # initr_bootstage() requires a timer and is called before initr_dm()
44 # so only the early timer is available
45 default y if X86 && BOOTSTAGE
Simon Glass32f6c172016-02-24 09:14:49 -070046 help
47 In some cases the timer must be accessible before driver model is
48 active. Examples include when using CONFIG_TRACE to trace U-Boot's
49 execution before driver model is set up. Enable this option to
50 use an early timer. These functions must be supported by your timer
51 driver: timer_early_get_count() and timer_early_get_rate().
52
Thomas Chou221d2ac2015-10-22 22:28:53 +080053config ALTERA_TIMER
Bin Meng8a7b8642015-11-13 00:11:14 -080054 bool "Altera timer support"
Thomas Chou221d2ac2015-10-22 22:28:53 +080055 depends on TIMER
56 help
Bin Meng8a7b8642015-11-13 00:11:14 -080057 Select this to enable a timer for Altera devices. Please find
Thomas Chou221d2ac2015-10-22 22:28:53 +080058 details on the "Embedded Peripherals IP User Guide" of Altera.
59
Sean Anderson5a238652020-10-25 21:46:57 -040060config ANDES_PLMT_TIMER
Sean Anderson5abf1f32020-10-25 21:46:56 -040061 bool
62 depends on RISCV_MMODE || SPL_RISCV_MMODE
63 help
64 The Andes PLMT block holds memory-mapped mtime register
65 associated with timer tick.
66
Bin Meng19f88b22018-10-10 22:07:02 -070067config ARC_TIMER
68 bool "ARC timer support"
69 depends on TIMER && ARC && CLK
70 help
71 Select this to enable built-in ARC timers.
72 ARC cores may have up to 2 built-in timers: timer0 and timer1,
73 usually at least one of them exists. Either of them is supported
74 in U-Boot.
75
Stefan Herbrechtsmeier10ff2882022-08-05 08:16:28 +020076config ARM_TWD_TIMER
77 bool "ARM timer watchdog (TWD) timer support"
78 depends on TIMER && CLK
79 help
80 Select this to enable support for the ARM global timer watchdog timer.
81
Bin Meng19f88b22018-10-10 22:07:02 -070082config AST_TIMER
83 bool "Aspeed ast2400/ast2500 timer support"
84 depends on TIMER
85 default y if ARCH_ASPEED
86 help
87 Select this to enable timer for Aspeed ast2400/ast2500 devices.
88 This is a simple sys timer driver, it is compatible with lib/time.c,
89 but does not support any interrupts. Even though SoC has 8 hardware
90 counters, they are all treated as a single device by this driver.
91 This is mostly because they all share several registers which
92 makes it difficult to completely separate them.
93
94config ATCPIT100_TIMER
95 bool "ATCPIT100 timer support"
96 depends on TIMER
97 help
98 Select this to enable a ATCPIT100 timer which will be embedded
99 in AE3XX, AE250 boards.
100
Wenyou.Yang@microchip.comce8a36f2017-08-15 17:40:26 +0800101config ATMEL_PIT_TIMER
102 bool "Atmel periodic interval timer support"
103 depends on TIMER
104 help
105 Select this to enable a periodic interval timer for Atmel devices,
106 it is designed to offer maximum accuracy and efficient management,
107 even for systems with long response time.
108
Eugen Hristev59d62892022-04-04 11:35:51 +0300109config SPL_ATMEL_PIT_TIMER
110 bool "Atmel periodic interval timer support in SPL"
111 depends on SPL_TIMER
112 help
113 Select this to enable a periodic interval timer for Atmel devices,
114 it is designed to offer maximum accuracy and efficient management,
115 even for systems with long response time.
116 Select this to be available in SPL.
117
Clément Léger7e5c11b2022-03-31 10:55:06 +0200118config ATMEL_TCB_TIMER
119 bool "Atmel timer counter support"
120 depends on TIMER
121 depends on ARCH_AT91
122 help
123 Select this to enable the use of the timer counter as a monotonic
124 counter.
125
Eugen Hristev118141e2022-04-04 11:35:50 +0300126config SPL_ATMEL_TCB_TIMER
127 bool "Atmel timer counter support in SPL"
128 depends on SPL_TIMER
129 depends on ARCH_AT91
130 help
131 Select this to enable the use of the timer counter as a monotonic
132 counter in SPL.
133
Michal Simekc3caac52018-04-17 13:40:46 +0200134config CADENCE_TTC_TIMER
135 bool "Cadence TTC (Triple Timer Counter)"
136 depends on TIMER
137 help
138 Enables support for the cadence ttc driver. This driver is present
139 on Xilinx Zynq and ZynqMP SoCs.
140
Marek Vasut442c0f12018-08-18 15:58:32 +0200141config DESIGNWARE_APB_TIMER
142 bool "Designware APB Timer"
143 depends on TIMER
144 help
145 Enables support for the Designware APB Timer driver. This timer is
146 present on Altera SoCFPGA SoCs.
147
Sergei Antonov4803f1d2023-02-13 20:34:36 +0300148config FTTMR010_TIMER
149 bool "Faraday Technology timer support"
150 depends on TIMER
151 help
152 Select this to enable support for the timer found on
153 devices using Faraday Technology's IP.
154
Nick Hawkins3cd8cfb2022-06-08 16:21:35 -0500155config GXP_TIMER
156 bool "HPE GXP Timer"
157 depends on TIMER
158 help
159 Enables support for the GXP Timer driver. This timer is
160 present on HPE GXP SoCs.
161
Bin Meng19f88b22018-10-10 22:07:02 -0700162config MPC83XX_TIMER
163 bool "MPC83xx timer support"
164 depends on TIMER
Bin Mengb2aa4c52015-11-13 00:11:24 -0800165 help
Bin Meng19f88b22018-10-10 22:07:02 -0700166 Select this to enable support for the timer found on
167 devices based on the MPC83xx family of SoCs.
Bin Mengb2aa4c52015-11-13 00:11:24 -0800168
Marek Vasut6be61c62019-05-04 17:30:58 +0200169config RENESAS_OSTM_TIMER
170 bool "Renesas RZ/A1 R7S72100 OSTM Timer"
171 depends on TIMER
172 help
173 Enables support for the Renesas OSTM Timer driver.
174 This timer is present on Renesas RZ/A1 R7S72100 SoCs.
175
Bin Meng917d2b82021-07-28 12:00:22 +0800176config X86_TSC_TIMER_FREQ
177 int "x86 TSC timer frequency in Hz"
Bin Meng855e6572018-10-13 20:52:10 -0700178 depends on X86_TSC_TIMER
Bin Meng917d2b82021-07-28 12:00:22 +0800179 default 1000000000
Bin Meng855e6572018-10-13 20:52:10 -0700180 help
Bin Meng917d2b82021-07-28 12:00:22 +0800181 Sets the estimated CPU frequency in Hz when TSC is used as the
Bin Meng855e6572018-10-13 20:52:10 -0700182 early timer and the frequency can neither be calibrated via some
183 hardware ways, nor got from device tree at the time when device
184 tree is not available yet.
185
Stephan Gerhold7b0c1c52020-01-04 18:45:15 +0100186config NOMADIK_MTU_TIMER
187 bool "Nomadik MTU Timer"
188 depends on TIMER
189 help
190 Enables support for the Nomadik Multi Timer Unit (MTU),
191 used in ST-Ericsson Ux500 SoCs.
192 The MTU provides 4 decrementing free-running timers.
193 At the moment, only the first timer is used by the driver.
194
Jim Liu5cb640a2022-04-19 13:32:22 +0800195config NPCM_TIMER
196 bool "Nuvoton NPCM timer support"
197 depends on TIMER
198 help
199 Select this to enable a timer on Nuvoton NPCM SoCs.
200 NPCM timer module has 5 down-counting timers, only the first timer
201 is used to implement timer ops. No support for early timer and
202 boot timer.
203
Mugunthan V Nafae3702015-12-24 16:08:07 +0530204config OMAP_TIMER
205 bool "Omap timer support"
206 depends on TIMER
207 help
208 Select this to enable an timer for Omap devices.
209
Michael Wallef874e092022-08-17 21:37:51 +0200210config ORION_TIMER
211 bool "Orion timer support"
212 depends on TIMER
Stefan Roese70280f22022-09-15 16:20:37 +0200213 default y if ARCH_KIRKWOOD || (ARCH_MVEBU && ARMADA_32BIT)
214 select TIMER_EARLY if ARCH_MVEBU
Michael Wallef874e092022-08-17 21:37:51 +0200215 help
Stefan Roese70280f22022-09-15 16:20:37 +0200216 Select this to enable an timer for Orion and Armada devices
217 like Armada XP etc.
Michael Wallef874e092022-08-17 21:37:51 +0200218
Bin Meng25399032018-12-12 06:12:27 -0800219config RISCV_TIMER
220 bool "RISC-V timer support"
221 depends on TIMER && RISCV
222 help
Sean Anderson9baaaef2020-09-28 10:52:21 -0400223 Select this to enable support for a generic RISC-V S-Mode timer
224 driver.
Bin Meng25399032018-12-12 06:12:27 -0800225
Bin Meng19f88b22018-10-10 22:07:02 -0700226config ROCKCHIP_TIMER
227 bool "Rockchip timer support"
maxims@google.comf57bd002017-01-18 13:44:55 -0800228 depends on TIMER
maxims@google.comf57bd002017-01-18 13:44:55 -0800229 help
Bin Meng19f88b22018-10-10 22:07:02 -0700230 Select this to enable support for the timer found on
231 Rockchip devices.
232
233config SANDBOX_TIMER
234 bool "Sandbox timer support"
235 depends on SANDBOX && TIMER
236 help
237 Select this to enable an emulated timer for sandbox. It gets
238 time from host os.
maxims@google.comf57bd002017-01-18 13:44:55 -0800239
William Zhang38c26de2022-08-23 21:44:32 -0700240config ARM_GLOBAL_TIMER
241 bool "ARM Cortex A9 global timer support"
Patrice Chotard200a7992017-02-21 13:37:05 +0100242 depends on TIMER
William Zhang38c26de2022-08-23 21:44:32 -0700243 depends on ARM
Patrice Chotard200a7992017-02-21 13:37:05 +0100244 default y if ARCH_STI
245 help
William Zhang38c26de2022-08-23 21:44:32 -0700246 Select this to enable global timer found on ARM Cortex A9
247 based devices.
Patrice Chotard200a7992017-02-21 13:37:05 +0100248
Andre Przywara31ab0fd2022-10-20 23:10:23 +0100249config SP804_TIMER
250 bool "ARM SP804 timer support"
251 depends on TIMER
252 help
253 ARM SP804 dual timer IP support
254
Patrice Chotardfdfefdc2018-02-07 10:44:45 +0100255config STM32_TIMER
Bin Meng19f88b22018-10-10 22:07:02 -0700256 bool "STM32 timer support"
Patrice Chotardfdfefdc2018-02-07 10:44:45 +0100257 depends on TIMER
258 help
259 Select this to enable support for the timer found on
260 STM32 devices.
261
Svyatoslav Ryhel4f89aa92023-02-01 10:53:02 +0200262config TEGRA_TIMER
263 bool "Tegra timer support"
264 depends on TIMER
265 select TIMER_EARLY
266 help
267 Select this to enable support for the timer found on
268 Tegra devices.
269
Bin Meng19f88b22018-10-10 22:07:02 -0700270config X86_TSC_TIMER
271 bool "x86 Time-Stamp Counter (TSC) timer support"
272 depends on TIMER && X86
Mario Six3c516552018-08-06 10:23:38 +0200273 help
Bin Meng19f88b22018-10-10 22:07:02 -0700274 Select this to enable Time-Stamp Counter (TSC) timer for x86.
Mario Six3c516552018-08-06 10:23:38 +0200275
Simon Glassd3edd422019-12-06 21:41:49 -0700276config X86_TSC_READ_BASE
277 bool "Read the TSC timer base on start-up"
278 depends on X86_TSC_TIMER
279 help
280 On x86 platforms the TSC timer tick starts at the value 0 on reset.
281 This it makes no sense to read the timer on boot and use that as the
282 base, since we will miss some time taken to load U-Boot, etc. This
283 delay is controlled by the SoC and we cannot reduce it, but for
284 bootstage we want to record the time since reset as accurately as
285 possible.
286
287 The only exception is when U-Boot is used as a secondary bootloader,
288 where this option should be enabled.
289
Simon Glassbba203e2019-12-06 21:41:50 -0700290config TPL_X86_TSC_TIMER_NATIVE
291 bool "x86 TSC timer uses native calibration"
292 depends on TPL && X86_TSC_TIMER
293 help
294 Selects native timer calibration for TPL and don't include the other
295 methods in the code. This helps to reduce code size in TPL and works
296 on fairly modern Intel chips. Code-size reductions is about 700
297 bytes.
298
developer4a347352018-11-15 10:07:56 +0800299config MTK_TIMER
300 bool "MediaTek timer support"
301 depends on TIMER
302 help
303 Select this to enable support for the timer found on
304 MediaTek devices.
305
Claudiu Beznea5669c3d2020-09-07 18:36:33 +0300306config MCHP_PIT64B_TIMER
307 bool "Microchip 64-bit periodic interval timer support"
308 depends on TIMER
309 help
310 Select this to enable support for Microchip 64-bit periodic
311 interval timer.
312
Giulio Benetti9aed42b2021-05-13 12:18:31 +0200313config IMX_GPT_TIMER
314 bool "NXP i.MX GPT timer support"
315 depends on TIMER
316 help
317 Select this to enable support for the timer found on
318 NXP i.MX devices.
319
Michal Simeke8e52772022-06-24 14:16:32 +0200320config XILINX_TIMER
321 bool "Xilinx timer support"
322 depends on TIMER
323 select REGMAP
Michal Simek8d2bea42022-06-23 13:08:30 +0200324 select SPL_REGMAP if SPL
Michal Simeke8e52772022-06-24 14:16:32 +0200325 help
326 Select this to enable support for the timer found on
327 any Xilinx boards (axi timer).
328
Thomas Choufb798b12015-10-09 13:46:34 +0800329endmenu