common/cnxk: support setting BPHY CGX/RPM FEC
[dpdk.git] / drivers / common / cnxk / roc_nix_npc.c
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(C) 2021 Marvell.
3  */
4
5 #include "roc_api.h"
6 #include "roc_priv.h"
7
8 static inline struct mbox *
9 get_mbox(struct roc_nix *roc_nix)
10 {
11         struct nix *nix = roc_nix_to_nix_priv(roc_nix);
12         struct dev *dev = &nix->dev;
13
14         return dev->mbox;
15 }
16
17 int
18 roc_nix_npc_promisc_ena_dis(struct roc_nix *roc_nix, int enable)
19 {
20         struct mbox *mbox = get_mbox(roc_nix);
21         struct nix_rx_mode *req;
22         int rc = -ENOSPC;
23
24         if (roc_nix_is_vf_or_sdp(roc_nix))
25                 return NIX_ERR_PARAM;
26
27         req = mbox_alloc_msg_nix_set_rx_mode(mbox);
28         if (req == NULL)
29                 return rc;
30
31         if (enable)
32                 req->mode = NIX_RX_MODE_UCAST | NIX_RX_MODE_PROMISC;
33
34         return mbox_process(mbox);
35 }
36
37 int
38 roc_nix_npc_mac_addr_set(struct roc_nix *roc_nix, uint8_t addr[])
39 {
40         struct mbox *mbox = get_mbox(roc_nix);
41         struct nix_set_mac_addr *req;
42
43         req = mbox_alloc_msg_nix_set_mac_addr(mbox);
44         mbox_memcpy(req->mac_addr, addr, PLT_ETHER_ADDR_LEN);
45         return mbox_process(mbox);
46 }
47
48 int
49 roc_nix_npc_mac_addr_get(struct roc_nix *roc_nix, uint8_t *addr)
50 {
51         struct mbox *mbox = get_mbox(roc_nix);
52         struct nix_get_mac_addr_rsp *rsp;
53         int rc;
54
55         mbox_alloc_msg_nix_get_mac_addr(mbox);
56         rc = mbox_process_msg(mbox, (void *)&rsp);
57         if (rc)
58                 return rc;
59
60         mbox_memcpy(addr, rsp->mac_addr, PLT_ETHER_ADDR_LEN);
61         return 0;
62 }
63
64 int
65 roc_nix_npc_rx_ena_dis(struct roc_nix *roc_nix, bool enable)
66 {
67         struct mbox *mbox = get_mbox(roc_nix);
68         int rc;
69
70         if (enable)
71                 mbox_alloc_msg_nix_lf_start_rx(mbox);
72         else
73                 mbox_alloc_msg_nix_lf_stop_rx(mbox);
74
75         rc = mbox_process(mbox);
76         if (!rc)
77                 roc_nix->io_enabled = enable;
78         return rc;
79 }
80
81 int
82 roc_nix_npc_mcast_config(struct roc_nix *roc_nix, bool mcast_enable,
83                          bool prom_enable)
84
85 {
86         struct mbox *mbox = get_mbox(roc_nix);
87         struct nix_rx_mode *req;
88         int rc = -ENOSPC;
89
90         if (roc_nix_is_vf_or_sdp(roc_nix))
91                 return 0;
92
93         req = mbox_alloc_msg_nix_set_rx_mode(mbox);
94         if (req == NULL)
95                 return rc;
96
97         if (mcast_enable)
98                 req->mode = NIX_RX_MODE_ALLMULTI;
99         else if (prom_enable)
100                 req->mode = NIX_RX_MODE_PROMISC;
101
102         return mbox_process(mbox);
103 }