2015-05-06 06:55:13 +07:00
|
|
|
/****************************************************************************
|
|
|
|
* Driver for Solarflare network controllers and boards
|
|
|
|
* Copyright 2015 Solarflare Communications Inc.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 as published
|
|
|
|
* by the Free Software Foundation, incorporated herein by reference.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef EF10_SRIOV_H
|
|
|
|
#define EF10_SRIOV_H
|
|
|
|
|
|
|
|
#include "net_driver.h"
|
|
|
|
|
2015-05-06 06:58:31 +07:00
|
|
|
/**
|
|
|
|
* struct ef10_vf - PF's store of VF data
|
2015-05-20 17:09:46 +07:00
|
|
|
* @efx: efx_nic struct for the current VF
|
2015-05-06 06:58:31 +07:00
|
|
|
* @vport_id: vport ID for the VF
|
|
|
|
* @vport_assigned: record whether the vport is currently assigned to the VF
|
|
|
|
* @mac: MAC address for the VF, zero when address is removed from the vport
|
2015-05-20 17:11:54 +07:00
|
|
|
* @vlan: Default VLAN for the VF or #EFX_EF10_NO_VLAN
|
2015-05-06 06:58:31 +07:00
|
|
|
*/
|
|
|
|
struct ef10_vf {
|
2015-05-20 17:09:46 +07:00
|
|
|
struct efx_nic *efx;
|
2015-05-06 06:58:31 +07:00
|
|
|
unsigned int vport_id;
|
|
|
|
unsigned int vport_assigned;
|
|
|
|
u8 mac[ETH_ALEN];
|
2015-05-20 17:11:54 +07:00
|
|
|
u16 vlan;
|
|
|
|
#define EFX_EF10_NO_VLAN 0
|
2015-05-06 06:58:31 +07:00
|
|
|
};
|
|
|
|
|
2015-05-06 06:55:13 +07:00
|
|
|
static inline bool efx_ef10_sriov_wanted(struct efx_nic *efx)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2015-05-06 06:55:58 +07:00
|
|
|
int efx_ef10_sriov_configure(struct efx_nic *efx, int num_vfs);
|
2015-05-06 06:58:14 +07:00
|
|
|
int efx_ef10_sriov_init(struct efx_nic *efx);
|
2015-05-06 06:55:13 +07:00
|
|
|
static inline void efx_ef10_sriov_reset(struct efx_nic *efx) {}
|
2015-05-06 06:58:14 +07:00
|
|
|
void efx_ef10_sriov_fini(struct efx_nic *efx);
|
2015-05-06 06:55:13 +07:00
|
|
|
static inline void efx_ef10_sriov_flr(struct efx_nic *efx, unsigned vf_i) {}
|
|
|
|
|
2015-05-20 17:11:03 +07:00
|
|
|
int efx_ef10_sriov_set_vf_mac(struct efx_nic *efx, int vf, u8 *mac);
|
2015-05-06 06:55:13 +07:00
|
|
|
|
2015-05-20 17:11:54 +07:00
|
|
|
int efx_ef10_sriov_set_vf_vlan(struct efx_nic *efx, int vf_i,
|
|
|
|
u16 vlan, u8 qos);
|
2015-05-06 06:55:13 +07:00
|
|
|
|
2015-05-20 17:12:30 +07:00
|
|
|
int efx_ef10_sriov_set_vf_spoofchk(struct efx_nic *efx, int vf,
|
|
|
|
bool spoofchk);
|
2015-05-06 06:55:13 +07:00
|
|
|
|
2015-05-20 17:11:18 +07:00
|
|
|
int efx_ef10_sriov_get_vf_config(struct efx_nic *efx, int vf_i,
|
|
|
|
struct ifla_vf_info *ivf);
|
2015-05-06 06:55:13 +07:00
|
|
|
|
2015-05-20 17:12:13 +07:00
|
|
|
int efx_ef10_sriov_set_vf_link_state(struct efx_nic *efx, int vf_i,
|
|
|
|
int link_state);
|
|
|
|
|
2015-06-02 17:38:16 +07:00
|
|
|
int efx_ef10_sriov_get_phys_port_id(struct efx_nic *efx,
|
|
|
|
struct netdev_phys_item_id *ppid);
|
|
|
|
|
2015-05-06 06:58:54 +07:00
|
|
|
int efx_ef10_vswitching_probe_pf(struct efx_nic *efx);
|
|
|
|
int efx_ef10_vswitching_probe_vf(struct efx_nic *efx);
|
|
|
|
int efx_ef10_vswitching_restore_pf(struct efx_nic *efx);
|
|
|
|
int efx_ef10_vswitching_restore_vf(struct efx_nic *efx);
|
|
|
|
void efx_ef10_vswitching_remove_pf(struct efx_nic *efx);
|
|
|
|
void efx_ef10_vswitching_remove_vf(struct efx_nic *efx);
|
2015-05-06 06:57:34 +07:00
|
|
|
|
2015-05-06 06:55:13 +07:00
|
|
|
#endif /* EF10_SRIOV_H */
|