diff options
author | glebius <glebius@FreeBSD.org> | 2005-12-18 18:24:27 +0000 |
---|---|---|
committer | glebius <glebius@FreeBSD.org> | 2005-12-18 18:24:27 +0000 |
commit | 175e16aa4df4f5510a7a395b24bd5ac9a00145f9 (patch) | |
tree | edde4e6e448953c23a09236086ca19000c7a4fb5 /sys/dev/vge | |
parent | 035fda79903772207b9132abc6ed91ac80535900 (diff) | |
download | FreeBSD-src-175e16aa4df4f5510a7a395b24bd5ac9a00145f9.zip FreeBSD-src-175e16aa4df4f5510a7a395b24bd5ac9a00145f9.tar.gz |
- Fix VLAN_INPUT_TAG() macro, so that it doesn't touch mtag in
case if memory allocation failed.
- Remove fourth argument from VLAN_INPUT_TAG(), that was used
incorrectly in almost all drivers. Indicate failure with
mbuf value of NULL.
In collaboration with: yongari, ru, sam
Diffstat (limited to 'sys/dev/vge')
-rw-r--r-- | sys/dev/vge/if_vge.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/sys/dev/vge/if_vge.c b/sys/dev/vge/if_vge.c index 915deb8..b433a01 100644 --- a/sys/dev/vge/if_vge.c +++ b/sys/dev/vge/if_vge.c @@ -1490,9 +1490,12 @@ vge_rxeof(sc) } } - if (rxstat & VGE_RDSTS_VTAG) + if (rxstat & VGE_RDSTS_VTAG) { VLAN_INPUT_TAG(ifp, m, - ntohs((rxctl & VGE_RDCTL_VLANID)), continue); + ntohs((rxctl & VGE_RDCTL_VLANID))); + if (m == NULL) + continue; + } VGE_UNLOCK(sc); (*ifp->if_input)(ifp, m); |