2019-06-02 03:14:06 +08:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
2018-01-22 07:15:57 +08:00
|
|
|
*
|
2019-06-02 03:14:06 +08:00
|
|
|
* Copyright(c) 2018 Intel Corporation. All rights reserved.
|
2018-01-22 07:15:57 +08:00
|
|
|
*
|
2018-08-23 16:50:51 +08:00
|
|
|
* Author: Janusz Jankowski <janusz.jankowski@linux.intel.com>
|
2018-01-22 07:15:57 +08:00
|
|
|
*/
|
|
|
|
|
2019-07-10 20:23:41 +08:00
|
|
|
#ifndef __SOF_DRIVERS_TIMER_H__
|
|
|
|
#define __SOF_DRIVERS_TIMER_H__
|
2018-01-22 07:15:57 +08:00
|
|
|
|
2019-07-17 02:31:41 +08:00
|
|
|
#include <arch/drivers/timer.h>
|
2022-09-03 01:23:19 +08:00
|
|
|
#include <rtos/clk.h>
|
2020-07-10 19:53:18 +08:00
|
|
|
#include <sof/lib/cpu.h>
|
2019-12-19 22:45:15 +08:00
|
|
|
#include <sof/sof.h>
|
2022-03-11 20:55:15 +08:00
|
|
|
#include <sof/platform.h>
|
2019-07-11 20:31:19 +08:00
|
|
|
#include <stdint.h>
|
2018-01-22 07:15:57 +08:00
|
|
|
|
2018-08-23 16:50:51 +08:00
|
|
|
struct comp_dev;
|
|
|
|
struct sof_ipc_stream_posn;
|
2018-01-22 07:15:57 +08:00
|
|
|
|
2019-08-05 22:14:52 +08:00
|
|
|
#define TIMER0 0
|
|
|
|
#define TIMER1 1
|
|
|
|
#define TIMER2 2
|
|
|
|
#define TIMER3 3
|
|
|
|
#define TIMER4 4
|
|
|
|
|
2019-09-06 16:45:35 +08:00
|
|
|
int timer_register(struct timer *timer, void (*handler)(void *arg), void *arg);
|
|
|
|
void timer_unregister(struct timer *timer, void *arg);
|
|
|
|
void timer_enable(struct timer *timer, void *arg, int core);
|
|
|
|
void timer_disable(struct timer *timer, void *arg, int core);
|
2019-07-11 20:31:19 +08:00
|
|
|
|
2019-12-19 22:45:15 +08:00
|
|
|
static inline struct timer *timer_get(void)
|
|
|
|
{
|
|
|
|
return sof_get()->platform_timer;
|
|
|
|
}
|
|
|
|
|
2020-01-14 01:18:31 +08:00
|
|
|
static inline struct timer *cpu_timer_get(void)
|
|
|
|
{
|
2020-07-10 19:53:18 +08:00
|
|
|
return &(sof_get()->cpu_timers[cpu_get_id()]);
|
2020-01-14 01:18:31 +08:00
|
|
|
}
|
|
|
|
|
2019-09-11 20:30:12 +08:00
|
|
|
static inline int64_t timer_set(struct timer *timer, uint64_t ticks)
|
2019-07-11 20:31:19 +08:00
|
|
|
{
|
|
|
|
return arch_timer_set(timer, ticks);
|
|
|
|
}
|
|
|
|
|
|
|
|
void timer_set_ms(struct timer *timer, unsigned int ms);
|
|
|
|
|
|
|
|
static inline void timer_clear(struct timer *timer)
|
|
|
|
{
|
|
|
|
arch_timer_clear(timer);
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int timer_get_count(struct timer *timer);
|
|
|
|
|
|
|
|
unsigned int timer_get_count_delta(struct timer *timer);
|
|
|
|
|
|
|
|
static inline uint64_t timer_get_system(struct timer *timer)
|
|
|
|
{
|
|
|
|
return arch_timer_get_system(timer);
|
|
|
|
}
|
|
|
|
|
2019-09-11 20:30:12 +08:00
|
|
|
int64_t platform_timer_set(struct timer *timer, uint64_t ticks);
|
2018-08-23 16:50:51 +08:00
|
|
|
void platform_timer_clear(struct timer *timer);
|
|
|
|
uint64_t platform_timer_get(struct timer *timer);
|
2021-02-01 21:18:52 +08:00
|
|
|
uint64_t platform_timer_get_atomic(struct timer *timer);
|
2021-06-18 08:30:11 +08:00
|
|
|
|
|
|
|
static inline uint64_t platform_safe_get_time(struct timer *timer)
|
|
|
|
{
|
|
|
|
/* Default to something small but at least 1.0 microsecond so it
|
|
|
|
* does not look like an uninitialized zero; not even when the
|
|
|
|
* user does not request any microseconds decimals. See
|
|
|
|
* DEFAULT_CLOCK constant in logger.c
|
|
|
|
*/
|
|
|
|
return timer ? platform_timer_get(timer) : 50;
|
|
|
|
}
|
|
|
|
|
2018-08-23 16:50:51 +08:00
|
|
|
void platform_timer_start(struct timer *timer);
|
|
|
|
void platform_timer_stop(struct timer *timer);
|
2018-01-22 07:15:57 +08:00
|
|
|
|
2022-03-11 20:55:15 +08:00
|
|
|
static inline uint64_t k_ms_to_cyc_ceil64(uint64_t ms)
|
|
|
|
{
|
|
|
|
return clock_ms_to_ticks(PLATFORM_DEFAULT_CLOCK, ms);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint64_t k_us_to_cyc_ceil64(uint64_t us)
|
|
|
|
{
|
|
|
|
return clock_us_to_ticks(PLATFORM_DEFAULT_CLOCK, us);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint64_t k_ns_to_cyc_near64(uint64_t ns)
|
|
|
|
{
|
|
|
|
return clock_ns_to_ticks(PLATFORM_DEFAULT_CLOCK, ns);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint64_t k_cyc_to_ms_near64(uint64_t ticks)
|
|
|
|
{
|
|
|
|
return ticks / clock_ms_to_ticks(PLATFORM_DEFAULT_CLOCK, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline uint64_t k_cyc_to_us_near64(uint64_t ticks)
|
|
|
|
{
|
|
|
|
return ticks / clock_us_to_ticks(PLATFORM_DEFAULT_CLOCK, 1);
|
|
|
|
}
|
|
|
|
|
2022-07-27 19:59:43 +08:00
|
|
|
static inline uint64_t sof_cycle_get_64(void)
|
2022-03-11 20:55:15 +08:00
|
|
|
{
|
|
|
|
return platform_timer_get(timer_get());
|
|
|
|
}
|
|
|
|
|
2022-07-27 19:59:43 +08:00
|
|
|
static inline uint64_t sof_cycle_get_64_atomic(void)
|
2022-03-11 20:55:15 +08:00
|
|
|
{
|
|
|
|
return platform_timer_get_atomic(timer_get());
|
|
|
|
}
|
|
|
|
|
2022-07-27 19:59:43 +08:00
|
|
|
static inline uint64_t sof_cycle_get_64_safe(void)
|
2022-03-11 20:55:15 +08:00
|
|
|
{
|
|
|
|
return platform_safe_get_time(timer_get());
|
|
|
|
}
|
|
|
|
|
2018-01-22 07:15:57 +08:00
|
|
|
/* get timestamp for host stream DMA position */
|
|
|
|
void platform_host_timestamp(struct comp_dev *host,
|
2018-08-23 16:50:51 +08:00
|
|
|
struct sof_ipc_stream_posn *posn);
|
2018-01-22 07:15:57 +08:00
|
|
|
|
|
|
|
/* get timestamp for DAI stream DMA position */
|
|
|
|
void platform_dai_timestamp(struct comp_dev *dai,
|
2018-08-23 16:50:51 +08:00
|
|
|
struct sof_ipc_stream_posn *posn);
|
2018-01-22 07:15:57 +08:00
|
|
|
|
|
|
|
/* get current wallclock for componnent */
|
2018-08-23 16:50:51 +08:00
|
|
|
void platform_dai_wallclock(struct comp_dev *dai, uint64_t *wallclock);
|
2018-01-22 07:15:57 +08:00
|
|
|
|
2019-07-10 20:23:41 +08:00
|
|
|
#endif /* __SOF_DRIVERS_TIMER_H__ */
|