2018-05-11 16:31:30 +08:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2010-2018 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _IFPGA_FEATURE_DEV_H_
|
|
|
|
#define _IFPGA_FEATURE_DEV_H_
|
|
|
|
|
|
|
|
#include "ifpga_hw.h"
|
|
|
|
|
2019-04-16 11:17:45 +08:00
|
|
|
struct feature_driver {
|
|
|
|
u64 id;
|
|
|
|
const char *name;
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature_ops *ops;
|
2019-04-16 11:17:45 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* FEATURE_DRV - macro used to describe a specific feature driver
|
|
|
|
*/
|
|
|
|
#define FEATURE_DRV(n, s, p) \
|
|
|
|
.id = (n), .name = (s), .ops = (p)
|
|
|
|
|
2018-05-11 16:31:30 +08:00
|
|
|
static inline struct ifpga_port_hw *
|
|
|
|
get_port(struct ifpga_hw *hw, u32 port_id)
|
|
|
|
{
|
|
|
|
if (!is_valid_port_id(hw, port_id))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
return &hw->port[port_id];
|
|
|
|
}
|
|
|
|
|
2018-05-14 17:58:37 +08:00
|
|
|
#define ifpga_for_each_fme_feature(hw, feature) \
|
2019-04-16 11:17:45 +08:00
|
|
|
TAILQ_FOREACH(feature, &hw->feature_list, next)
|
2018-05-11 16:31:30 +08:00
|
|
|
|
2019-04-16 11:17:45 +08:00
|
|
|
#define ifpga_for_each_port_feature(port, feature) \
|
|
|
|
TAILQ_FOREACH(feature, &port->feature_list, next)
|
2018-05-14 17:58:37 +08:00
|
|
|
|
2019-04-16 11:17:50 +08:00
|
|
|
static inline struct ifpga_feature *
|
2018-05-11 16:31:30 +08:00
|
|
|
get_fme_feature_by_id(struct ifpga_fme_hw *fme, u64 id)
|
|
|
|
{
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature *feature;
|
2018-05-11 16:31:30 +08:00
|
|
|
|
2018-05-14 17:58:37 +08:00
|
|
|
ifpga_for_each_fme_feature(fme, feature) {
|
2018-05-11 16:31:30 +08:00
|
|
|
if (feature->id == id)
|
|
|
|
return feature;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-04-16 11:17:50 +08:00
|
|
|
static inline struct ifpga_feature *
|
2018-05-11 16:31:30 +08:00
|
|
|
get_port_feature_by_id(struct ifpga_port_hw *port, u64 id)
|
|
|
|
{
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature *feature;
|
2018-05-11 16:31:30 +08:00
|
|
|
|
2018-05-14 17:58:37 +08:00
|
|
|
ifpga_for_each_port_feature(port, feature) {
|
2018-05-11 16:31:30 +08:00
|
|
|
if (feature->id == id)
|
|
|
|
return feature;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-04-16 11:17:50 +08:00
|
|
|
static inline struct ifpga_feature *
|
2019-04-16 11:17:45 +08:00
|
|
|
get_feature_by_id(struct ifpga_feature_list *list, u64 id)
|
|
|
|
{
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature *feature;
|
2019-04-16 11:17:45 +08:00
|
|
|
|
|
|
|
TAILQ_FOREACH(feature, list, next)
|
|
|
|
if (feature->id == id)
|
|
|
|
return feature;
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2018-05-11 16:31:30 +08:00
|
|
|
static inline void *
|
|
|
|
get_fme_feature_ioaddr_by_index(struct ifpga_fme_hw *fme, int index)
|
|
|
|
{
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature *feature =
|
|
|
|
get_feature_by_id(&fme->feature_list, index);
|
2019-04-16 11:17:45 +08:00
|
|
|
|
|
|
|
return feature ? feature->addr : NULL;
|
2018-05-11 16:31:30 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *
|
|
|
|
get_port_feature_ioaddr_by_index(struct ifpga_port_hw *port, int index)
|
|
|
|
{
|
2019-04-16 11:17:50 +08:00
|
|
|
struct ifpga_feature *feature =
|
|
|
|
get_feature_by_id(&port->feature_list, index);
|
2019-04-16 11:17:45 +08:00
|
|
|
|
|
|
|
return feature ? feature->addr : NULL;
|
2018-05-11 16:31:30 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool
|
|
|
|
is_fme_feature_present(struct ifpga_fme_hw *fme, int index)
|
|
|
|
{
|
|
|
|
return !!get_fme_feature_ioaddr_by_index(fme, index);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool
|
|
|
|
is_port_feature_present(struct ifpga_port_hw *port, int index)
|
|
|
|
{
|
|
|
|
return !!get_port_feature_ioaddr_by_index(port, index);
|
|
|
|
}
|
|
|
|
|
|
|
|
int fpga_get_afu_uuid(struct ifpga_port_hw *port, struct uuid *uuid);
|
|
|
|
|
|
|
|
int __fpga_port_disable(struct ifpga_port_hw *port);
|
|
|
|
void __fpga_port_enable(struct ifpga_port_hw *port);
|
|
|
|
|
|
|
|
static inline int fpga_port_disable(struct ifpga_port_hw *port)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
spinlock_lock(&port->lock);
|
|
|
|
ret = __fpga_port_disable(port);
|
|
|
|
spinlock_unlock(&port->lock);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int fpga_port_enable(struct ifpga_port_hw *port)
|
|
|
|
{
|
|
|
|
spinlock_lock(&port->lock);
|
|
|
|
__fpga_port_enable(port);
|
|
|
|
spinlock_unlock(&port->lock);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int __fpga_port_reset(struct ifpga_port_hw *port)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
ret = __fpga_port_disable(port);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
__fpga_port_enable(port);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int fpga_port_reset(struct ifpga_port_hw *port)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
spinlock_lock(&port->lock);
|
|
|
|
ret = __fpga_port_reset(port);
|
|
|
|
spinlock_unlock(&port->lock);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2019-06-21 16:40:13 +08:00
|
|
|
int do_pr(struct ifpga_hw *hw, u32 port_id, const char *buffer, u32 size,
|
2018-05-11 16:31:30 +08:00
|
|
|
u64 *status);
|
|
|
|
|
|
|
|
int fme_get_prop(struct ifpga_fme_hw *fme, struct feature_prop *prop);
|
|
|
|
int fme_set_prop(struct ifpga_fme_hw *fme, struct feature_prop *prop);
|
|
|
|
int fme_set_irq(struct ifpga_fme_hw *fme, u32 feature_id, void *irq_set);
|
|
|
|
|
|
|
|
int fme_hw_init(struct ifpga_fme_hw *fme);
|
|
|
|
void fme_hw_uinit(struct ifpga_fme_hw *fme);
|
|
|
|
void port_hw_uinit(struct ifpga_port_hw *port);
|
|
|
|
int port_hw_init(struct ifpga_port_hw *port);
|
|
|
|
int port_clear_error(struct ifpga_port_hw *port);
|
|
|
|
void port_err_mask(struct ifpga_port_hw *port, bool mask);
|
|
|
|
int port_err_clear(struct ifpga_port_hw *port, u64 err);
|
|
|
|
|
2019-04-16 11:17:50 +08:00
|
|
|
extern struct ifpga_feature_ops fme_hdr_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_thermal_mgmt_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_power_mgmt_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_global_err_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_pr_mgmt_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_global_iperf_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_global_dperf_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_hssi_eth_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_emif_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_spi_master_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_i2c_master_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_eth_group_ops;
|
|
|
|
extern struct ifpga_feature_ops fme_nios_spi_master_ops;
|
2018-05-11 16:31:30 +08:00
|
|
|
|
|
|
|
int port_get_prop(struct ifpga_port_hw *port, struct feature_prop *prop);
|
|
|
|
int port_set_prop(struct ifpga_port_hw *port, struct feature_prop *prop);
|
|
|
|
|
|
|
|
/* This struct is used when parsing uafu irq_set */
|
|
|
|
struct fpga_uafu_irq_set {
|
|
|
|
u32 start;
|
|
|
|
u32 count;
|
|
|
|
s32 *evtfds;
|
|
|
|
};
|
|
|
|
|
|
|
|
int port_set_irq(struct ifpga_port_hw *port, u32 feature_id, void *irq_set);
|
2019-04-16 11:17:45 +08:00
|
|
|
const char *get_fme_feature_name(unsigned int id);
|
|
|
|
const char *get_port_feature_name(unsigned int id);
|
2018-05-11 16:31:30 +08:00
|
|
|
|
2019-04-16 11:17:50 +08:00
|
|
|
extern struct ifpga_feature_ops ifpga_rawdev_port_hdr_ops;
|
|
|
|
extern struct ifpga_feature_ops ifpga_rawdev_port_error_ops;
|
|
|
|
extern struct ifpga_feature_ops ifpga_rawdev_port_stp_ops;
|
|
|
|
extern struct ifpga_feature_ops ifpga_rawdev_port_uint_ops;
|
|
|
|
extern struct ifpga_feature_ops ifpga_rawdev_port_afu_ops;
|
2018-05-11 16:31:30 +08:00
|
|
|
|
|
|
|
/* help functions for feature ops */
|
2019-04-16 11:17:50 +08:00
|
|
|
int fpga_msix_set_block(struct ifpga_feature *feature, unsigned int start,
|
2018-05-11 16:31:30 +08:00
|
|
|
unsigned int count, s32 *fds);
|
2019-04-16 11:17:47 +08:00
|
|
|
|
|
|
|
/* FME network function ops*/
|
|
|
|
int fme_mgr_read_mac_rom(struct ifpga_fme_hw *fme, int offset,
|
|
|
|
void *buf, int size);
|
|
|
|
int fme_mgr_write_mac_rom(struct ifpga_fme_hw *fme, int offset,
|
|
|
|
void *buf, int size);
|
2019-04-16 11:17:48 +08:00
|
|
|
int fme_mgr_get_eth_group_nums(struct ifpga_fme_hw *fme);
|
|
|
|
int fme_mgr_get_eth_group_info(struct ifpga_fme_hw *fme,
|
|
|
|
u8 group_id, struct opae_eth_group_info *info);
|
|
|
|
int fme_mgr_eth_group_read_reg(struct ifpga_fme_hw *fme, u8 group_id,
|
|
|
|
u8 type, u8 index, u16 addr, u32 *data);
|
|
|
|
int fme_mgr_eth_group_write_reg(struct ifpga_fme_hw *fme, u8 group_id,
|
|
|
|
u8 type, u8 index, u16 addr, u32 data);
|
|
|
|
int fme_mgr_get_retimer_info(struct ifpga_fme_hw *fme,
|
|
|
|
struct opae_retimer_info *info);
|
|
|
|
int fme_mgr_get_retimer_status(struct ifpga_fme_hw *fme,
|
|
|
|
struct opae_retimer_status *status);
|
2019-11-14 17:02:56 +08:00
|
|
|
int fme_mgr_get_sensor_value(struct ifpga_fme_hw *fme,
|
|
|
|
struct opae_sensor_info *sensor,
|
|
|
|
unsigned int *value);
|
2018-05-11 16:31:30 +08:00
|
|
|
#endif /* _IFPGA_FEATURE_DEV_H_ */
|