// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
/* Copyright (C) 2017 Netronome Systems, Inc. */

#include "../nfpcore/nfp_cpp.h"
#include "../nfpcore/nfp_nsp.h"
#include "../nfp_app.h"
#include "../nfp_main.h"
#include "../nfp_net.h"
#include "main.h"

static int nfp_nic_init(struct nfp_app *app)
{
	struct nfp_pf *pf = app->pf;

	if (pf->eth_tbl && pf->max_data_vnics != pf->eth_tbl->count) {
		nfp_err(pf->cpp, "ETH entries don't match vNICs (%d vs %d)\n",
			pf->max_data_vnics, pf->eth_tbl->count);
		return -EINVAL;
	}

	return 0;
}

static int nfp_nic_sriov_enable(struct nfp_app *app, int num_vfs)
{
	return 0;
}

static void nfp_nic_sriov_disable(struct nfp_app *app)
{
}

static int nfp_nic_vnic_init(struct nfp_app *app, struct nfp_net *nn)
{
	return nfp_nic_dcb_init(nn);
}

static void nfp_nic_vnic_clean(struct nfp_app *app, struct nfp_net *nn)
{
	nfp_nic_dcb_clean(nn);
}

static int nfp_nic_vnic_alloc(struct nfp_app *app, struct nfp_net *nn,
			      unsigned int id)
{
	struct nfp_app_nic_private *app_pri = nn->app_priv;
	int err;

	err = nfp_app_nic_vnic_alloc(app, nn, id);
	if (err)
		return err;

	if (sizeof(*app_pri)) {
		nn->app_priv = kzalloc(sizeof(*app_pri), GFP_KERNEL);
		if (!nn->app_priv)
			return -ENOMEM;
	}

	return 0;
}

static void nfp_nic_vnic_free(struct nfp_app *app, struct nfp_net *nn)
{
	kfree(nn->app_priv);
}

const struct nfp_app_type app_nic = {
	.id		= NFP_APP_CORE_NIC,
	.name		= "nic",

	.init		= nfp_nic_init,
	.vnic_alloc	= nfp_nic_vnic_alloc,
	.vnic_free	= nfp_nic_vnic_free,
	.sriov_enable	= nfp_nic_sriov_enable,
	.sriov_disable	= nfp_nic_sriov_disable,

	.vnic_init      = nfp_nic_vnic_init,
	.vnic_clean     = nfp_nic_vnic_clean,
}