/*
// Copyright (c) 2010-2017 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
*/

#ifndef _PROX_PORT_CFG_H
#define _PROX_PORT_CFG_H

#include <rte_pci.h>
#include <rte_ether.h>
#include <rte_ethdev.h>
#include <rte_version.h>
#if RTE_VERSION >= RTE_VERSION_NUM(17,11,0,0)
#include <rte_bus_pci.h>
#endif
#include <rte_pci.h>

#include "prox_globals.h"

enum addr_type {PROX_PORT_MAC_HW, PROX_PORT_MAC_SET, PROX_PORT_MAC_RAND};

#define IPV4_CKSUM	1
#define UDP_CKSUM	2

struct prox_port_cfg {
	struct rte_mempool *pool[32];  /* Rx/Tx mempool */
	size_t pool_size[32];
	uint8_t promiscuous;
	uint8_t lsc_set_explicitely; /* Explicitly enable/disable lsc */
	uint8_t lsc_val;
	uint8_t active;
	int socket;
	uint16_t max_rxq;         /* max number of Tx queues */
	uint16_t max_txq;         /* max number of Tx queues */
	uint16_t n_rxq;           /* number of used Rx queues */
	uint16_t n_txq;           /* number of used Tx queues */
	uint32_t n_rxd;
	uint32_t n_txd;
	uint8_t  link_up;
	uint32_t  link_speed;
	uint32_t  mtu;
	enum addr_type    type;
	struct ether_addr eth_addr;    /* port MAC address */
	char name[MAX_NAME_SIZE];
	char short_name[MAX_NAME_SIZE];
	char driver_name[MAX_NAME_SIZE];
	char rx_ring[MAX_NAME_SIZE];
	char tx_ring[MAX_NAME_SIZE];
	char pci_addr[32];
	struct rte_eth_conf port_conf;
	struct rte_eth_rxconf rx_conf;
	struct rte_eth_txconf tx_conf;
	uint64_t requested_rx_offload;
	uint64_t requested_tx_offload;
	uint64_t disabled_tx_offload;
	struct rte_eth_dev_info dev_info;
	struct {
		int tx_offload_cksum;
	} capabilities;
	uint32_t max_rx_pkt_len;
	uint32_t min_rx_bufsize;
};

extern rte_atomic32_t lsc;

int prox_nb_active_ports(void);
int prox_last_port_active(void);

extern struct prox_port_cfg prox_port_cfg[];

void init_rte_dev(int use_dummy_devices);
uint8_t init_rte_ring_dev(void);
void init_port_addr(void);
void init_port_all(void);
void close_ports_atexit(void);

struct rte_mempool;

void prox_pktmbuf_init(struct rte_mempool *mp, void *opaque_arg, void *_m, unsigned i);
void prox_pktmbuf_reinit(void *arg, void *start, void *end, uint32_t idx);

int port_is_active(uint8_t port_id);

#endif /* __PROX_PORT_CFG_H_ */