summaryrefslogtreecommitdiff
path: root/usr.sbin/ppp
diff options
context:
space:
mode:
authorbrian <brian@cvs.openbsd.org>2000-06-19 21:43:42 +0000
committerbrian <brian@cvs.openbsd.org>2000-06-19 21:43:42 +0000
commit1abef89558453935167b734f3edda32d8a73ab1a (patch)
tree88a3d8e16b1e3360672879aad3373b36aac35638 /usr.sbin/ppp
parentbf91d542f0331ad27712c94a7f31a215885478d1 (diff)
Don't mis-match interface names in iface_Create()
Submitted by: Adrian Penisoara <ady@freebsd.ady.ro>
Diffstat (limited to 'usr.sbin/ppp')
-rw-r--r--usr.sbin/ppp/ppp/iface.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/usr.sbin/ppp/ppp/iface.c b/usr.sbin/ppp/ppp/iface.c
index a10452d43d7..c207406abad 100644
--- a/usr.sbin/ppp/ppp/iface.c
+++ b/usr.sbin/ppp/ppp/iface.c
@@ -23,7 +23,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $OpenBSD: iface.c,v 1.10 2000/02/27 01:38:26 brian Exp $
+ * $OpenBSD: iface.c,v 1.11 2000/06/19 21:43:41 brian Exp $
*/
#include <sys/param.h>
@@ -95,7 +95,7 @@ struct iface *
iface_Create(const char *name)
{
int mib[6], s;
- size_t needed;
+ size_t needed, namelen;
char *buf, *ptr, *end;
struct if_msghdr *ifm;
struct ifa_msghdr *ifam;
@@ -140,13 +140,14 @@ iface_Create(const char *name)
ptr = buf;
end = buf + needed;
iface = NULL;
+ namelen = strlen(name);
while (ptr < end && iface == NULL) {
ifm = (struct if_msghdr *)ptr; /* On if_msghdr */
if (ifm->ifm_type != RTM_IFINFO)
break;
dl = (struct sockaddr_dl *)(ifm + 1); /* Single _dl at end */
- if (!strncmp(name, dl->sdl_data, dl->sdl_nlen)) {
+ if (dl->sdl_nlen == namelen && !strncmp(name, dl->sdl_data, namelen)) {
iface = (struct iface *)malloc(sizeof *iface);
if (iface == NULL) {
fprintf(stderr, "iface_Create: malloc: %s\n", strerror(errno));