]> git.ipfire.org Git - thirdparty/glibc.git/blobdiff - rt/aio_cancel.c
Update copyright dates with scripts/update-copyrights.
[thirdparty/glibc.git] / rt / aio_cancel.c
index dcb7d5ef8dafd01d1c64cf0a0c7020b452621585..2087cc328611e7bd5078a6ee622da3b3b6e8bac9 100644 (file)
@@ -1,22 +1,20 @@
-/* Cancel requests associated with given file descriptor.
-   Copyright (C) 1997, 1998, 2000 Free Software Foundation, Inc.
+/* Cancel requests associated with given file descriptor.  Stub version.
+   Copyright (C) 2001-2019 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
-   Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
    The GNU C Library is free software; you can redistribute it and/or
-   modify it under the terms of the GNU Library General Public License as
-   published by the Free Software Foundation; either version 2 of the
-   License, or (at your option) any later version.
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
 
    The GNU C Library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-   Library General Public License for more details.
+   Lesser General Public License for more details.
 
-   You should have received a copy of the GNU Library General Public
-   License along with the GNU C Library; see the file COPYING.LIB.  If not,
-   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
 
 
 /* We use an UGLY hack to prevent gcc from finding us cheating.  The
 
 #include <errno.h>
 
-#include "aio_misc.h"
-
-
 int
-aio_cancel (fildes, aiocbp)
-     int fildes;
-     struct aiocb *aiocbp;
+aio_cancel (int fildes, struct aiocb *aiocbp)
 {
-  struct requestlist *req = NULL;
-  int result = AIO_ALLDONE;
-
-  /* Request the mutex.  */
-  pthread_mutex_lock (&__aio_requests_mutex);
-
-  /* We are asked to cancel a specific AIO request.  */
-  if (aiocbp != NULL)
-    {
-      /* If the AIO request is not for this descriptor it has no value
-        to look for the request block.  */
-      if (aiocbp->aio_fildes == fildes)
-       {
-         struct requestlist *last = NULL;
-
-         req = __aio_find_req_fd (fildes);
-
-         while (req->aiocbp != (aiocb_union *) aiocbp)
-           {
-             last = req;
-             req = req->next_prio;
-             if (req == NULL)
-               {
-                 pthread_mutex_unlock (&__aio_requests_mutex);
-                 __set_errno (EINVAL);
-                 return -1;
-               }
-           }
-
-         /* Don't remove the entry if a thread is already working on it.  */
-         if (req->running == allocated)
-           result = AIO_NOTCANCELED;
-         else if (req->running == yes)
-           {
-             /* We can remove the entry.  */
-             if (last != NULL)
-               last->next_prio = req->next_prio;
-             else
-               if (req->next_prio == NULL)
-                 {
-                   if (req->last_fd != NULL)
-                     req->last_fd->next_fd = req->next_fd;
-                   if (req->next_fd != NULL)
-                     req->next_fd->last_fd = req->last_fd;
-                 }
-               else
-                 {
-                   if (req->last_fd != NULL)
-                     req->last_fd->next_fd = req->next_prio;
-                   if (req->next_fd != NULL)
-                     req->next_fd->last_fd = req->next_prio;
-                   req->next_prio->last_fd = req->last_fd;
-                   req->next_prio->next_fd = req->next_fd;
-
-                   /* Mark this entry as runnable.  */
-                   req->next_prio->running = yes;
-                 }
-
-             result = AIO_CANCELED;
-           }
-
-         req->next_prio = NULL;
-       }
-    }
-  else
-    {
-      /* Find the beginning of the list of all requests for this
-        desriptor.  */
-      req = __aio_find_req_fd (fildes);
-
-      /* If any request is worked on by a thread it must be the first.
-        So either we can delete all requests or all but the first.  */
-      if (req != NULL)
-       {
-         if (req->running == allocated)
-           {
-             struct requestlist *old = req;
-             req = req->next_prio;
-             old->next_prio = NULL;
-
-             result = AIO_NOTCANCELED;
-           }
-         else
-           {
-             /* Remove entry from the file descriptor list.  */
-             if (req->last_fd != NULL)
-               req->last_fd->next_fd = req->next_fd;
-             if (req->next_fd != NULL)
-               req->next_fd->last_fd = req->last_fd;
-
-             result = AIO_CANCELED;
-           }
-       }
-    }
-
-  /* Mark requests as canceled and send signal.  */
-  while (req != NULL)
-    {
-      struct requestlist *old = req;
-      req->aiocbp->aiocb.__error_code = ECANCELED;
-      req->aiocbp->aiocb.__return_value = -1;
-      __aio_notify (req);
-      req = req->next_prio;
-      __aio_free_request (old);
-    }
-
-  /* Release the mutex.  */
-  pthread_mutex_unlock (&__aio_requests_mutex);
-
-  return result;
+  __set_errno (ENOSYS);
+  return -1;
 }
 
 weak_alias (aio_cancel, aio_cancel64)
+
+stub_warning (aio_cancel)
+stub_warning (aio_cancel64)