1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(C) 2021 Marvell.
9 ROC_TIM_CLK_SRC_10NS = 0,
13 ROC_TIM_CLK_SRC_SYNCE,
15 ROC_TIM_CLK_SRC_INVALID,
19 struct roc_sso *roc_sso;
23 #define TIM_MEM_SZ (1 * 1024)
24 uint8_t reserved[TIM_MEM_SZ] __plt_cache_aligned;
25 } __plt_cache_aligned;
27 int __roc_api roc_tim_init(struct roc_tim *roc_tim);
28 void __roc_api roc_tim_fini(struct roc_tim *roc_tim);
31 int __roc_api roc_tim_lf_enable(struct roc_tim *roc_tim, uint8_t ring_id,
32 uint64_t *start_tsc, uint32_t *cur_bkt);
33 int __roc_api roc_tim_lf_disable(struct roc_tim *roc_tim, uint8_t ring_id);
34 int __roc_api roc_tim_lf_config(struct roc_tim *roc_tim, uint8_t ring_id,
35 enum roc_tim_clk_src clk_src,
36 uint8_t ena_periodic, uint8_t ena_dfb,
37 uint32_t bucket_sz, uint32_t chunk_sz,
38 uint32_t interval, uint64_t intervalns,
40 int __roc_api roc_tim_lf_interval(struct roc_tim *roc_tim,
41 enum roc_tim_clk_src clk_src,
42 uint64_t clockfreq, uint64_t *intervalns,
44 int __roc_api roc_tim_lf_alloc(struct roc_tim *roc_tim, uint8_t ring_id,
46 int __roc_api roc_tim_lf_free(struct roc_tim *roc_tim, uint8_t ring_id);
47 uintptr_t __roc_api roc_tim_lf_base_get(struct roc_tim *roc_tim,