blob: 68e90b8660b293c7224e0af97d542e2f05e9fb43 [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 Glass32f6c172016-02-24 09:14:49 -070030config TIMER_EARLY
31 bool "Allow timer to be used early in U-Boot"
32 depends on TIMER
Simon Glass6abd89b2018-09-02 17:02:24 -060033 # initr_bootstage() requires a timer and is called before initr_dm()
34 # so only the early timer is available
35 default y if X86 && BOOTSTAGE
Simon Glass32f6c172016-02-24 09:14:49 -070036 help
37 In some cases the timer must be accessible before driver model is
38 active. Examples include when using CONFIG_TRACE to trace U-Boot's
39 execution before driver model is set up. Enable this option to
40 use an early timer. These functions must be supported by your timer
41 driver: timer_early_get_count() and timer_early_get_rate().
42
Thomas Chou221d2ac2015-10-22 22:28:53 +080043config ALTERA_TIMER
Bin Meng8a7b8642015-11-13 00:11:14 -080044 bool "Altera timer support"
Thomas Chou221d2ac2015-10-22 22:28:53 +080045 depends on TIMER
46 help
Bin Meng8a7b8642015-11-13 00:11:14 -080047 Select this to enable a timer for Altera devices. Please find
Thomas Chou221d2ac2015-10-22 22:28:53 +080048 details on the "Embedded Peripherals IP User Guide" of Altera.
49
Sean Anderson5a238652020-10-25 21:46:57 -040050config ANDES_PLMT_TIMER
Sean Anderson5abf1f32020-10-25 21:46:56 -040051 bool
52 depends on RISCV_MMODE || SPL_RISCV_MMODE
53 help
54 The Andes PLMT block holds memory-mapped mtime register
55 associated with timer tick.
56
Bin Meng19f88b22018-10-10 22:07:02 -070057config ARC_TIMER
58 bool "ARC timer support"
59 depends on TIMER && ARC && CLK
60 help
61 Select this to enable built-in ARC timers.
62 ARC cores may have up to 2 built-in timers: timer0 and timer1,
63 usually at least one of them exists. Either of them is supported
64 in U-Boot.
65
66config AST_TIMER
67 bool "Aspeed ast2400/ast2500 timer support"
68 depends on TIMER
69 default y if ARCH_ASPEED
70 help
71 Select this to enable timer for Aspeed ast2400/ast2500 devices.
72 This is a simple sys timer driver, it is compatible with lib/time.c,
73 but does not support any interrupts. Even though SoC has 8 hardware
74 counters, they are all treated as a single device by this driver.
75 This is mostly because they all share several registers which
76 makes it difficult to completely separate them.
77
78config ATCPIT100_TIMER
79 bool "ATCPIT100 timer support"
80 depends on TIMER
81 help
82 Select this to enable a ATCPIT100 timer which will be embedded
83 in AE3XX, AE250 boards.
84
Wenyou.Yang@microchip.comce8a36f2017-08-15 17:40:26 +080085config ATMEL_PIT_TIMER
86 bool "Atmel periodic interval timer support"
87 depends on TIMER
88 help
89 Select this to enable a periodic interval timer for Atmel devices,
90 it is designed to offer maximum accuracy and efficient management,
91 even for systems with long response time.
92
Clément Léger7e5c11b2022-03-31 10:55:06 +020093config ATMEL_TCB_TIMER
94 bool "Atmel timer counter support"
95 depends on TIMER
96 depends on ARCH_AT91
97 help
98 Select this to enable the use of the timer counter as a monotonic
99 counter.
100
Eugen Hristev118141e2022-04-04 11:35:50 +0300101config SPL_ATMEL_TCB_TIMER
102 bool "Atmel timer counter support in SPL"
103 depends on SPL_TIMER
104 depends on ARCH_AT91
105 help
106 Select this to enable the use of the timer counter as a monotonic
107 counter in SPL.
108
Michal Simekc3caac52018-04-17 13:40:46 +0200109config CADENCE_TTC_TIMER
110 bool "Cadence TTC (Triple Timer Counter)"
111 depends on TIMER
112 help
113 Enables support for the cadence ttc driver. This driver is present
114 on Xilinx Zynq and ZynqMP SoCs.
115
Marek Vasut442c0f12018-08-18 15:58:32 +0200116config DESIGNWARE_APB_TIMER
117 bool "Designware APB Timer"
118 depends on TIMER
119 help
120 Enables support for the Designware APB Timer driver. This timer is
121 present on Altera SoCFPGA SoCs.
122
Bin Meng19f88b22018-10-10 22:07:02 -0700123config MPC83XX_TIMER
124 bool "MPC83xx timer support"
125 depends on TIMER
Bin Mengb2aa4c52015-11-13 00:11:24 -0800126 help
Bin Meng19f88b22018-10-10 22:07:02 -0700127 Select this to enable support for the timer found on
128 devices based on the MPC83xx family of SoCs.
Bin Mengb2aa4c52015-11-13 00:11:24 -0800129
Marek Vasut6be61c62019-05-04 17:30:58 +0200130config RENESAS_OSTM_TIMER
131 bool "Renesas RZ/A1 R7S72100 OSTM Timer"
132 depends on TIMER
133 help
134 Enables support for the Renesas OSTM Timer driver.
135 This timer is present on Renesas RZ/A1 R7S72100 SoCs.
136
Bin Meng917d2b82021-07-28 12:00:22 +0800137config X86_TSC_TIMER_FREQ
138 int "x86 TSC timer frequency in Hz"
Bin Meng855e6572018-10-13 20:52:10 -0700139 depends on X86_TSC_TIMER
Bin Meng917d2b82021-07-28 12:00:22 +0800140 default 1000000000
Bin Meng855e6572018-10-13 20:52:10 -0700141 help
Bin Meng917d2b82021-07-28 12:00:22 +0800142 Sets the estimated CPU frequency in Hz when TSC is used as the
Bin Meng855e6572018-10-13 20:52:10 -0700143 early timer and the frequency can neither be calibrated via some
144 hardware ways, nor got from device tree at the time when device
145 tree is not available yet.
146
Stephan Gerhold7b0c1c52020-01-04 18:45:15 +0100147config NOMADIK_MTU_TIMER
148 bool "Nomadik MTU Timer"
149 depends on TIMER
150 help
151 Enables support for the Nomadik Multi Timer Unit (MTU),
152 used in ST-Ericsson Ux500 SoCs.
153 The MTU provides 4 decrementing free-running timers.
154 At the moment, only the first timer is used by the driver.
155
Mugunthan V Nafae3702015-12-24 16:08:07 +0530156config OMAP_TIMER
157 bool "Omap timer support"
158 depends on TIMER
159 help
160 Select this to enable an timer for Omap devices.
161
Bin Meng25399032018-12-12 06:12:27 -0800162config RISCV_TIMER
163 bool "RISC-V timer support"
164 depends on TIMER && RISCV
165 help
Sean Anderson9baaaef2020-09-28 10:52:21 -0400166 Select this to enable support for a generic RISC-V S-Mode timer
167 driver.
Bin Meng25399032018-12-12 06:12:27 -0800168
Bin Meng19f88b22018-10-10 22:07:02 -0700169config ROCKCHIP_TIMER
170 bool "Rockchip timer support"
maxims@google.comf57bd002017-01-18 13:44:55 -0800171 depends on TIMER
maxims@google.comf57bd002017-01-18 13:44:55 -0800172 help
Bin Meng19f88b22018-10-10 22:07:02 -0700173 Select this to enable support for the timer found on
174 Rockchip devices.
175
176config SANDBOX_TIMER
177 bool "Sandbox timer support"
178 depends on SANDBOX && TIMER
179 help
180 Select this to enable an emulated timer for sandbox. It gets
181 time from host os.
maxims@google.comf57bd002017-01-18 13:44:55 -0800182
Patrice Chotard200a7992017-02-21 13:37:05 +0100183config STI_TIMER
184 bool "STi timer support"
185 depends on TIMER
186 default y if ARCH_STI
187 help
188 Select this to enable a timer for STi devices.
189
Patrice Chotardfdfefdc2018-02-07 10:44:45 +0100190config STM32_TIMER
Bin Meng19f88b22018-10-10 22:07:02 -0700191 bool "STM32 timer support"
Patrice Chotardfdfefdc2018-02-07 10:44:45 +0100192 depends on TIMER
193 help
194 Select this to enable support for the timer found on
195 STM32 devices.
196
Bin Meng19f88b22018-10-10 22:07:02 -0700197config X86_TSC_TIMER
198 bool "x86 Time-Stamp Counter (TSC) timer support"
199 depends on TIMER && X86
Mario Six3c516552018-08-06 10:23:38 +0200200 help
Bin Meng19f88b22018-10-10 22:07:02 -0700201 Select this to enable Time-Stamp Counter (TSC) timer for x86.
Mario Six3c516552018-08-06 10:23:38 +0200202
Simon Glassd3edd422019-12-06 21:41:49 -0700203config X86_TSC_READ_BASE
204 bool "Read the TSC timer base on start-up"
205 depends on X86_TSC_TIMER
206 help
207 On x86 platforms the TSC timer tick starts at the value 0 on reset.
208 This it makes no sense to read the timer on boot and use that as the
209 base, since we will miss some time taken to load U-Boot, etc. This
210 delay is controlled by the SoC and we cannot reduce it, but for
211 bootstage we want to record the time since reset as accurately as
212 possible.
213
214 The only exception is when U-Boot is used as a secondary bootloader,
215 where this option should be enabled.
216
Simon Glassbba203e2019-12-06 21:41:50 -0700217config TPL_X86_TSC_TIMER_NATIVE
218 bool "x86 TSC timer uses native calibration"
219 depends on TPL && X86_TSC_TIMER
220 help
221 Selects native timer calibration for TPL and don't include the other
222 methods in the code. This helps to reduce code size in TPL and works
223 on fairly modern Intel chips. Code-size reductions is about 700
224 bytes.
225
developer4a347352018-11-15 10:07:56 +0800226config MTK_TIMER
227 bool "MediaTek timer support"
228 depends on TIMER
229 help
230 Select this to enable support for the timer found on
231 MediaTek devices.
232
Claudiu Beznea5669c3d2020-09-07 18:36:33 +0300233config MCHP_PIT64B_TIMER
234 bool "Microchip 64-bit periodic interval timer support"
235 depends on TIMER
236 help
237 Select this to enable support for Microchip 64-bit periodic
238 interval timer.
239
Giulio Benetti9aed42b2021-05-13 12:18:31 +0200240config IMX_GPT_TIMER
241 bool "NXP i.MX GPT timer support"
242 depends on TIMER
243 help
244 Select this to enable support for the timer found on
245 NXP i.MX devices.
246
Thomas Choufb798b12015-10-09 13:46:34 +0800247endmenu