2018-10-11 23:57:42 +08:00
|
|
|
// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
|
|
/* Copyright (C) 2017-2018 Netronome Systems, Inc. */
|
2017-05-31 23:06:46 +08:00
|
|
|
|
|
|
|
#include "nfpcore/nfp_cpp.h"
|
|
|
|
#include "nfpcore/nfp_nsp.h"
|
|
|
|
#include "nfp_app.h"
|
|
|
|
#include "nfp_main.h"
|
|
|
|
#include "nfp_net.h"
|
|
|
|
#include "nfp_port.h"
|
|
|
|
|
2018-05-22 13:12:48 +08:00
|
|
|
int nfp_app_nic_vnic_init_phy_port(struct nfp_pf *pf, struct nfp_app *app,
|
|
|
|
struct nfp_net *nn, unsigned int id)
|
2017-05-31 23:06:46 +08:00
|
|
|
{
|
2017-06-24 04:12:00 +08:00
|
|
|
int err;
|
|
|
|
|
2017-05-31 23:06:46 +08:00
|
|
|
if (!pf->eth_tbl)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
nn->port = nfp_port_alloc(app, NFP_PORT_PHYS_PORT, nn->dp.netdev);
|
|
|
|
if (IS_ERR(nn->port))
|
|
|
|
return PTR_ERR(nn->port);
|
|
|
|
|
2017-06-24 04:12:00 +08:00
|
|
|
err = nfp_port_init_phy_port(pf, app, nn->port, id);
|
|
|
|
if (err) {
|
2017-05-31 23:06:46 +08:00
|
|
|
nfp_port_free(nn->port);
|
2017-06-24 04:12:00 +08:00
|
|
|
return err;
|
2017-05-31 23:06:46 +08:00
|
|
|
}
|
|
|
|
|
2017-06-24 04:12:00 +08:00
|
|
|
return nn->port->type == NFP_PORT_INVALID;
|
2017-05-31 23:06:46 +08:00
|
|
|
}
|
|
|
|
|
2017-09-03 09:26:00 +08:00
|
|
|
int nfp_app_nic_vnic_alloc(struct nfp_app *app, struct nfp_net *nn,
|
|
|
|
unsigned int id)
|
2017-05-31 23:06:46 +08:00
|
|
|
{
|
|
|
|
int err;
|
|
|
|
|
|
|
|
err = nfp_app_nic_vnic_init_phy_port(app->pf, app, nn, id);
|
|
|
|
if (err)
|
|
|
|
return err < 0 ? err : 0;
|
|
|
|
|
2018-04-26 02:21:08 +08:00
|
|
|
nfp_net_get_mac_addr(app->pf, nn->dp.netdev, nn->port);
|
2017-05-31 23:06:46 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|