event/cnxk: add option to control SSO HWGRP QoS
[dpdk.git] / drivers / event / cnxk / cnxk_eventdev.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(C) 2021 Marvell.
3  */
4
5 #ifndef __CNXK_EVENTDEV_H__
6 #define __CNXK_EVENTDEV_H__
7
8 #include <rte_devargs.h>
9 #include <rte_kvargs.h>
10 #include <rte_mbuf_pool_ops.h>
11 #include <rte_pci.h>
12
13 #include <eventdev_pmd_pci.h>
14
15 #include "roc_api.h"
16
17 #define CNXK_SSO_XAE_CNT  "xae_cnt"
18 #define CNXK_SSO_GGRP_QOS "qos"
19
20 #define USEC2NSEC(__us) ((__us)*1E3)
21
22 #define CNXK_SSO_FC_NAME       "cnxk_evdev_xaq_fc"
23 #define CNXK_SSO_MZ_NAME       "cnxk_evdev_mz"
24 #define CNXK_SSO_XAQ_CACHE_CNT (0x7)
25 #define CNXK_SSO_XAQ_SLACK     (8)
26
27 struct cnxk_sso_qos {
28         uint16_t queue;
29         uint8_t xaq_prcnt;
30         uint8_t taq_prcnt;
31         uint8_t iaq_prcnt;
32 };
33
34 struct cnxk_sso_evdev {
35         struct roc_sso sso;
36         uint8_t max_event_queues;
37         uint8_t max_event_ports;
38         uint8_t is_timeout_deq;
39         uint8_t nb_event_queues;
40         uint8_t nb_event_ports;
41         uint32_t deq_tmo_ns;
42         uint32_t min_dequeue_timeout_ns;
43         uint32_t max_dequeue_timeout_ns;
44         int32_t max_num_events;
45         uint64_t *fc_mem;
46         uint64_t xaq_lmt;
47         uint64_t nb_xaq_cfg;
48         rte_iova_t fc_iova;
49         struct rte_mempool *xaq_pool;
50         /* Dev args */
51         uint32_t xae_cnt;
52         uint8_t qos_queue_cnt;
53         struct cnxk_sso_qos *qos_parse_data;
54         /* CN9K */
55         uint8_t dual_ws;
56 } __rte_cache_aligned;
57
58 static inline int
59 parse_kvargs_value(const char *key, const char *value, void *opaque)
60 {
61         RTE_SET_USED(key);
62
63         *(uint32_t *)opaque = (uint32_t)atoi(value);
64         return 0;
65 }
66
67 static inline struct cnxk_sso_evdev *
68 cnxk_sso_pmd_priv(const struct rte_eventdev *event_dev)
69 {
70         return event_dev->data->dev_private;
71 }
72
73 /* Configuration functions */
74 int cnxk_sso_xaq_allocate(struct cnxk_sso_evdev *dev);
75
76 /* Common ops API. */
77 int cnxk_sso_init(struct rte_eventdev *event_dev);
78 int cnxk_sso_fini(struct rte_eventdev *event_dev);
79 int cnxk_sso_remove(struct rte_pci_device *pci_dev);
80 void cnxk_sso_info_get(struct cnxk_sso_evdev *dev,
81                        struct rte_event_dev_info *dev_info);
82 int cnxk_sso_dev_validate(const struct rte_eventdev *event_dev);
83 void cnxk_sso_queue_def_conf(struct rte_eventdev *event_dev, uint8_t queue_id,
84                              struct rte_event_queue_conf *queue_conf);
85 int cnxk_sso_queue_setup(struct rte_eventdev *event_dev, uint8_t queue_id,
86                          const struct rte_event_queue_conf *queue_conf);
87 void cnxk_sso_queue_release(struct rte_eventdev *event_dev, uint8_t queue_id);
88 void cnxk_sso_port_def_conf(struct rte_eventdev *event_dev, uint8_t port_id,
89                             struct rte_event_port_conf *port_conf);
90
91 #endif /* __CNXK_EVENTDEV_H__ */