79aab093a0
Introduce new rtnl UAPI that exposes a list of vlans per VF, giving the ability for user-space application to specify it for the VF, as an option to support 802.1ad. We adjusted IP Link tool to support this option. For future use cases, the new UAPI supports multiple vlans. For now we limit the list size to a single vlan in kernel. Add IFLA_VF_VLAN_LIST in addition to IFLA_VF_VLAN to keep backward compatibility with older versions of IP Link tool. Add a vlan protocol parameter to the ndo_set_vf_vlan callback. We kept 802.1Q as the drivers' default vlan protocol. Suitable ip link tool command examples: Set vf vlan protocol 802.1ad: ip link set eth0 vf 1 vlan 100 proto 802.1ad Set vf to VST (802.1Q) mode: ip link set eth0 vf 1 vlan 100 proto 802.1Q Or by omitting the new parameter ip link set eth0 vf 1 vlan 100 Signed-off-by: Moshe Shemesh <moshe@mellanox.com> Signed-off-by: Tariq Toukan <tariqt@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
87 lines
2.3 KiB
C
87 lines
2.3 KiB
C
/****************************************************************************
|
|
* Driver for Solarflare network controllers and boards
|
|
* Copyright 2014-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.
|
|
*/
|
|
#include <linux/module.h>
|
|
#include "net_driver.h"
|
|
#include "nic.h"
|
|
#include "sriov.h"
|
|
|
|
int efx_sriov_set_vf_mac(struct net_device *net_dev, int vf_i, u8 *mac)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_set_vf_mac)
|
|
return efx->type->sriov_set_vf_mac(efx, vf_i, mac);
|
|
else
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
int efx_sriov_set_vf_vlan(struct net_device *net_dev, int vf_i, u16 vlan,
|
|
u8 qos, __be16 vlan_proto)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_set_vf_vlan) {
|
|
if ((vlan & ~VLAN_VID_MASK) ||
|
|
(qos & ~(VLAN_PRIO_MASK >> VLAN_PRIO_SHIFT)))
|
|
return -EINVAL;
|
|
|
|
if (vlan_proto != htons(ETH_P_8021Q))
|
|
return -EPROTONOSUPPORT;
|
|
|
|
return efx->type->sriov_set_vf_vlan(efx, vf_i, vlan, qos);
|
|
} else {
|
|
return -EOPNOTSUPP;
|
|
}
|
|
}
|
|
|
|
int efx_sriov_set_vf_spoofchk(struct net_device *net_dev, int vf_i,
|
|
bool spoofchk)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_set_vf_spoofchk)
|
|
return efx->type->sriov_set_vf_spoofchk(efx, vf_i, spoofchk);
|
|
else
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
int efx_sriov_get_vf_config(struct net_device *net_dev, int vf_i,
|
|
struct ifla_vf_info *ivi)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_get_vf_config)
|
|
return efx->type->sriov_get_vf_config(efx, vf_i, ivi);
|
|
else
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
int efx_sriov_set_vf_link_state(struct net_device *net_dev, int vf_i,
|
|
int link_state)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_set_vf_link_state)
|
|
return efx->type->sriov_set_vf_link_state(efx, vf_i,
|
|
link_state);
|
|
else
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
int efx_sriov_get_phys_port_id(struct net_device *net_dev,
|
|
struct netdev_phys_item_id *ppid)
|
|
{
|
|
struct efx_nic *efx = netdev_priv(net_dev);
|
|
|
|
if (efx->type->sriov_get_phys_port_id)
|
|
return efx->type->sriov_get_phys_port_id(efx, ppid);
|
|
else
|
|
return -EOPNOTSUPP;
|
|
}
|