mirror of https://github.com/F-Stack/f-stack.git
65 lines
1.5 KiB
C
65 lines
1.5 KiB
C
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||
|
* Copyright 2018-2019 NXP
|
||
|
*/
|
||
|
|
||
|
#ifndef _PFE_MOD_H_
|
||
|
#define _PFE_MOD_H_
|
||
|
|
||
|
struct pfe;
|
||
|
|
||
|
#include <rte_ethdev.h>
|
||
|
|
||
|
#include "pfe.h"
|
||
|
#include "pfe_hif.h"
|
||
|
#include "pfe_hif_lib.h"
|
||
|
#include "pfe_eth.h"
|
||
|
|
||
|
#define PHYID_MAX_VAL 32
|
||
|
|
||
|
/* PFE DPDK driver supports two interfaces.
|
||
|
*/
|
||
|
#define PFE_CDEV_ETH_COUNT 2
|
||
|
|
||
|
/* PFE DPDK driver needs a kernel module named "pfe.ko", This module
|
||
|
* is required for PHY initialisation and creates a character device
|
||
|
* "pfe_us_cdev" for IOCTL support. PFE DPDK driver uses this character
|
||
|
* device for link status.
|
||
|
*/
|
||
|
#define PFE_CDEV_PATH "/dev/pfe_us_cdev"
|
||
|
#define PFE_CDEV_INVALID_FD -1
|
||
|
#define PFE_NAME_PMD net_pfe
|
||
|
|
||
|
/* used when 'read' call is issued, returning PFE_CDEV_ETH_COUNT number of
|
||
|
* pfe_shared_info as array.
|
||
|
*/
|
||
|
struct pfe_shared_info {
|
||
|
uint32_t phy_id; /* Link phy ID */
|
||
|
uint8_t state; /* Has either 0 or 1 */
|
||
|
};
|
||
|
|
||
|
struct pfe_eth {
|
||
|
struct pfe_eth_priv_s *eth_priv[PFE_CDEV_ETH_COUNT];
|
||
|
};
|
||
|
|
||
|
struct pfe {
|
||
|
uint64_t ddr_phys_baseaddr;
|
||
|
void *ddr_baseaddr;
|
||
|
uint64_t ddr_size;
|
||
|
void *cbus_baseaddr;
|
||
|
uint64_t cbus_size;
|
||
|
struct ls1012a_pfe_platform_data platform_data;
|
||
|
struct pfe_hif hif;
|
||
|
struct pfe_eth eth;
|
||
|
struct hif_client_s *hif_client[HIF_CLIENTS_MAX];
|
||
|
int mdio_muxval[PHYID_MAX_VAL];
|
||
|
uint8_t nb_devs;
|
||
|
uint8_t max_intf;
|
||
|
int cdev_fd;
|
||
|
};
|
||
|
|
||
|
/* IOCTL Commands */
|
||
|
#define PFE_CDEV_ETH0_STATE_GET _IOR('R', 0, int)
|
||
|
#define PFE_CDEV_ETH1_STATE_GET _IOR('R', 1, int)
|
||
|
#define PFE_CDEV_HIF_INTR_EN _IOWR('R', 2, int)
|
||
|
#endif /* _PFE_MOD_H */
|