Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Fix ixl_{add|remove}_macvlan() to return errno
details: https://anonhg.NetBSD.org/src/rev/ba37b0f94b8b
branches: trunk
changeset: 1005766:ba37b0f94b8b
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Fri Dec 20 01:45:20 2019 +0000
description:
Fix ixl_{add|remove}_macvlan() to return errno
instead of command status
diffstat:
sys/dev/pci/if_ixl.c | 55 ++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 41 insertions(+), 14 deletions(-)
diffs (123 lines):
diff -r f3c10f2d3fcb -r ba37b0f94b8b sys/dev/pci/if_ixl.c
--- a/sys/dev/pci/if_ixl.c Fri Dec 20 01:18:53 2019 +0000
+++ b/sys/dev/pci/if_ixl.c Fri Dec 20 01:45:20 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_ixl.c,v 1.6 2019/12/20 01:18:53 yamaguchi Exp $ */
+/* $NetBSD: if_ixl.c,v 1.7 2019/12/20 01:45:20 yamaguchi Exp $ */
/*
* Copyright (c) 2013-2015, Intel Corporation
@@ -1448,16 +1448,13 @@
rv = ixl_add_macvlan(sc, addrlo, 0,
IXL_AQ_OP_ADD_MACVLAN_IGNORE_VLAN);
- if (rv == IXL_AQ_RC_ENOSPC) {
+ if (rv == ENOSPC) {
ixl_del_all_multiaddr(sc);
SET(ifp->if_flags, IFF_ALLMULTI);
return 0;
}
- if (rv != IXL_AQ_RC_OK)
- return EIO;
-
- return 0;
+ return rv;
}
static void
@@ -1489,7 +1486,7 @@
ETHER_NEXT_MULTI(step, enm)) {
rv = ixl_add_macvlan(sc, enm->enm_addrlo, 0,
IXL_AQ_OP_ADD_MACVLAN_IGNORE_VLAN);
- if (rv != IXL_AQ_RC_OK)
+ if (rv != 0)
break;
}
@@ -4180,7 +4177,24 @@
return IXL_AQ_RC_EINVAL;
}
- return le16toh(iaq.iaq_retval);
+ switch (le16toh(iaq.iaq_retval)) {
+ case IXL_AQ_RC_OK:
+ break;
+ case IXL_AQ_RC_ENOSPC:
+ return ENOSPC;
+ case IXL_AQ_RC_ENOENT:
+ return ENOENT;
+ case IXL_AQ_RC_EACCES:
+ return EACCES;
+ case IXL_AQ_RC_EEXIST:
+ return EEXIST;
+ case IXL_AQ_RC_EINVAL:
+ return EINVAL;
+ default:
+ return EIO;
+ }
+
+ return 0;
}
static int
@@ -4210,10 +4224,23 @@
elem->vlan = htole16(vlan);
if (ixl_atq_poll(sc, &iaq, 250) != 0) {
- return IXL_AQ_RC_EINVAL;
+ return EINVAL;
}
- return le16toh(iaq.iaq_retval);
+ switch (le16toh(iaq.iaq_retval)) {
+ case IXL_AQ_RC_OK:
+ break;
+ case IXL_AQ_RC_ENOENT:
+ return ENOENT;
+ case IXL_AQ_RC_EACCES:
+ return EACCES;
+ case IXL_AQ_RC_EINVAL:
+ return EINVAL;
+ default:
+ return EIO;
+ }
+
+ return 0;
}
static int
@@ -4756,14 +4783,14 @@
/* remove default mac filter and replace it so we can see vlans */
error = ixl_remove_macvlan(sc, sc->sc_enaddr, 0, 0);
- if (error != IXL_AQ_RC_OK) {
+ if (error != 0 && error != ENOENT) {
aprint_debug_dev(sc->sc_dev, "unable to remove macvlan\n");
rv = -1;
}
error = ixl_remove_macvlan(sc, sc->sc_enaddr, 0,
IXL_AQ_OP_REMOVE_MACVLAN_IGNORE_VLAN);
- if (error != IXL_AQ_RC_OK && error != IXL_AQ_RC_ENOENT) {
+ if (error != 0 && error != ENOENT) {
aprint_debug_dev(sc->sc_dev,
"unable to remove macvlan(IGNORE_VLAN)\n");
rv = -1;
@@ -4771,14 +4798,14 @@
error = ixl_add_macvlan(sc, sc->sc_enaddr, 0,
IXL_AQ_OP_ADD_MACVLAN_IGNORE_VLAN);
- if (error != IXL_AQ_RC_OK) {
+ if (error != 0) {
aprint_debug_dev(sc->sc_dev, "unable to add mac address\n");
rv = -1;
}
error = ixl_add_macvlan(sc, etherbroadcastaddr, 0,
IXL_AQ_OP_ADD_MACVLAN_IGNORE_VLAN);
- if (error != IXL_AQ_RC_OK) {
+ if (error != 0) {
aprint_debug_dev(sc->sc_dev,
"unable to add broadcast mac address\n");
rv = -1;
Home |
Main Index |
Thread Index |
Old Index