]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
2005-10-22 Roland McGrath <roland@frob.com>
authorRoland McGrath <roland@gnu.org>
Sun, 23 Oct 2005 00:53:24 +0000 (00:53 +0000)
committerRoland McGrath <roland@gnu.org>
Sun, 23 Oct 2005 00:53:24 +0000 (00:53 +0000)
[BZ #1254]
* sysdeps/mach/hurd/getpeername.c (__getpeername): Fix last change.
From Samuel Thibault <samuel.thibault@ens-lyon.org>.
2005-10-16  Roland McGrath  <roland@frob.com>

[BZ #1254]
* sysdeps/mach/hurd/getpeername.c (__getpeername): Respect *LEN
byte limit when setting ADDR->sa_family.
Reported by Samuel Thibault <samuel.thibault@ens-lyon.org>.

sysdeps/mach/hurd/getpeername.c

index 2e4f9f6a9d3ff336f35fb990ab4ba5fbd7aa72b3..325b6fd75d50a33afb9ca13aa3b96efa6a949248 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1992, 1994, 1997, 1999, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1992,1994,1997,1999,2000,2005 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -47,14 +47,22 @@ __getpeername (int fd, __SOCKADDR_ARG addrarg, socklen_t *len)
 
   if (*len > buflen)
     *len = buflen;
-  
+
   if (buf != (char *) addr)
     {
       memcpy (addr, buf, *len);
       __vm_deallocate (__mach_task_self (), (vm_address_t) buf, buflen);
     }
 
-  addr->sa_family = type;
+  const sa_family_t family = type;
+  if (*len > offsetof (struct sockaddr, sa_family))
+    {
+      if (*len < (char *) (&addr->sa_family + 1) - (char *) addr)
+       memcpy (&addr->sa_family, &family,
+               *len - offsetof (struct sockaddr, sa_family));
+      else
+       addr->sa_family = family;
+    }
 
   return 0;
 }