xref: /dpdk/drivers/net/octeontx/base/octeontx_bgx.c (revision 72b452c5f2599f970f47fd17d3e8e5d60bfebe7a)
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