Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/net Simplify ifunit, if_get and if_get_byindex by reusin...
details: https://anonhg.NetBSD.org/src/rev/378f111b91f5
branches: trunk
changeset: 352108:378f111b91f5
user: ozaki-r <ozaki-r%NetBSD.org@localhost>
date: Thu Mar 16 09:40:48 2017 +0000
description:
Simplify ifunit, if_get and if_get_byindex by reusing other functions
Inspired by kre@'s comment
diffstat:
sys/net/if.c | 34 ++++++++--------------------------
1 files changed, 8 insertions(+), 26 deletions(-)
diffs (76 lines):
diff -r 7f2c4f685884 -r 378f111b91f5 sys/net/if.c
--- a/sys/net/if.c Thu Mar 16 08:11:47 2017 +0000
+++ b/sys/net/if.c Thu Mar 16 09:40:48 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if.c,v 1.386 2017/03/16 08:11:47 ozaki-r Exp $ */
+/* $NetBSD: if.c,v 1.387 2017/03/16 09:40:48 ozaki-r Exp $ */
/*-
* Copyright (c) 1999, 2000, 2001, 2008 The NetBSD Foundation, Inc.
@@ -90,7 +90,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if.c,v 1.386 2017/03/16 08:11:47 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if.c,v 1.387 2017/03/16 09:40:48 ozaki-r Exp $");
#if defined(_KERNEL_OPT)
#include "opt_inet.h"
@@ -2545,14 +2545,8 @@
/*
* If the number took all of the name, then it's a valid ifindex.
*/
- if (i == IFNAMSIZ || (cp != name && *cp == '\0')) {
- if (unit >= if_indexlim)
- return NULL;
- ifp = ifindex2ifnet[unit];
- if (ifp == NULL || if_is_deactivated(ifp))
- return NULL;
- return ifp;
- }
+ if (i == IFNAMSIZ || (cp != name && *cp == '\0'))
+ return if_byindex(unit);
ifp = NULL;
s = pserialize_read_enter();
@@ -2591,18 +2585,8 @@
/*
* If the number took all of the name, then it's a valid ifindex.
*/
- if (i == IFNAMSIZ || (cp != name && *cp == '\0')) {
- if (unit >= if_indexlim)
- return NULL;
- s = pserialize_read_enter();
- ifp = ifindex2ifnet[unit];
- if (ifp == NULL || if_is_deactivated(ifp))
- ifp = NULL;
- if (ifp != NULL)
- psref_acquire(psref, &ifp->if_psref, ifnet_psref_class);
- pserialize_read_exit(s);
- return ifp;
- }
+ if (i == IFNAMSIZ || (cp != name && *cp == '\0'))
+ return if_get_byindex(unit, psref);
ifp = NULL;
s = pserialize_read_enter();
@@ -2639,7 +2623,7 @@
{
ifnet_t *ifp;
- ifp = (idx < if_indexlim) ? ifindex2ifnet[idx] : NULL;
+ ifp = (__predict_true(idx < if_indexlim)) ? ifindex2ifnet[idx] : NULL;
if (ifp != NULL && if_is_deactivated(ifp))
ifp = NULL;
return ifp;
@@ -2657,9 +2641,7 @@
int s;
s = pserialize_read_enter();
- ifp = (__predict_true(idx < if_indexlim)) ? ifindex2ifnet[idx] : NULL;
- if (ifp != NULL && if_is_deactivated(ifp))
- ifp = NULL;
+ ifp = if_byindex(idx);
if (__predict_true(ifp != NULL))
psref_acquire(psref, &ifp->if_psref, ifnet_psref_class);
pserialize_read_exit(s);
Home |
Main Index |
Thread Index |
Old Index