DPDK  19.05.0
rte_timer.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2010-2014 Intel Corporation
3  */
4 
5 #ifndef _RTE_TIMER_H_
6 #define _RTE_TIMER_H_
7 
37 #include <stdio.h>
38 #include <stdint.h>
39 #include <stddef.h>
40 #include <rte_common.h>
41 #include <rte_config.h>
42 #include <rte_spinlock.h>
43 
44 #ifdef __cplusplus
45 extern "C" {
46 #endif
47 
48 #define RTE_TIMER_STOP 0
49 #define RTE_TIMER_PENDING 1
50 #define RTE_TIMER_RUNNING 2
51 #define RTE_TIMER_CONFIG 3
53 #define RTE_TIMER_NO_OWNER -2
58 enum rte_timer_type {
59  SINGLE,
60  PERIODICAL
61 };
62 
69  struct {
70  uint16_t state;
71  int16_t owner;
72  };
73  uint32_t u32;
74 };
75 
76 #ifdef RTE_LIBRTE_TIMER_DEBUG
77 
80 struct rte_timer_debug_stats {
81  uint64_t reset;
82  uint64_t stop;
83  uint64_t manage;
84  uint64_t pending;
85 };
86 #endif
87 
88 struct rte_timer;
89 
93 typedef void (*rte_timer_cb_t)(struct rte_timer *, void *);
94 
95 #define MAX_SKIPLIST_DEPTH 10
96 
100 struct rte_timer
101 {
102  uint64_t expire;
103  struct rte_timer *sl_next[MAX_SKIPLIST_DEPTH];
104  volatile union rte_timer_status status;
105  uint64_t period;
107  void *arg;
108 };
109 
110 
111 #ifdef __cplusplus
112 
115 #define RTE_TIMER_INITIALIZER { \
116  0, \
117  {NULL}, \
118  {{RTE_TIMER_STOP, RTE_TIMER_NO_OWNER}}, \
119  0, \
120  NULL, \
121  NULL, \
122  }
123 #else
124 
127 #define RTE_TIMER_INITIALIZER { \
128  .status = {{ \
129  .state = RTE_TIMER_STOP, \
130  .owner = RTE_TIMER_NO_OWNER, \
131  }}, \
132  }
133 #endif
134 
150 int __rte_experimental rte_timer_data_alloc(uint32_t *id_ptr);
151 
165 int __rte_experimental rte_timer_data_dealloc(uint32_t id);
166 
180 int rte_timer_subsystem_init(void);
181 int rte_timer_subsystem_init_v1905(void);
182 void rte_timer_subsystem_init_v20(void);
183 
190 void __rte_experimental rte_timer_subsystem_finalize(void);
191 
202 void rte_timer_init(struct rte_timer *tim);
203 
246 int rte_timer_reset(struct rte_timer *tim, uint64_t ticks,
247  enum rte_timer_type type, unsigned tim_lcore,
248  rte_timer_cb_t fct, void *arg);
249 int rte_timer_reset_v1905(struct rte_timer *tim, uint64_t ticks,
250  enum rte_timer_type type, unsigned int tim_lcore,
251  rte_timer_cb_t fct, void *arg);
252 int rte_timer_reset_v20(struct rte_timer *tim, uint64_t ticks,
253  enum rte_timer_type type, unsigned int tim_lcore,
254  rte_timer_cb_t fct, void *arg);
255 
256 
283 void
284 rte_timer_reset_sync(struct rte_timer *tim, uint64_t ticks,
285  enum rte_timer_type type, unsigned tim_lcore,
286  rte_timer_cb_t fct, void *arg);
287 
311 int rte_timer_stop(struct rte_timer *tim);
312 int rte_timer_stop_v1905(struct rte_timer *tim);
313 int rte_timer_stop_v20(struct rte_timer *tim);
314 
324 void rte_timer_stop_sync(struct rte_timer *tim);
325 
339 int rte_timer_pending(struct rte_timer *tim);
340 
356 int rte_timer_manage(void);
357 int rte_timer_manage_v1905(void);
358 void rte_timer_manage_v20(void);
359 
369 int rte_timer_dump_stats(FILE *f);
370 int rte_timer_dump_stats_v1905(FILE *f);
371 void rte_timer_dump_stats_v20(FILE *f);
372 
411 int __rte_experimental
412 rte_timer_alt_reset(uint32_t timer_data_id, struct rte_timer *tim,
413  uint64_t ticks, enum rte_timer_type type,
414  unsigned int tim_lcore, rte_timer_cb_t fct, void *arg);
415 
436 int __rte_experimental
437 rte_timer_alt_stop(uint32_t timer_data_id, struct rte_timer *tim);
438 
442 typedef void (*rte_timer_alt_manage_cb_t)(struct rte_timer *tim);
443 
472 int __rte_experimental
473 rte_timer_alt_manage(uint32_t timer_data_id, unsigned int *poll_lcores,
474  int n_poll_lcores, rte_timer_alt_manage_cb_t f);
475 
479 typedef void (*rte_timer_stop_all_cb_t)(struct rte_timer *tim, void *arg);
480 
504 int __rte_experimental
505 rte_timer_stop_all(uint32_t timer_data_id, unsigned int *walk_lcores,
506  int nb_walk_lcores, rte_timer_stop_all_cb_t f, void *f_arg);
507 
526 int __rte_experimental
527 rte_timer_alt_dump_stats(uint32_t timer_data_id, FILE *f);
528 
529 #ifdef __cplusplus
530 }
531 #endif
532 
533 #endif /* _RTE_TIMER_H_ */