1aaf4363eSJerin Jacob /* SPDX-License-Identifier: BSD-3-Clause
2aaf4363eSJerin Jacob * Copyright(c) 2017 Cavium, Inc
34d027880SJerin Jacob */
44d027880SJerin Jacob
5*72b452c5SDmitry Kozlyuk #include <errno.h>
64d027880SJerin Jacob #include <string.h>
74d027880SJerin Jacob
84d027880SJerin Jacob #include "octeontx_bgx.h"
94d027880SJerin Jacob
104d027880SJerin Jacob int
octeontx_bgx_port_open(int port,octeontx_mbox_bgx_port_conf_t * conf)114d027880SJerin Jacob octeontx_bgx_port_open(int port, octeontx_mbox_bgx_port_conf_t *conf)
124d027880SJerin Jacob {
134d027880SJerin Jacob struct octeontx_mbox_hdr hdr;
144d027880SJerin Jacob octeontx_mbox_bgx_port_conf_t bgx_conf;
154d027880SJerin Jacob int len = sizeof(octeontx_mbox_bgx_port_conf_t);
164d027880SJerin Jacob int res;
174d027880SJerin Jacob
184d027880SJerin Jacob memset(&bgx_conf, 0, sizeof(octeontx_mbox_bgx_port_conf_t));
194d027880SJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
204d027880SJerin Jacob hdr.msg = MBOX_BGX_PORT_OPEN;
214d027880SJerin Jacob hdr.vfid = port;
224d027880SJerin Jacob
23d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, &bgx_conf, len);
244d027880SJerin Jacob if (res < 0)
254d027880SJerin Jacob return -EACCES;
264d027880SJerin Jacob
274d027880SJerin Jacob conf->enable = bgx_conf.enable;
284d027880SJerin Jacob conf->promisc = bgx_conf.promisc;
294d027880SJerin Jacob conf->bpen = bgx_conf.bpen;
304d027880SJerin Jacob conf->node = bgx_conf.node;
314d027880SJerin Jacob conf->base_chan = bgx_conf.base_chan;
324d027880SJerin Jacob conf->num_chans = bgx_conf.num_chans;
334d027880SJerin Jacob conf->mtu = bgx_conf.mtu;
344d027880SJerin Jacob conf->bgx = bgx_conf.bgx;
354d027880SJerin Jacob conf->lmac = bgx_conf.lmac;
364d027880SJerin Jacob conf->mode = bgx_conf.mode;
374d027880SJerin Jacob conf->pkind = bgx_conf.pkind;
384d027880SJerin Jacob memcpy(conf->macaddr, bgx_conf.macaddr, 6);
394d027880SJerin Jacob
404d027880SJerin Jacob return res;
414d027880SJerin Jacob }
424d027880SJerin Jacob
434d027880SJerin Jacob int
octeontx_bgx_port_close(int port)444d027880SJerin Jacob octeontx_bgx_port_close(int port)
454d027880SJerin Jacob {
464d027880SJerin Jacob struct octeontx_mbox_hdr hdr;
474d027880SJerin Jacob int res;
484d027880SJerin Jacob
494d027880SJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
504d027880SJerin Jacob hdr.msg = MBOX_BGX_PORT_CLOSE;
514d027880SJerin Jacob hdr.vfid = port;
524d027880SJerin Jacob
53d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, NULL, 0);
544d027880SJerin Jacob if (res < 0)
554d027880SJerin Jacob return -EACCES;
564d027880SJerin Jacob
574d027880SJerin Jacob return res;
584d027880SJerin Jacob }
594d027880SJerin Jacob
604d027880SJerin Jacob int
octeontx_bgx_port_start(int port)614d027880SJerin Jacob octeontx_bgx_port_start(int port)
624d027880SJerin Jacob {
634d027880SJerin Jacob struct octeontx_mbox_hdr hdr;
644d027880SJerin Jacob int res;
654d027880SJerin Jacob
664d027880SJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
674d027880SJerin Jacob hdr.msg = MBOX_BGX_PORT_START;
684d027880SJerin Jacob hdr.vfid = port;
694d027880SJerin Jacob
70d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, NULL, 0);
714d027880SJerin Jacob if (res < 0)
724d027880SJerin Jacob return -EACCES;
734d027880SJerin Jacob
744d027880SJerin Jacob return res;
754d027880SJerin Jacob }
764d027880SJerin Jacob
774d027880SJerin Jacob int
octeontx_bgx_port_stop(int port)784d027880SJerin Jacob octeontx_bgx_port_stop(int port)
794d027880SJerin Jacob {
804d027880SJerin Jacob struct octeontx_mbox_hdr hdr;
814d027880SJerin Jacob int res;
824d027880SJerin Jacob
834d027880SJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
844d027880SJerin Jacob hdr.msg = MBOX_BGX_PORT_STOP;
854d027880SJerin Jacob hdr.vfid = port;
864d027880SJerin Jacob
87d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, NULL, 0);
884d027880SJerin Jacob if (res < 0)
894d027880SJerin Jacob return -EACCES;
904d027880SJerin Jacob
914d027880SJerin Jacob return res;
924d027880SJerin Jacob }
93e242dd1cSJerin Jacob
94e242dd1cSJerin Jacob int
octeontx_bgx_port_get_config(int port,octeontx_mbox_bgx_port_conf_t * conf)95e242dd1cSJerin Jacob octeontx_bgx_port_get_config(int port, octeontx_mbox_bgx_port_conf_t *conf)
96e242dd1cSJerin Jacob {
97e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
98e242dd1cSJerin Jacob octeontx_mbox_bgx_port_conf_t bgx_conf;
99e242dd1cSJerin Jacob int len = sizeof(octeontx_mbox_bgx_port_conf_t);
100e242dd1cSJerin Jacob int res;
101e242dd1cSJerin Jacob
102e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
103e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_GET_CONFIG;
104e242dd1cSJerin Jacob hdr.vfid = port;
105e242dd1cSJerin Jacob
106e242dd1cSJerin Jacob memset(&bgx_conf, 0, sizeof(octeontx_mbox_bgx_port_conf_t));
107d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, &bgx_conf, len);
108e242dd1cSJerin Jacob if (res < 0)
109e242dd1cSJerin Jacob return -EACCES;
110e242dd1cSJerin Jacob
111e242dd1cSJerin Jacob conf->enable = bgx_conf.enable;
112e242dd1cSJerin Jacob conf->promisc = bgx_conf.promisc;
113e242dd1cSJerin Jacob conf->bpen = bgx_conf.bpen;
114e242dd1cSJerin Jacob conf->node = bgx_conf.node;
115e242dd1cSJerin Jacob conf->base_chan = bgx_conf.base_chan;
116e242dd1cSJerin Jacob conf->num_chans = bgx_conf.num_chans;
117e242dd1cSJerin Jacob conf->mtu = bgx_conf.mtu;
118e242dd1cSJerin Jacob conf->bgx = bgx_conf.bgx;
119e242dd1cSJerin Jacob conf->lmac = bgx_conf.lmac;
120e242dd1cSJerin Jacob conf->mode = bgx_conf.mode;
121e242dd1cSJerin Jacob conf->pkind = bgx_conf.pkind;
122e242dd1cSJerin Jacob memcpy(conf->macaddr, bgx_conf.macaddr, 6);
123e242dd1cSJerin Jacob
124e242dd1cSJerin Jacob return res;
125e242dd1cSJerin Jacob }
126e242dd1cSJerin Jacob
127e242dd1cSJerin Jacob int
octeontx_bgx_port_status(int port,octeontx_mbox_bgx_port_status_t * stat)128e242dd1cSJerin Jacob octeontx_bgx_port_status(int port, octeontx_mbox_bgx_port_status_t *stat)
129e242dd1cSJerin Jacob {
130e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
131e242dd1cSJerin Jacob octeontx_mbox_bgx_port_status_t bgx_stat;
132e242dd1cSJerin Jacob int len = sizeof(octeontx_mbox_bgx_port_status_t);
133e242dd1cSJerin Jacob int res;
134e242dd1cSJerin Jacob
135e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
136e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_GET_STATUS;
137e242dd1cSJerin Jacob hdr.vfid = port;
138e242dd1cSJerin Jacob
139d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, &bgx_stat, len);
140e242dd1cSJerin Jacob if (res < 0)
141e242dd1cSJerin Jacob return -EACCES;
142e242dd1cSJerin Jacob
143e242dd1cSJerin Jacob stat->link_up = bgx_stat.link_up;
144e242dd1cSJerin Jacob
145e242dd1cSJerin Jacob return res;
146e242dd1cSJerin Jacob }
147e242dd1cSJerin Jacob
148e242dd1cSJerin Jacob int
octeontx_bgx_port_multicast_set(int port,int en)1492f69bbd8SHarman Kalra octeontx_bgx_port_multicast_set(int port, int en)
1502f69bbd8SHarman Kalra {
1512f69bbd8SHarman Kalra struct octeontx_mbox_hdr hdr;
1522f69bbd8SHarman Kalra uint8_t prom;
1532f69bbd8SHarman Kalra int res;
1542f69bbd8SHarman Kalra
1552f69bbd8SHarman Kalra hdr.coproc = OCTEONTX_BGX_COPROC;
1562f69bbd8SHarman Kalra hdr.msg = MBOX_BGX_PORT_SET_MCAST;
1572f69bbd8SHarman Kalra hdr.vfid = port;
1582f69bbd8SHarman Kalra prom = en ? 1 : 0;
1592f69bbd8SHarman Kalra
1602f69bbd8SHarman Kalra res = octeontx_mbox_send(&hdr, &prom, sizeof(prom), NULL, 0);
1612f69bbd8SHarman Kalra if (res < 0)
1622f69bbd8SHarman Kalra return -EACCES;
1632f69bbd8SHarman Kalra
1642f69bbd8SHarman Kalra return res;
1652f69bbd8SHarman Kalra }
1662f69bbd8SHarman Kalra
1672f69bbd8SHarman Kalra int
octeontx_bgx_port_xstats(int port,octeontx_mbox_bgx_port_stats_t * stats)168c6b97d67SHarman Kalra octeontx_bgx_port_xstats(int port, octeontx_mbox_bgx_port_stats_t *stats)
169c6b97d67SHarman Kalra {
170c6b97d67SHarman Kalra struct octeontx_mbox_hdr hdr;
171c6b97d67SHarman Kalra int len = sizeof(octeontx_mbox_bgx_port_stats_t);
172c6b97d67SHarman Kalra int res;
173c6b97d67SHarman Kalra
174c6b97d67SHarman Kalra hdr.coproc = OCTEONTX_BGX_COPROC;
175c6b97d67SHarman Kalra hdr.msg = MBOX_BGX_PORT_GET_STATS;
176c6b97d67SHarman Kalra hdr.vfid = port;
177c6b97d67SHarman Kalra
178c6b97d67SHarman Kalra res = octeontx_mbox_send(&hdr, NULL, 0, stats, len);
179c6b97d67SHarman Kalra if (res < 0)
180c6b97d67SHarman Kalra return -EACCES;
181c6b97d67SHarman Kalra return res;
182c6b97d67SHarman Kalra }
183c6b97d67SHarman Kalra
184c6b97d67SHarman Kalra int
octeontx_bgx_port_stats(int port,octeontx_mbox_bgx_port_stats_t * stats)185e242dd1cSJerin Jacob octeontx_bgx_port_stats(int port, octeontx_mbox_bgx_port_stats_t *stats)
186e242dd1cSJerin Jacob {
187e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
188e242dd1cSJerin Jacob octeontx_mbox_bgx_port_stats_t bgx_stats;
189e242dd1cSJerin Jacob int len = sizeof(octeontx_mbox_bgx_port_stats_t);
190e242dd1cSJerin Jacob int res;
191e242dd1cSJerin Jacob
192e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
193e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_GET_STATS;
194e242dd1cSJerin Jacob hdr.vfid = port;
195e242dd1cSJerin Jacob
196d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, &bgx_stats, len);
197e242dd1cSJerin Jacob if (res < 0)
198e242dd1cSJerin Jacob return -EACCES;
199e242dd1cSJerin Jacob
200e242dd1cSJerin Jacob stats->rx_packets = bgx_stats.rx_packets;
201e242dd1cSJerin Jacob stats->rx_bytes = bgx_stats.rx_bytes;
202e242dd1cSJerin Jacob stats->rx_dropped = bgx_stats.rx_dropped;
203e242dd1cSJerin Jacob stats->rx_errors = bgx_stats.rx_errors;
204e242dd1cSJerin Jacob stats->tx_packets = bgx_stats.tx_packets;
205e242dd1cSJerin Jacob stats->tx_bytes = bgx_stats.tx_bytes;
206e242dd1cSJerin Jacob stats->tx_dropped = bgx_stats.tx_dropped;
207e242dd1cSJerin Jacob stats->tx_errors = bgx_stats.tx_errors;
208e242dd1cSJerin Jacob return res;
209e242dd1cSJerin Jacob }
210e242dd1cSJerin Jacob
211e242dd1cSJerin Jacob int
octeontx_bgx_port_stats_clr(int port)212e242dd1cSJerin Jacob octeontx_bgx_port_stats_clr(int port)
213e242dd1cSJerin Jacob {
214e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
215e242dd1cSJerin Jacob int res;
216e242dd1cSJerin Jacob
217e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
218e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_CLR_STATS;
219e242dd1cSJerin Jacob hdr.vfid = port;
220e242dd1cSJerin Jacob
221d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, NULL, 0);
222e242dd1cSJerin Jacob if (res < 0)
223e242dd1cSJerin Jacob return -EACCES;
224e242dd1cSJerin Jacob
225e242dd1cSJerin Jacob return res;
226e242dd1cSJerin Jacob }
227e242dd1cSJerin Jacob
228e242dd1cSJerin Jacob int
octeontx_bgx_port_link_status(int port)229e242dd1cSJerin Jacob octeontx_bgx_port_link_status(int port)
230e242dd1cSJerin Jacob {
231e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
232e242dd1cSJerin Jacob uint8_t link;
233e242dd1cSJerin Jacob int len = sizeof(uint8_t);
234e242dd1cSJerin Jacob int res;
235e242dd1cSJerin Jacob
236e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
237e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_GET_LINK_STATUS;
238e242dd1cSJerin Jacob hdr.vfid = port;
239e242dd1cSJerin Jacob
240d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, NULL, 0, &link, len);
241e242dd1cSJerin Jacob if (res < 0)
242e242dd1cSJerin Jacob return -EACCES;
243e242dd1cSJerin Jacob
244e242dd1cSJerin Jacob return link;
245e242dd1cSJerin Jacob }
246e242dd1cSJerin Jacob
247e242dd1cSJerin Jacob int
octeontx_bgx_port_set_link_state(int port,bool enable)2488b42b07eSHarman Kalra octeontx_bgx_port_set_link_state(int port, bool enable)
2498b42b07eSHarman Kalra {
2508b42b07eSHarman Kalra struct octeontx_mbox_hdr hdr;
2518b42b07eSHarman Kalra
2528b42b07eSHarman Kalra hdr.coproc = OCTEONTX_BGX_COPROC;
2538b42b07eSHarman Kalra hdr.msg = MBOX_BGX_PORT_SET_LINK_STATE;
2548b42b07eSHarman Kalra hdr.vfid = port;
2558b42b07eSHarman Kalra
2568b42b07eSHarman Kalra return octeontx_mbox_send(&hdr, &enable, sizeof(bool), NULL, 0);
2578b42b07eSHarman Kalra }
2588b42b07eSHarman Kalra
2598b42b07eSHarman Kalra int
octeontx_bgx_port_promisc_set(int port,int en)260e242dd1cSJerin Jacob octeontx_bgx_port_promisc_set(int port, int en)
261e242dd1cSJerin Jacob {
262e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
263e242dd1cSJerin Jacob uint8_t prom;
264e242dd1cSJerin Jacob int res;
265e242dd1cSJerin Jacob
266e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
267e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_SET_PROMISC;
268e242dd1cSJerin Jacob hdr.vfid = port;
269e242dd1cSJerin Jacob prom = en ? 1 : 0;
270e242dd1cSJerin Jacob
271d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, &prom, sizeof(prom), NULL, 0);
272e242dd1cSJerin Jacob if (res < 0)
273e242dd1cSJerin Jacob return -EACCES;
274e242dd1cSJerin Jacob
275e242dd1cSJerin Jacob return res;
276e242dd1cSJerin Jacob }
277e242dd1cSJerin Jacob
278e242dd1cSJerin Jacob int
octeontx_bgx_port_mtu_set(int port,int mtu)2793151e6a6SHarman Kalra octeontx_bgx_port_mtu_set(int port, int mtu)
2803151e6a6SHarman Kalra {
2813151e6a6SHarman Kalra struct octeontx_mbox_hdr hdr;
2823151e6a6SHarman Kalra int res;
2833151e6a6SHarman Kalra
2843151e6a6SHarman Kalra hdr.coproc = OCTEONTX_BGX_COPROC;
2853151e6a6SHarman Kalra hdr.msg = MBOX_BGX_PORT_SET_MTU;
2863151e6a6SHarman Kalra hdr.vfid = port;
2873151e6a6SHarman Kalra
2883151e6a6SHarman Kalra res = octeontx_mbox_send(&hdr, &mtu, sizeof(mtu), NULL, 0);
2893151e6a6SHarman Kalra if (res < 0)
2903151e6a6SHarman Kalra return -EACCES;
2913151e6a6SHarman Kalra
2923151e6a6SHarman Kalra return res;
2933151e6a6SHarman Kalra }
2943151e6a6SHarman Kalra
2953151e6a6SHarman Kalra int
octeontx_bgx_port_mac_set(int port,uint8_t * mac_addr)296e242dd1cSJerin Jacob octeontx_bgx_port_mac_set(int port, uint8_t *mac_addr)
297e242dd1cSJerin Jacob {
298e242dd1cSJerin Jacob struct octeontx_mbox_hdr hdr;
299e242dd1cSJerin Jacob int len = 6;
300e242dd1cSJerin Jacob int res = 0;
301e242dd1cSJerin Jacob
302e242dd1cSJerin Jacob hdr.coproc = OCTEONTX_BGX_COPROC;
303e242dd1cSJerin Jacob hdr.msg = MBOX_BGX_PORT_SET_MACADDR;
304e242dd1cSJerin Jacob hdr.vfid = port;
305e242dd1cSJerin Jacob
306d8dd3165SPavan Nikhilesh res = octeontx_mbox_send(&hdr, mac_addr, len, NULL, 0);
307e242dd1cSJerin Jacob if (res < 0)
308e242dd1cSJerin Jacob return -EACCES;
309e242dd1cSJerin Jacob
310e242dd1cSJerin Jacob return res;
311e242dd1cSJerin Jacob }
312e4373bf1SSunil Kumar Kori
313e4373bf1SSunil Kumar Kori int
octeontx_bgx_port_mac_add(int port,uint8_t * mac_addr,int index)3149614459bSSunil Kumar Kori octeontx_bgx_port_mac_add(int port, uint8_t *mac_addr, int index)
315e4373bf1SSunil Kumar Kori {
3169614459bSSunil Kumar Kori struct octeontx_mbox_bgx_port_mac_filter filter;
317e4373bf1SSunil Kumar Kori struct octeontx_mbox_hdr hdr;
318e4373bf1SSunil Kumar Kori int len = 6;
319e4373bf1SSunil Kumar Kori
320e4373bf1SSunil Kumar Kori hdr.coproc = OCTEONTX_BGX_COPROC;
321e4373bf1SSunil Kumar Kori hdr.msg = MBOX_BGX_PORT_ADD_MACADDR;
322e4373bf1SSunil Kumar Kori hdr.vfid = port;
323e4373bf1SSunil Kumar Kori
3249614459bSSunil Kumar Kori memcpy(filter.mac_addr, mac_addr, len);
3259614459bSSunil Kumar Kori filter.index = index;
3269614459bSSunil Kumar Kori len = sizeof(struct octeontx_mbox_bgx_port_mac_filter);
327e4373bf1SSunil Kumar Kori
3289614459bSSunil Kumar Kori return octeontx_mbox_send(&hdr, &filter, len, NULL, 0);
329e4373bf1SSunil Kumar Kori }
330e4373bf1SSunil Kumar Kori
331e4373bf1SSunil Kumar Kori int
octeontx_bgx_port_mac_del(int port,uint32_t index)332e4373bf1SSunil Kumar Kori octeontx_bgx_port_mac_del(int port, uint32_t index)
333e4373bf1SSunil Kumar Kori {
334e4373bf1SSunil Kumar Kori struct octeontx_mbox_hdr hdr;
335e4373bf1SSunil Kumar Kori int len = sizeof(uint32_t);
336e4373bf1SSunil Kumar Kori int res = 0;
337e4373bf1SSunil Kumar Kori
338e4373bf1SSunil Kumar Kori hdr.coproc = OCTEONTX_BGX_COPROC;
339e4373bf1SSunil Kumar Kori hdr.msg = MBOX_BGX_PORT_DEL_MACADDR;
340e4373bf1SSunil Kumar Kori hdr.vfid = port;
341e4373bf1SSunil Kumar Kori
342e4373bf1SSunil Kumar Kori res = octeontx_mbox_send(&hdr, &index, len, NULL, 0);
343e4373bf1SSunil Kumar Kori if (res < 0)
344e4373bf1SSunil Kumar Kori return -EACCES;
345e4373bf1SSunil Kumar Kori
346e4373bf1SSunil Kumar Kori return res;
347e4373bf1SSunil Kumar Kori }
348e4373bf1SSunil Kumar Kori
349e4373bf1SSunil Kumar Kori int
octeontx_bgx_port_mac_entries_get(int port)350e4373bf1SSunil Kumar Kori octeontx_bgx_port_mac_entries_get(int port)
351e4373bf1SSunil Kumar Kori {
352e4373bf1SSunil Kumar Kori struct octeontx_mbox_hdr hdr;
353e4373bf1SSunil Kumar Kori int resp = 6;
354e4373bf1SSunil Kumar Kori int res = 0;
355e4373bf1SSunil Kumar Kori
356e4373bf1SSunil Kumar Kori hdr.coproc = OCTEONTX_BGX_COPROC;
357e4373bf1SSunil Kumar Kori hdr.msg = MBOX_BGX_PORT_GET_MACADDR_ENTRIES;
358e4373bf1SSunil Kumar Kori hdr.vfid = port;
359e4373bf1SSunil Kumar Kori
360e4373bf1SSunil Kumar Kori res = octeontx_mbox_send(&hdr, NULL, 0, &resp, sizeof(int));
361e4373bf1SSunil Kumar Kori if (res < 0)
362e4373bf1SSunil Kumar Kori return -EACCES;
363e4373bf1SSunil Kumar Kori
364e4373bf1SSunil Kumar Kori return resp;
365e4373bf1SSunil Kumar Kori }
366241a6500SVamsi Attunuru
octeontx_bgx_port_get_fifo_cfg(int port,octeontx_mbox_bgx_port_fifo_cfg_t * cfg)367241a6500SVamsi Attunuru int octeontx_bgx_port_get_fifo_cfg(int port,
368241a6500SVamsi Attunuru octeontx_mbox_bgx_port_fifo_cfg_t *cfg)
369241a6500SVamsi Attunuru {
370241a6500SVamsi Attunuru int len = sizeof(octeontx_mbox_bgx_port_fifo_cfg_t);
371241a6500SVamsi Attunuru octeontx_mbox_bgx_port_fifo_cfg_t conf;
372241a6500SVamsi Attunuru struct octeontx_mbox_hdr hdr;
373241a6500SVamsi Attunuru
374241a6500SVamsi Attunuru hdr.coproc = OCTEONTX_BGX_COPROC;
375241a6500SVamsi Attunuru hdr.msg = MBOX_BGX_PORT_GET_FIFO_CFG;
376241a6500SVamsi Attunuru hdr.vfid = port;
377241a6500SVamsi Attunuru
378241a6500SVamsi Attunuru if (octeontx_mbox_send(&hdr, NULL, 0, &conf, len) < 0)
379241a6500SVamsi Attunuru return -EACCES;
380241a6500SVamsi Attunuru
381241a6500SVamsi Attunuru cfg->rx_fifosz = conf.rx_fifosz;
382241a6500SVamsi Attunuru
383241a6500SVamsi Attunuru return 0;
384241a6500SVamsi Attunuru }
385241a6500SVamsi Attunuru
octeontx_bgx_port_flow_ctrl_cfg(int port,octeontx_mbox_bgx_port_fc_cfg_t * cfg)386241a6500SVamsi Attunuru int octeontx_bgx_port_flow_ctrl_cfg(int port,
387241a6500SVamsi Attunuru octeontx_mbox_bgx_port_fc_cfg_t *cfg)
388241a6500SVamsi Attunuru {
389241a6500SVamsi Attunuru int len = sizeof(octeontx_mbox_bgx_port_fc_cfg_t);
390241a6500SVamsi Attunuru octeontx_mbox_bgx_port_fc_cfg_t conf;
391241a6500SVamsi Attunuru struct octeontx_mbox_hdr hdr;
392241a6500SVamsi Attunuru
393241a6500SVamsi Attunuru hdr.coproc = OCTEONTX_BGX_COPROC;
394241a6500SVamsi Attunuru hdr.msg = MBOX_BGX_PORT_FLOW_CTRL_CFG;
395241a6500SVamsi Attunuru hdr.vfid = port;
396241a6500SVamsi Attunuru
397241a6500SVamsi Attunuru if (cfg->fc_cfg == BGX_PORT_FC_CFG_SET)
398241a6500SVamsi Attunuru memcpy(&conf, cfg, len);
399241a6500SVamsi Attunuru else
400241a6500SVamsi Attunuru memset(&conf, 0, len);
401241a6500SVamsi Attunuru
402241a6500SVamsi Attunuru if (octeontx_mbox_send(&hdr, &conf, len, &conf, len) < 0)
403241a6500SVamsi Attunuru return -EACCES;
404241a6500SVamsi Attunuru
405241a6500SVamsi Attunuru if (cfg->fc_cfg == BGX_PORT_FC_CFG_SET)
406241a6500SVamsi Attunuru goto done;
407241a6500SVamsi Attunuru
408241a6500SVamsi Attunuru cfg->rx_pause = conf.rx_pause;
409241a6500SVamsi Attunuru cfg->tx_pause = conf.tx_pause;
410241a6500SVamsi Attunuru cfg->low_water = conf.low_water;
411241a6500SVamsi Attunuru cfg->high_water = conf.high_water;
412241a6500SVamsi Attunuru
413241a6500SVamsi Attunuru done:
414241a6500SVamsi Attunuru return 0;
415241a6500SVamsi Attunuru }
416a84ff1d9SHarman Kalra
octeontx_bgx_port_change_mode(int port,octeontx_mbox_bgx_port_change_mode_t * cfg)417a84ff1d9SHarman Kalra int octeontx_bgx_port_change_mode(int port,
418a84ff1d9SHarman Kalra octeontx_mbox_bgx_port_change_mode_t *cfg)
419a84ff1d9SHarman Kalra {
420a84ff1d9SHarman Kalra int len = sizeof(octeontx_mbox_bgx_port_change_mode_t), res;
421a84ff1d9SHarman Kalra octeontx_mbox_bgx_port_change_mode_t conf;
422a84ff1d9SHarman Kalra struct octeontx_mbox_hdr hdr;
423a84ff1d9SHarman Kalra
424a84ff1d9SHarman Kalra hdr.coproc = OCTEONTX_BGX_COPROC;
425a84ff1d9SHarman Kalra hdr.msg = MBOX_BGX_PORT_CHANGE_MODE;
426a84ff1d9SHarman Kalra hdr.vfid = port;
427a84ff1d9SHarman Kalra
428a84ff1d9SHarman Kalra memcpy(&conf, cfg, len);
429a84ff1d9SHarman Kalra res = octeontx_mbox_send(&hdr, &conf, len, NULL, 0);
430a84ff1d9SHarman Kalra if (res < 0)
431a84ff1d9SHarman Kalra return -EACCES;
432a84ff1d9SHarman Kalra
433a84ff1d9SHarman Kalra return res;
434a84ff1d9SHarman Kalra }
435