summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--inet/ether_aton.c4
-rw-r--r--inet/ether_aton_r.c4
3 files changed, 9 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 1f0f4d3a7c..866fa203b6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
 1998-04-28  Ulrich Drepper  <drepper@cygnus.com>
 
+	* inet/ether_aton_r.c (ether_aton_r): Preserve high-nibble value
+	in hex conversion.
+	* inet/ether_aton.c (ether_aton): Declare result variable static.
+	Reported by ahyung@unixg.ubc.ca.
+
 	* sysdeps/unix/sysv/linux/bits/sem.h: Don't define union semun.
 	Define macro _SEM_SEMUN_UNDEFINED instead.
 	Reported by Dirk Laessig <d.laessig@tu-bs.de>.
diff --git a/inet/ether_aton.c b/inet/ether_aton.c
index 20300c806a..574800765a 100644
--- a/inet/ether_aton.c
+++ b/inet/ether_aton.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
 
@@ -24,7 +24,7 @@
 struct ether_addr *
 ether_aton (const char *asc)
 {
-  struct ether_addr result;
+  static struct ether_addr result;
 
   return ether_aton_r (asc, &result);
 }
diff --git a/inet/ether_aton_r.c b/inet/ether_aton_r.c
index 28fe6f6962..14ccd2574f 100644
--- a/inet/ether_aton_r.c
+++ b/inet/ether_aton_r.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
 
@@ -45,7 +45,7 @@ ether_aton_r (const char *asc, struct ether_addr *addr)
 	  if ((ch < '0' || ch > '9') && (ch < 'a' || ch > 'f'))
 	    return NULL;
 	  number <<= 4;
-	  number = isdigit (ch) ? (ch - '0') : (ch - 'a' + 10);
+	  number += isdigit (ch) ? (ch - '0') : (ch - 'a' + 10);
 
 	  ch = *asc;
 	  if (cnt < 5 && ch != ':')