]> sourceware.org Git - newlib-cygwin.git/commitdiff
Cygwin: fix facl on sockets that are not socket files
authorKen Brown <kbrown@cornell.edu>
Mon, 22 Feb 2021 15:13:09 +0000 (10:13 -0500)
committerKen Brown <kbrown@cornell.edu>
Thu, 25 Feb 2021 22:44:18 +0000 (17:44 -0500)
If facl(2) is called on an AF_LOCAL or AF_UNIX socket that is not a
socket file, the current code calls fhandler_disk_file::facl in most
cases.  The latter expects to be operating on a disk file and uses the
socket's io_handle, which is not a file handle.

Fix this by calling fhandler_disk_file::facl only if the
fhandler_socket object is a file (determined by testing dev().isfs()).

winsup/cygwin/fhandler_socket_local.cc
winsup/cygwin/fhandler_socket_unix.cc

index 349ade897d5c847e2b4f14a7eda1420705f80752..22586c0dd2144fa1e53176499863cddadec94517 100644 (file)
@@ -737,8 +737,12 @@ fhandler_socket_local::fchown (uid_t uid, gid_t gid)
 int
 fhandler_socket_local::facl (int cmd, int nentries, aclent_t *aclbufp)
 {
-  if (get_sun_path () && get_sun_path ()[0] == '\0')
+  if (!dev ().isfs ())
+    /* facl called on a socket. */
     return fhandler_socket_wsock::facl (cmd, nentries, aclbufp);
+
+  /* facl on a socket file.  [We won't get here if facl is called on a
+     socket opened w/ O_PATH.] */
   fhandler_disk_file fh (pc);
   return fh.facl (cmd, nentries, aclbufp);
 }
index 573864b9f4a96426b18058c86aaae224e5f1f338..fae07367d53fda397c96c552e12e1455e85fe779 100644 (file)
@@ -2408,10 +2408,12 @@ fhandler_socket_unix::fchown (uid_t uid, gid_t gid)
 int
 fhandler_socket_unix::facl (int cmd, int nentries, aclent_t *aclbufp)
 {
-  if (sun_path ()
-      && (sun_path ()->un_len <= (socklen_t) sizeof (sa_family_t)
-         || sun_path ()->un.sun_path[0] == '\0'))
+  if (!dev ().isfs ())
+    /* facl called on a socket. */
     return fhandler_socket::facl (cmd, nentries, aclbufp);
+
+  /* facl on a socket file.  [We won't get here if facl is called on a
+     socket opened w/ O_PATH.] */
   fhandler_disk_file fh (pc);
   return fh.facl (cmd, nentries, aclbufp);
 }
This page took 0.036654 seconds and 5 git commands to generate.