Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

204 lines
5.6 KiB

  1. /*++
  2. Copyright (c) 1995 Microsoft Corporation
  3. Module Name :
  4. asyncio.hxx
  5. Abstract:
  6. This module declares a class for handling Asynchronous IO using
  7. ATQs and overlapped IO structures
  8. Author:
  9. Murali R. Krishnan ( MuraliK ) 27-March-1995
  10. Environment:
  11. User Mode -- Win32
  12. Project:
  13. Internet Services DLL
  14. Revision History:
  15. --*/
  16. # ifndef _ASYNCIO_HXX_
  17. # define _ASYNCIO_HXX_
  18. /************************************************************
  19. * Include Headers
  20. ************************************************************/
  21. //
  22. // Include NT/Windows headers
  23. //
  24. # include "atq.h"
  25. # define DEFAULT_CONNECTION_IO_TIMEOUT ( 60) // 1 minutes
  26. /************************************************************
  27. * Type Definitions
  28. ************************************************************/
  29. class ASYNC_IO_CONNECTION;
  30. typedef ASYNC_IO_CONNECTION * LPASYNC_IO_CONNECTION;
  31. extern VOID
  32. ProcessAtqCompletion(IN LPVOID pContext,
  33. IN DWORD cbIo,
  34. IN DWORD dwCompletionStatus,
  35. IN OVERLAPPED * lpo);
  36. /*++
  37. PFN_ASYNC_IO_COMPLETION:
  38. Call back function to be called at completion of the IO using
  39. ASYNC_IO_CONNECTION object.
  40. Parameters:
  41. pContext pointer to Context information for call back.
  42. cbIo count of bytes involved in IO
  43. dwCompletionStatus DWORD containing the Error code ( if any errors)
  44. for last IO operation.
  45. pAic pointer to the Asynchronous IO object involved in
  46. processing last request.
  47. fTimedOut indicates if the request was timed out.
  48. --*/
  49. typedef VOID ( * PFN_ASYNC_IO_COMPLETION)(
  50. IN LPVOID pContext,
  51. IN DWORD cbIo,
  52. IN DWORD dwCompletionStatus,
  53. IN LPASYNC_IO_CONNECTION pAic,
  54. IN BOOL fTimedOut
  55. );
  56. /*++
  57. class ASYNC_IO_CONNECTION:
  58. This class maintains state of an asynchronous IO operation.
  59. It supports async Read, Write and TransmitFile operations
  60. for the user of its objects.
  61. It also maintains state regarding timeout, user context
  62. --*/
  63. class ASYNC_IO_CONNECTION {
  64. public:
  65. enum ASYNC_IO_OPERATION {
  66. AioNone,
  67. AioRead,
  68. AioWrite,
  69. AioTransmitFile,
  70. AioError
  71. };
  72. ASYNC_IO_CONNECTION( IN PFN_ASYNC_IO_COMPLETION pfnCompletion,
  73. IN SOCKET sClient = INVALID_SOCKET);
  74. virtual ~ASYNC_IO_CONNECTION( VOID);
  75. VOID SetAioContext(IN LPVOID pContext) { m_pAioContext = pContext; }
  76. SOCKET QuerySocket( VOID) const { return ( m_sClient); }
  77. LPVOID QueryAioContext( VOID) const { return ( m_pAioContext); }
  78. PFN_ASYNC_IO_COMPLETION QueryPfnAioCompletion( VOID) const
  79. { return ( m_pfnAioCompletion); }
  80. PATQ_CONTEXT QueryAtqContext(VOID) const { return ( m_pAtqContext); }
  81. DWORD QueryIoTimeout( VOID) const { return (m_sTimeout);}
  82. VOID SetIoTimeout(IN DWORD sTimeout) { m_sTimeout = sTimeout; }
  83. // This function should be called once per object for new socket.
  84. VOID SetAioInformation( IN LPVOID pContext, IN DWORD sTimeout)
  85. {
  86. m_pAioContext = pContext;
  87. m_sTimeout = sTimeout;
  88. }
  89. // returns the timetilltimeout value from atq or locally.
  90. DWORD ResumeIoOperation(VOID)
  91. {
  92. if ( m_pAtqContext != NULL) {
  93. // no valid 3rd parameter required for setting this info.
  94. // just to satisfy compiler send 0 as 3rd param
  95. return (DWORD)AtqContextSetInfo( m_pAtqContext, ATQ_INFO_RESUME_IO, 0);
  96. }
  97. return ( INFINITE); // No Outstanding IO; so send INFINITE.
  98. }
  99. BOOL SetNewSocket(IN SOCKET sNewSocket,
  100. IN PATQ_CONTEXT pAtqContext = NULL,
  101. IN PVOID EndpointObject = NULL);
  102. BOOL ReadFile(
  103. OUT LPVOID pvBuffer,
  104. IN DWORD cbSize);
  105. BOOL WriteFile(
  106. IN LPVOID pvBuffer,
  107. IN DWORD cbSize);
  108. BOOL TransmitFile(
  109. IN HANDLE hFile,
  110. IN LARGE_INTEGER & liSize,
  111. IN DWORD Offset,
  112. IN LPTRANSMIT_FILE_BUFFERS lpTransmitBuffers = NULL
  113. );
  114. BOOL TransmitFileTs(
  115. IN TS_OPEN_FILE_INFO * pOpenFile,
  116. IN LARGE_INTEGER & liSize,
  117. IN DWORD dwOffset
  118. );
  119. BOOL StopIo( IN DWORD dwErrorCode = NO_ERROR);
  120. # if DBG
  121. VOID Print( VOID) const;
  122. # endif // DBG
  123. private:
  124. // data required for callback and establishing Atq connection.
  125. LPVOID m_pAioContext;
  126. PFN_ASYNC_IO_COMPLETION m_pfnAioCompletion;
  127. DWORD m_sTimeout; // timeout in seconds
  128. // data related to Async io.
  129. SOCKET m_sClient;
  130. PATQ_CONTEXT m_pAtqContext;
  131. PVOID m_endpointObject;
  132. BOOL AddToAtqHandles( VOID)
  133. {
  134. return ( AtqAddAsyncHandle( &m_pAtqContext,
  135. m_endpointObject,
  136. this,
  137. ProcessAtqCompletion,
  138. QueryIoTimeout(),
  139. (HANDLE ) m_sClient)
  140. );
  141. } // AddToAtqHandles()
  142. }; // class ASYNC_IO_CONNECTION:
  143. # endif // _ASYNCIO_HXX_
  144. /************************ End of File ***********************/