blob: 5594e2327648f4220bbefd8a394e3993ad4c6f88 [file] [log] [blame]
Yann Gautier9aea69e2018-07-24 17:13:36 +02001/*
2 * Copyright (c) 2018, STMicroelectronics - All Rights Reserved
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Antonio Nino Diaz5eb88372018-11-08 10:20:19 +00007#ifndef STM32MP1_CLK_H
8#define STM32MP1_CLK_H
Yann Gautier9aea69e2018-07-24 17:13:36 +02009
Yann Gautier9aea69e2018-07-24 17:13:36 +020010#include <stdbool.h>
11
Antonio Nino Diaze0f90632018-12-14 00:18:21 +000012#include <arch_helpers.h>
13
Yann Gautier9aea69e2018-07-24 17:13:36 +020014int stm32mp1_clk_probe(void);
15int stm32mp1_clk_init(void);
16bool stm32mp1_clk_is_enabled(unsigned long id);
17int stm32mp1_clk_enable(unsigned long id);
18int stm32mp1_clk_disable(unsigned long id);
19unsigned long stm32mp1_clk_get_rate(unsigned long id);
20void stm32mp1_stgen_increment(unsigned long long offset_in_ms);
21
22static inline uint32_t get_timer(uint32_t base)
23{
24 if (base == 0U) {
25 return (uint32_t)(~read_cntpct_el0());
26 }
27
28 return base - (uint32_t)(~read_cntpct_el0());
29}
30
Antonio Nino Diaz5eb88372018-11-08 10:20:19 +000031#endif /* STM32MP1_CLK_H */