2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: (BSD-3-Clause OR GPL-2.0)
|
2018-05-15 09:49:22 +00:00
|
|
|
*
|
|
|
|
* Copyright 2010-2016 Freescale Semiconductor Inc.
|
2020-06-18 16:55:50 +00:00
|
|
|
* Copyright 2017-2019 NXP
|
2018-05-15 09:49:22 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
#include <inttypes.h>
|
2020-06-18 16:55:50 +00:00
|
|
|
#include <dpaa_of.h>
|
2018-05-15 09:49:22 +00:00
|
|
|
#include <net/if.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <error.h>
|
|
|
|
#include <net/if_arp.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include <rte_malloc.h>
|
|
|
|
|
|
|
|
#include <rte_dpaa_logs.h>
|
|
|
|
#include <netcfg.h>
|
|
|
|
|
|
|
|
/* This data structure contaings all configurations information
|
|
|
|
* related to usages of DPA devices.
|
|
|
|
*/
|
2019-06-25 11:12:58 +00:00
|
|
|
static struct netcfg_info *netcfg;
|
2018-05-15 09:49:22 +00:00
|
|
|
/* fd to open a socket for making ioctl request to disable/enable shared
|
|
|
|
* interfaces.
|
|
|
|
*/
|
|
|
|
static int skfd = -1;
|
|
|
|
|
|
|
|
#ifdef RTE_LIBRTE_DPAA_DEBUG_DRIVER
|
|
|
|
void
|
|
|
|
dump_netcfg(struct netcfg_info *cfg_ptr)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
printf(".......... DPAA Configuration ..........\n\n");
|
|
|
|
|
|
|
|
/* Network interfaces */
|
|
|
|
printf("Network interfaces: %d\n", cfg_ptr->num_ethports);
|
|
|
|
for (i = 0; i < cfg_ptr->num_ethports; i++) {
|
|
|
|
struct fman_if_bpool *bpool;
|
|
|
|
struct fm_eth_port_cfg *p_cfg = &cfg_ptr->port_cfg[i];
|
|
|
|
struct fman_if *__if = p_cfg->fman_if;
|
|
|
|
|
|
|
|
printf("\n+ Fman %d, MAC %d (%s);\n",
|
|
|
|
__if->fman_idx, __if->mac_idx,
|
2021-02-05 08:48:47 +00:00
|
|
|
(__if->mac_type == fman_mac_1g) ? "1G" :
|
|
|
|
(__if->mac_type == fman_mac_2_5g) ? "2.5G" : "10G");
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
printf("\tmac_addr: %02x:%02x:%02x:%02x:%02x:%02x\n",
|
|
|
|
(&__if->mac_addr)->addr_bytes[0],
|
|
|
|
(&__if->mac_addr)->addr_bytes[1],
|
|
|
|
(&__if->mac_addr)->addr_bytes[2],
|
|
|
|
(&__if->mac_addr)->addr_bytes[3],
|
|
|
|
(&__if->mac_addr)->addr_bytes[4],
|
|
|
|
(&__if->mac_addr)->addr_bytes[5]);
|
|
|
|
|
|
|
|
printf("\ttx_channel_id: 0x%02x\n",
|
|
|
|
__if->tx_channel_id);
|
|
|
|
|
|
|
|
printf("\tfqid_rx_def: 0x%x\n", p_cfg->rx_def);
|
|
|
|
printf("\tfqid_rx_err: 0x%x\n", __if->fqid_rx_err);
|
|
|
|
|
|
|
|
printf("\tfqid_tx_err: 0x%x\n", __if->fqid_tx_err);
|
|
|
|
printf("\tfqid_tx_confirm: 0x%x\n", __if->fqid_tx_confirm);
|
|
|
|
fman_if_for_each_bpool(bpool, __if)
|
|
|
|
printf("\tbuffer pool: (bpid=%d, count=%"PRId64
|
|
|
|
" size=%"PRId64", addr=0x%"PRIx64")\n",
|
|
|
|
bpool->bpid, bpool->count, bpool->size,
|
|
|
|
bpool->addr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* RTE_LIBRTE_DPAA_DEBUG_DRIVER */
|
|
|
|
|
|
|
|
struct netcfg_info *
|
|
|
|
netcfg_acquire(void)
|
|
|
|
{
|
|
|
|
struct fman_if *__if;
|
|
|
|
int _errno, idx = 0;
|
|
|
|
uint8_t num_ports = 0;
|
|
|
|
uint8_t num_cfg_ports = 0;
|
|
|
|
size_t size;
|
|
|
|
|
|
|
|
/* Extract dpa configuration from fman driver and FMC configuration
|
|
|
|
* for command-line interfaces.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Open a basic socket to enable/disable shared
|
|
|
|
* interfaces.
|
|
|
|
*/
|
|
|
|
skfd = socket(AF_PACKET, SOCK_RAW, 0);
|
|
|
|
if (unlikely(skfd < 0)) {
|
|
|
|
error(0, errno, "%s(): open(SOCK_RAW)", __func__);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialise the Fman driver */
|
|
|
|
_errno = fman_init();
|
|
|
|
if (_errno) {
|
|
|
|
DPAA_BUS_LOG(ERR, "FMAN driver init failed (%d)", errno);
|
|
|
|
close(skfd);
|
|
|
|
skfd = -1;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Number of MAC ports */
|
|
|
|
list_for_each_entry(__if, fman_if_list, node)
|
|
|
|
num_ports++;
|
|
|
|
|
|
|
|
if (!num_ports) {
|
|
|
|
DPAA_BUS_LOG(ERR, "FMAN ports not available");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
/* Allocate space for all enabled mac ports */
|
|
|
|
size = sizeof(*netcfg) +
|
|
|
|
(num_ports * sizeof(struct fm_eth_port_cfg));
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
netcfg = rte_calloc(NULL, 1, size, 0);
|
2018-05-15 09:49:22 +00:00
|
|
|
if (unlikely(netcfg == NULL)) {
|
|
|
|
DPAA_BUS_LOG(ERR, "Unable to allocat mem for netcfg");
|
|
|
|
goto error;
|
|
|
|
}
|
|
|
|
|
|
|
|
netcfg->num_ethports = num_ports;
|
|
|
|
|
|
|
|
list_for_each_entry(__if, fman_if_list, node) {
|
|
|
|
struct fm_eth_port_cfg *cfg = &netcfg->port_cfg[idx];
|
|
|
|
/* Hook in the fman driver interface */
|
|
|
|
cfg->fman_if = __if;
|
|
|
|
cfg->rx_def = __if->fqid_rx_def;
|
|
|
|
num_cfg_ports++;
|
|
|
|
idx++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!num_cfg_ports) {
|
|
|
|
DPAA_BUS_LOG(ERR, "No FMAN ports found");
|
|
|
|
goto error;
|
|
|
|
} else if (num_ports != num_cfg_ports)
|
|
|
|
netcfg->num_ethports = num_cfg_ports;
|
|
|
|
|
|
|
|
return netcfg;
|
|
|
|
|
|
|
|
error:
|
|
|
|
if (netcfg) {
|
2020-06-18 16:55:50 +00:00
|
|
|
rte_free(netcfg);
|
2018-05-15 09:49:22 +00:00
|
|
|
netcfg = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
netcfg_release(struct netcfg_info *cfg_ptr)
|
|
|
|
{
|
2020-06-18 16:55:50 +00:00
|
|
|
rte_free(cfg_ptr);
|
2018-05-15 09:49:22 +00:00
|
|
|
/* Close socket for shared interfaces */
|
|
|
|
if (skfd >= 0) {
|
|
|
|
close(skfd);
|
|
|
|
skfd = -1;
|
|
|
|
}
|
|
|
|
}
|