1540914bcSEd Czeck /* SPDX-License-Identifier: BSD-3-Clause
2540914bcSEd Czeck * Copyright (c) 2015-2018 Atomic Rules LLC
3cf18d4deSEd Czeck */
4cf18d4deSEd Czeck
5cf18d4deSEd Czeck #include <unistd.h>
6cf18d4deSEd Czeck
7cf18d4deSEd Czeck #include "ark_logs.h"
8cf18d4deSEd Czeck #include "ark_udm.h"
9cf18d4deSEd Czeck
109ee9e0d3SEd Czeck static_assert(sizeof(struct ark_rx_meta) == 32, "Unexpected struct size ark_rx_meta");
119ee9e0d3SEd Czeck
12cf18d4deSEd Czeck int
ark_udm_verify(struct ark_udm_t * udm)13cf18d4deSEd Czeck ark_udm_verify(struct ark_udm_t *udm)
14cf18d4deSEd Czeck {
15*f0d33f78SEd Czeck uint32_t idnum = udm->setup.idnum;
16*f0d33f78SEd Czeck uint32_t vernum = udm->setup.vernum;
17cf18d4deSEd Czeck if (sizeof(struct ark_udm_t) != ARK_UDM_EXPECT_SIZE) {
181502d443SEd Czeck ARK_PMD_LOG(ERR,
19cf18d4deSEd Czeck "ARK: UDM structure looks incorrect %d vs %zd\n",
20cf18d4deSEd Czeck ARK_UDM_EXPECT_SIZE, sizeof(struct ark_udm_t));
21cf18d4deSEd Czeck return -1;
22cf18d4deSEd Czeck }
23cf18d4deSEd Czeck
24*f0d33f78SEd Czeck if (idnum != ARK_UDM_MODID || vernum != ARK_UDM_MODVER) {
251502d443SEd Czeck ARK_PMD_LOG(ERR,
26*f0d33f78SEd Czeck "ARK: UDM module not found as expected 0x%08x 0x%08x\n",
27*f0d33f78SEd Czeck idnum, vernum);
28cf18d4deSEd Czeck return -1;
29cf18d4deSEd Czeck }
30cf18d4deSEd Czeck return 0;
31cf18d4deSEd Czeck }
32cf18d4deSEd Czeck
33cf18d4deSEd Czeck void
ark_udm_configure(struct ark_udm_t * udm,uint32_t headroom,uint32_t dataroom)34cf18d4deSEd Czeck ark_udm_configure(struct ark_udm_t *udm,
35cf18d4deSEd Czeck uint32_t headroom,
36*f0d33f78SEd Czeck uint32_t dataroom)
37cf18d4deSEd Czeck {
38cf18d4deSEd Czeck /* headroom and data room are in DWords in the UDM */
39cf18d4deSEd Czeck udm->cfg.dataroom = dataroom / 4;
40cf18d4deSEd Czeck udm->cfg.headroom = headroom / 4;
41cf18d4deSEd Czeck }
42cf18d4deSEd Czeck
43cf18d4deSEd Czeck void
ark_udm_write_addr(struct ark_udm_t * udm,rte_iova_t addr)44df6e0a06SSantosh Shukla ark_udm_write_addr(struct ark_udm_t *udm, rte_iova_t addr)
45cf18d4deSEd Czeck {
46cf18d4deSEd Czeck udm->rt_cfg.hw_prod_addr = addr;
47*f0d33f78SEd Czeck udm->rt_cfg.prod_idx = 0;
48cf18d4deSEd Czeck }
49cf18d4deSEd Czeck
50cf18d4deSEd Czeck uint64_t
ark_udm_dropped(struct ark_udm_t * udm)51cf18d4deSEd Czeck ark_udm_dropped(struct ark_udm_t *udm)
52cf18d4deSEd Czeck {
53cf18d4deSEd Czeck return udm->qstats.q_pkt_drop;
54cf18d4deSEd Czeck }
55cf18d4deSEd Czeck
56cf18d4deSEd Czeck uint64_t
ark_udm_bytes(struct ark_udm_t * udm)57cf18d4deSEd Czeck ark_udm_bytes(struct ark_udm_t *udm)
58cf18d4deSEd Czeck {
59cf18d4deSEd Czeck return udm->qstats.q_byte_count;
60cf18d4deSEd Czeck }
61cf18d4deSEd Czeck
62cf18d4deSEd Czeck uint64_t
ark_udm_packets(struct ark_udm_t * udm)63cf18d4deSEd Czeck ark_udm_packets(struct ark_udm_t *udm)
64cf18d4deSEd Czeck {
65cf18d4deSEd Czeck return udm->qstats.q_ff_packet_count;
66cf18d4deSEd Czeck }
67cf18d4deSEd Czeck
68cf18d4deSEd Czeck void
ark_udm_dump_stats(struct ark_udm_t * udm,const char * msg)69cf18d4deSEd Czeck ark_udm_dump_stats(struct ark_udm_t *udm, const char *msg)
70cf18d4deSEd Czeck {
711502d443SEd Czeck ARK_PMD_LOG(INFO, "UDM Stats: %s"
72*f0d33f78SEd Czeck ARK_SU64 ARK_SU64 ARK_SU64 ARK_SU64 "\n",
73cf18d4deSEd Czeck msg,
74cf18d4deSEd Czeck "Pkts Received", udm->stats.rx_packet_count,
75cf18d4deSEd Czeck "Pkts Finalized", udm->stats.rx_sent_packets,
76cf18d4deSEd Czeck "Bytes Count", udm->stats.rx_byte_count,
77cf18d4deSEd Czeck "MBuf Count", udm->stats.rx_mbuf_count);
78cf18d4deSEd Czeck }
79cf18d4deSEd Czeck
80cf18d4deSEd Czeck void
ark_udm_dump_queue_stats(struct ark_udm_t * udm,const char * msg,uint16_t qid)81cf18d4deSEd Czeck ark_udm_dump_queue_stats(struct ark_udm_t *udm, const char *msg, uint16_t qid)
82cf18d4deSEd Czeck {
831502d443SEd Czeck ARK_PMD_LOG(INFO, "UDM Queue %3u Stats: %s"
84cf18d4deSEd Czeck ARK_SU64 ARK_SU64
85cf18d4deSEd Czeck ARK_SU64 ARK_SU64
86cf18d4deSEd Czeck ARK_SU64 "\n",
87cf18d4deSEd Czeck qid, msg,
88cf18d4deSEd Czeck "Pkts Received", udm->qstats.q_packet_count,
89cf18d4deSEd Czeck "Pkts Finalized", udm->qstats.q_ff_packet_count,
90cf18d4deSEd Czeck "Pkts Dropped", udm->qstats.q_pkt_drop,
91cf18d4deSEd Czeck "Bytes Count", udm->qstats.q_byte_count,
92cf18d4deSEd Czeck "MBuf Count", udm->qstats.q_mbuf_count);
93cf18d4deSEd Czeck }
94cf18d4deSEd Czeck
95cf18d4deSEd Czeck void
ark_udm_dump_setup(struct ark_udm_t * udm,uint16_t q_id)96cf18d4deSEd Czeck ark_udm_dump_setup(struct ark_udm_t *udm, uint16_t q_id)
97cf18d4deSEd Czeck {
981502d443SEd Czeck ARK_PMD_LOG(DEBUG, "UDM Setup Q: %u"
99cf18d4deSEd Czeck ARK_SU64X ARK_SU32 "\n",
100cf18d4deSEd Czeck q_id,
101cf18d4deSEd Czeck "hw_prod_addr", udm->rt_cfg.hw_prod_addr,
102cf18d4deSEd Czeck "prod_idx", udm->rt_cfg.prod_idx);
103cf18d4deSEd Czeck }
104cf18d4deSEd Czeck
105cf18d4deSEd Czeck void
ark_udm_queue_stats_reset(struct ark_udm_t * udm)106cf18d4deSEd Czeck ark_udm_queue_stats_reset(struct ark_udm_t *udm)
107cf18d4deSEd Czeck {
108cf18d4deSEd Czeck udm->qstats.q_byte_count = 1;
109cf18d4deSEd Czeck }
110cf18d4deSEd Czeck
111cf18d4deSEd Czeck void
ark_udm_queue_enable(struct ark_udm_t * udm,int enable)112cf18d4deSEd Czeck ark_udm_queue_enable(struct ark_udm_t *udm, int enable)
113cf18d4deSEd Czeck {
114cf18d4deSEd Czeck udm->qstats.q_enable = enable ? 1 : 0;
115cf18d4deSEd Czeck }
116