home *** CD-ROM | disk | FTP | other *** search
/ Aminet 18 / aminetcdnumber181997.iso / Aminet / misc / emu / AROSdev.lha / AROS / rom / exec / checkio.c < prev    next >
Encoding:
C/C++ Source or Header  |  1997-01-09  |  1.8 KB  |  87 lines

  1. /*
  2.     (C) 1995-96 AROS - The Amiga Replacement OS
  3.     $Id: checkio.c,v 1.7 1997/01/01 03:46:06 ldp Exp $
  4.     $Log: checkio.c,v $
  5.     Revision 1.7  1997/01/01 03:46:06  ldp
  6.     Committed Amiga native (support) code
  7.  
  8.     Changed clib to proto
  9.  
  10.     Revision 1.6  1996/12/10 13:51:39  aros
  11.     Moved all #include's in the first column so makedepend can see it.
  12.  
  13.     Revision 1.5  1996/10/24 15:50:45  aros
  14.     Use the official AROS macros over the __AROS versions.
  15.  
  16.     Revision 1.4  1996/08/13 13:55:59  digulla
  17.     Replaced AROS_LA by AROS_LHA
  18.     Replaced some AROS_LH*I by AROS_LH*
  19.     Sorted and added includes
  20.  
  21.     Revision 1.3  1996/08/01 17:41:07  digulla
  22.     Added standard header for all files
  23.  
  24.     Desc:
  25.     Lang: english
  26. */
  27. #include <exec/execbase.h>
  28. #include <exec/io.h>
  29. #include <aros/libcall.h>
  30. #include <proto/exec.h>
  31.  
  32. /*****************************************************************************
  33.  
  34.     NAME */
  35.  
  36.     AROS_LH1I(struct IORequest *, CheckIO,
  37.  
  38. /*  SYNOPSIS */
  39.     AROS_LHA(struct IORequest *, iORequest, A1),
  40.  
  41. /*  LOCATION */
  42.     struct ExecBase *, SysBase, 78, Exec)
  43.  
  44. /*  FUNCTION
  45.     Check if an I/O request is completed.
  46.  
  47.     INPUTS
  48.     iORequest - Pointer to iorequest structure.
  49.  
  50.     RESULT
  51.     Pointer to the iorequest structure or NULL if the device is still
  52.     at work.
  53.  
  54.     NOTES
  55.  
  56.     EXAMPLE
  57.  
  58.     BUGS
  59.  
  60.     SEE ALSO
  61.     OpenDevice(), CloseDevice(), DoIO(), SendIO(), AbortIO(), WaitIO()
  62.  
  63.     INTERNALS
  64.  
  65.     HISTORY
  66.  
  67. ******************************************************************************/
  68. {
  69.     AROS_LIBFUNC_INIT
  70.  
  71.     /*
  72.     The I/O request is still in use if it wasn't done quick
  73.     and isn't yet replied (ln_Type==NT_MESSAGE).
  74.     */
  75.     if(!(iORequest->io_Flags&IOF_QUICK)&&
  76.        iORequest->io_Message.mn_Node.ln_Type==NT_MESSAGE)
  77.  
  78.     /* Still in use */
  79.     return NULL;
  80.     else
  81.     /* done */
  82.     return iORequest;
  83.  
  84.     AROS_LIBFUNC_EXIT
  85. } /* CheckIO */
  86.  
  87.