rtnetlink: clean up SR-IOV config interface

This patch consists of a few minor cleanups to the SR-IOV
configurion code in rtnetlink.
- Remove unneccesary lock
- Remove unneccesary casts
- Return correct error code for no driver support

These changes are based on comments from Patrick McHardy

Signed-off-by: Mitch Williams <mitch.a.williams@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Williams, Mitch A 2010-02-24 21:59:56 +00:00 committed by David S. Miller
parent 914c8ad2d1
commit 4edb246626

View File

@ -930,10 +930,9 @@ static int do_setlink(struct net_device *dev, struct ifinfomsg *ifm,
if (tb[IFLA_VF_MAC]) { if (tb[IFLA_VF_MAC]) {
struct ifla_vf_mac *ivm; struct ifla_vf_mac *ivm;
ivm = nla_data(tb[IFLA_VF_MAC]); ivm = nla_data(tb[IFLA_VF_MAC]);
write_lock_bh(&dev_base_lock); err = -EOPNOTSUPP;
if (ops->ndo_set_vf_mac) if (ops->ndo_set_vf_mac)
err = ops->ndo_set_vf_mac(dev, ivm->vf, ivm->mac); err = ops->ndo_set_vf_mac(dev, ivm->vf, ivm->mac);
write_unlock_bh(&dev_base_lock);
if (err < 0) if (err < 0)
goto errout; goto errout;
modified = 1; modified = 1;
@ -942,12 +941,11 @@ static int do_setlink(struct net_device *dev, struct ifinfomsg *ifm,
if (tb[IFLA_VF_VLAN]) { if (tb[IFLA_VF_VLAN]) {
struct ifla_vf_vlan *ivv; struct ifla_vf_vlan *ivv;
ivv = nla_data(tb[IFLA_VF_VLAN]); ivv = nla_data(tb[IFLA_VF_VLAN]);
write_lock_bh(&dev_base_lock); err = -EOPNOTSUPP;
if (ops->ndo_set_vf_vlan) if (ops->ndo_set_vf_vlan)
err = ops->ndo_set_vf_vlan(dev, ivv->vf, err = ops->ndo_set_vf_vlan(dev, ivv->vf,
(u16)ivv->vlan, ivv->vlan,
(u8)ivv->qos); ivv->qos);
write_unlock_bh(&dev_base_lock);
if (err < 0) if (err < 0)
goto errout; goto errout;
modified = 1; modified = 1;
@ -957,10 +955,9 @@ static int do_setlink(struct net_device *dev, struct ifinfomsg *ifm,
if (tb[IFLA_VF_TX_RATE]) { if (tb[IFLA_VF_TX_RATE]) {
struct ifla_vf_tx_rate *ivt; struct ifla_vf_tx_rate *ivt;
ivt = nla_data(tb[IFLA_VF_TX_RATE]); ivt = nla_data(tb[IFLA_VF_TX_RATE]);
write_lock_bh(&dev_base_lock); err = -EOPNOTSUPP;
if (ops->ndo_set_vf_tx_rate) if (ops->ndo_set_vf_tx_rate)
err = ops->ndo_set_vf_tx_rate(dev, ivt->vf, ivt->rate); err = ops->ndo_set_vf_tx_rate(dev, ivt->vf, ivt->rate);
write_unlock_bh(&dev_base_lock);
if (err < 0) if (err < 0)
goto errout; goto errout;
modified = 1; modified = 1;