2 * Copyright (c) 2008 Secure Endpoints, Inc.
3 * Copyright (c) 2009-2013 Your File System, Inc.
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are met:
9 * - Redistributions of source code must retain the above copyright notice,
10 * this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation
13 * and/or other materials provided with the distribution.
14 * - Neither the name of Secure Endpoints Inc. nor the names of its contributors
15 * may be used to endorse or promote products derived from this software without
16 * specific prior written permission from Secure Endpoints, Inc. and
17 * Your File System, Inc.
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
22 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
23 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 #include <afsconfig.h>
34 #include <afs/param.h>
39 #define _WIN32_WINNT 0x0500
41 #define _CRT_SECURE_NO_DEPRECATE
42 #define _CRT_NON_CONFORMING_SWPRINTFS
44 #define STRSAFE_NO_DEPRECATE
47 #define WIN32_NO_STATUS
49 typedef LONG NTSTATUS, *PNTSTATUS; // not declared in ntstatus.h
60 #include "..\\Common\\AFSUserDefines.h"
61 #include "..\\Common\\AFSUserIoctl.h"
62 #include "..\\Common\\AFSUserStructs.h"
66 extern osi_log_t *afsd_logp;
68 #include <WINNT/afsreg.h>
69 #include <afs/cm_config.h>
70 #include <afs/cm_error.h>
71 #include <afs/cm_nls.h>
72 #include <afs/cm_user.h>
74 #include <RDRPrototypes.h>
77 RDR_SetFileStatus2( AFSFileID * pFileId,
82 #define FlagOn(_F,_SF) ((_F) & (_SF))
86 #define BooleanFlagOn(F,SF) ((BOOLEAN)(((F) & (SF)) != 0))
90 #define SetFlag(_F,_SF) ((_F) |= (_SF))
94 #define ClearFlag(_F,_SF) ((_F) &= ~(_SF))
97 #define QuadAlign(Ptr) ( \
98 ((((ULONG)(Ptr)) + 7) & 0xfffffff8) \
101 #define MIN_WORKER_THREADS 5
102 #define MAX_WORKER_THREADS 512
104 typedef struct _worker_thread_info {
114 WorkerThreadInfo glWorkerThreadInfo[ MAX_WORKER_THREADS];
116 UINT glThreadHandleIndex = 0;
118 HANDLE glDevHandle = INVALID_HANDLE_VALUE;
120 static DWORD Exit = false;
122 static DWORD ExitPending = false;
126 extern "C" wchar_t RDR_UNCName[64]=L"AFS";
128 HANDLE RDR_SuspendEvent = INVALID_HANDLE_VALUE;
130 /* returns 0 on success */
138 DWORD numSvThreads = CM_CONFIGDEFAULT_SVTHREADS;
140 // Initialize the Suspend Event
141 RDR_SuspendEvent = CreateEvent( NULL,
142 TRUE, // manual reset event
146 dwRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE, AFSREG_CLT_SVC_PARAM_SUBKEY,
147 0, KEY_QUERY_VALUE, &parmKey);
148 if (dwRet == ERROR_SUCCESS) {
149 dummyLen = sizeof(numSvThreads);
150 dwRet = RegQueryValueEx(parmKey, TEXT("ServerThreads"), NULL, NULL,
151 (BYTE *) &numSvThreads, &dummyLen);
153 dummyLen = sizeof(RDR_UNCName);
154 dwRet = RegQueryValueExW(parmKey, L"NetbiosName", NULL, NULL,
155 (BYTE *) RDR_UNCName, &dummyLen);
157 RegCloseKey (parmKey);
160 // Initialize the Thread local storage index for the overlapped i/o
162 dwOvEvIdx = TlsAlloc();
167 // Launch our workers down to the
168 // filters control device for processing requests
171 dwRet = RDR_ProcessWorkerThreads(numSvThreads);
173 if (dwRet == ERROR_SUCCESS) {
182 BOOL RDR_DeviceIoControl( HANDLE hDevice,
183 DWORD dwIoControlCode,
187 DWORD nOutBufferSize,
188 LPDWORD lpBytesReturned )
195 ZeroMemory(&ov, sizeof(OVERLAPPED));
197 hEvent = (HANDLE)TlsGetValue(dwOvEvIdx);
198 if (hEvent == NULL) {
199 hEvent = CreateEvent( NULL, TRUE, TRUE, NULL );
200 if (hEvent == INVALID_HANDLE_VALUE || hEvent == NULL)
202 TlsSetValue( dwOvEvIdx, (LPVOID) hEvent );
207 *lpBytesReturned = 0;
209 rc = DeviceIoControl( hDevice,
218 gle = GetLastError();
220 if ( gle == ERROR_IO_PENDING )
221 rc = GetOverlappedResult( hDevice, &ov, lpBytesReturned, TRUE );
228 RDR_ShutdownFinal(void)
236 // Close all the worker thread handles
239 while( dwIndex < glThreadHandleIndex)
242 CloseHandle( glWorkerThreadInfo[ dwIndex].hThread);
247 if( glDevHandle != INVALID_HANDLE_VALUE)
250 CloseHandle( glDevHandle);
257 RDR_ShutdownNotify(void)
260 HANDLE hDevHandle = NULL;
264 // We use the global handle to the control device instance
267 hDevHandle = glDevHandle;
271 // First, notify the file system driver that
272 // we are shutting down.
277 if( !RDR_DeviceIoControl( hDevHandle,
285 // log the error, nothing to do
296 // Here we launch the worker threads for the given volume
300 RDR_ProcessWorkerThreads(DWORD numThreads)
305 DWORD bytesReturned = 0;
306 DWORD dwRedirInitInfo;
307 AFSRedirectorInitInfo * redirInitInfo = NULL;
310 if (dwErr = RDR_SetInitParams(&redirInitInfo, &dwRedirInitInfo))
313 glDevHandle = CreateFile( AFS_SYMLINK_W,
314 GENERIC_READ | GENERIC_WRITE,
315 FILE_SHARE_READ | FILE_SHARE_WRITE,
318 FILE_FLAG_OVERLAPPED,
321 if( glDevHandle == INVALID_HANDLE_VALUE)
324 return GetLastError();
328 // Now call down to initialize the pool.
331 if( !RDR_DeviceIoControl( glDevHandle,
332 IOCTL_AFS_INITIALIZE_CONTROL_DEVICE,
340 CloseHandle( glDevHandle);
346 return GetLastError();
350 // OK, now launch the workers
353 hEvent = CreateEvent( NULL,
359 // Here we create a pool of worker threads but you can create the pool with as many requests
363 if (numThreads < MIN_WORKER_THREADS)
364 numThreads = MIN_WORKER_THREADS;
365 else if (numThreads > MAX_WORKER_THREADS)
366 numThreads = MAX_WORKER_THREADS;
368 for (index = 0; index < numThreads; index++)
371 // 20% of worker threads should be reserved for release extent
374 glWorkerThreadInfo[ glThreadHandleIndex].Flags =
375 (glThreadHandleIndex % 5) ? 0 : AFS_REQUEST_RELEASE_THREAD;
376 glWorkerThreadInfo[ glThreadHandleIndex].hEvent = hEvent;
377 glWorkerThreadInfo[ glThreadHandleIndex].hThread =
380 RDR_RequestWorkerThread,
381 (void *)&glWorkerThreadInfo[ glThreadHandleIndex],
385 if( glWorkerThreadInfo[ glThreadHandleIndex].hThread != NULL)
389 // Wait for the thread to signal it is ready for processing
392 WaitForSingleObject( hEvent,
395 glThreadHandleIndex++;
403 // Perform cleanup specific to your application
409 if( !RDR_DeviceIoControl( glDevHandle,
410 IOCTL_AFS_INITIALIZE_REDIRECTOR_DEVICE,
418 CloseHandle( glDevHandle);
424 return GetLastError();
433 // Entry point for the worker thread
438 RDR_RequestWorkerThread( LPVOID lpParameter)
441 HANDLE hDevHandle = NULL;
443 AFSCommRequest *requestBuffer;
445 WorkerThreadInfo * pInfo = (WorkerThreadInfo *)lpParameter;
448 // We use the global handle to the control device instance
451 hDevHandle = glDevHandle;
454 // Allocate a request buffer.
457 requestBuffer = (AFSCommRequest *)malloc( sizeof( AFSCommRequest) + AFS_PAYLOAD_BUFFER_SIZE);
463 // Here we simply signal back to the main thread that we ahve started
466 SetEvent( pInfo->hEvent);
469 // Process requests until we are told to stop
475 memset( requestBuffer, '\0', sizeof( AFSCommRequest) + AFS_PAYLOAD_BUFFER_SIZE);
477 requestBuffer->RequestFlags = pInfo->Flags;
479 if( RDR_DeviceIoControl( hDevHandle,
480 IOCTL_AFS_PROCESS_IRP_REQUEST,
481 (void *)requestBuffer,
482 sizeof( AFSCommRequest),
483 (void *)requestBuffer,
484 sizeof( AFSCommRequest) + AFS_PAYLOAD_BUFFER_SIZE,
488 WaitForSingleObject( RDR_SuspendEvent, INFINITE);
491 // Go process the request
495 RDR_ProcessRequest( requestBuffer);
500 if (afsd_logp->enabled) {
501 WCHAR wchBuffer[256];
502 DWORD gle = GetLastError();
505 L"Failed to post IOCTL_AFS_IRP_REQUEST gle 0x%x", gle);
506 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
511 free( requestBuffer);
520 // This is the entry point for the worker threads to process the request from the TC Filter driver
524 RDR_ProcessRequest( AFSCommRequest *RequestBuffer)
530 ULONG ulCreateFlags = 0;
531 AFSCommResult * pResultCB = NULL;
532 AFSCommResult stResultCB;
533 DWORD dwResultBufferLength = 0;
534 AFSSetFileExtentsCB * SetFileExtentsResultCB = NULL;
535 AFSSetByteRangeLockResultCB *SetByteRangeLockResultCB = NULL;
536 WCHAR wchBuffer[1024];
537 char *pBuffer = (char *)wchBuffer;
539 cm_user_t * userp = NULL;
540 BOOL bWow64 = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_WOW64) ? TRUE : FALSE;
541 BOOL bFast = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_FAST_REQUEST) ? TRUE : FALSE;
542 BOOL bHoldFid = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_HOLD_FID) ? TRUE : FALSE;
543 BOOL bFlushFile = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_FLUSH_FILE) ? TRUE : FALSE;
544 BOOL bDeleteFile = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_FILE_DELETED) ? TRUE : FALSE;
545 BOOL bUnlockFile = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_BYTE_RANGE_UNLOCK_ALL) ? TRUE : FALSE;
546 BOOL bCheckOnly = (RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_CHECK_ONLY) ? TRUE : FALSE;
548 BOOL bUnsupported = FALSE;
549 BOOL bIsLocalSystem = (RequestBuffer->RequestFlags & AFS_REQUEST_LOCAL_SYSTEM_PAG) ? TRUE : FALSE;
551 userp = RDR_UserFromCommRequest(RequestBuffer);
555 // Build up the string to display based on the request type.
558 switch( RequestBuffer->RequestType)
561 case AFS_REQUEST_TYPE_DIR_ENUM:
564 AFSDirQueryCB *pQueryCB = (AFSDirQueryCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
566 if (afsd_logp->enabled) {
568 L"ProcessRequest Processing AFS_REQUEST_TYPE_DIR_ENUM Index %08lX",
569 RequestBuffer->RequestIndex);
571 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
575 // Here is where the content of the specific directory is enumerated.
578 RDR_EnumerateDirectory( userp, RequestBuffer->FileId,
579 pQueryCB, bWow64, bFast,
580 RequestBuffer->ResultBufferLength,
585 case AFS_REQUEST_TYPE_EVAL_TARGET_BY_ID:
587 AFSEvalTargetCB *pEvalTargetCB = (AFSEvalTargetCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
589 if (afsd_logp->enabled) {
591 L"ProcessRequest Processing AFS_REQUEST_TYPE_EVAL_TARGET_BY_ID Index %08lX",
592 RequestBuffer->RequestIndex);
594 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
597 // Here is where the specified node is evaluated.
600 RDR_EvaluateNodeByID( userp, pEvalTargetCB->ParentId,
601 RequestBuffer->FileId,
602 bWow64, bFast, bHoldFid,
603 RequestBuffer->ResultBufferLength,
608 case AFS_REQUEST_TYPE_EVAL_TARGET_BY_NAME:
610 AFSEvalTargetCB *pEvalTargetCB = (AFSEvalTargetCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
612 if (afsd_logp->enabled) {
614 L"ProcessRequest Processing AFS_REQUEST_TYPE_EVAL_TARGET_BY_NAME Index %08lX",
615 RequestBuffer->RequestIndex);
617 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
620 // Here is where the specified node is evaluated.
623 RDR_EvaluateNodeByName( userp, pEvalTargetCB->ParentId,
625 RequestBuffer->NameLength,
626 RequestBuffer->RequestFlags & AFS_REQUEST_FLAG_CASE_SENSITIVE ? TRUE : FALSE,
627 bWow64, bFast, bHoldFid,
628 RequestBuffer->ResultBufferLength,
633 case AFS_REQUEST_TYPE_CREATE_FILE:
636 AFSFileCreateCB *pCreateCB = (AFSFileCreateCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
638 WCHAR wchFileName[ 256];
640 if (afsd_logp->enabled) {
641 memset( wchFileName, '\0', 256 * sizeof( WCHAR));
645 RequestBuffer->NameLength);
647 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_CREATE_FILE Index %08lX File %S",
648 RequestBuffer->RequestIndex, wchFileName);
650 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
653 RDR_CreateFileEntry( userp,
655 RequestBuffer->NameLength,
659 RequestBuffer->ResultBufferLength,
665 case AFS_REQUEST_TYPE_UPDATE_FILE:
668 AFSFileUpdateCB *pUpdateCB = (AFSFileUpdateCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
670 if (afsd_logp->enabled) {
671 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_UPDATE_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX",
672 RequestBuffer->RequestIndex,
673 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
674 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
676 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
679 RDR_UpdateFileEntry( userp, RequestBuffer->FileId,
682 RequestBuffer->ResultBufferLength,
688 case AFS_REQUEST_TYPE_DELETE_FILE:
691 AFSFileDeleteCB *pDeleteCB = (AFSFileDeleteCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
693 if (afsd_logp->enabled) {
694 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_DELETE_FILE Index %08lX %08lX.%08lX.%08lX.%08lX CheckOnly %X",
695 RequestBuffer->RequestIndex,
696 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
697 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique,
700 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
703 RDR_DeleteFileEntry( userp,
705 pDeleteCB->ProcessId,
707 RequestBuffer->NameLength,
710 RequestBuffer->ResultBufferLength,
716 case AFS_REQUEST_TYPE_RENAME_FILE:
719 AFSFileRenameCB *pFileRenameCB = (AFSFileRenameCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
721 if (afsd_logp->enabled) {
722 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_RENAME_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX NameLength %08lX Name %*S TargetLength %08lX Target %*S",
723 RequestBuffer->RequestIndex,
724 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
725 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique,
726 RequestBuffer->NameLength, (int)RequestBuffer->NameLength, RequestBuffer->Name,
727 pFileRenameCB->TargetNameLength, (int)pFileRenameCB->TargetNameLength, pFileRenameCB->TargetName);
729 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
732 RDR_RenameFileEntry( userp,
734 RequestBuffer->NameLength,
735 RequestBuffer->FileId,
738 RequestBuffer->ResultBufferLength,
744 case AFS_REQUEST_TYPE_HARDLINK_FILE:
747 AFSFileHardLinkCB *pFileHardLinkCB = (AFSFileHardLinkCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
749 if (afsd_logp->enabled) {
750 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_HARDLINK_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX NameLength %08lX Name %*S TargetLength %08lX Target %*S",
751 RequestBuffer->RequestIndex,
752 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
753 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique,
754 RequestBuffer->NameLength, (int)RequestBuffer->NameLength, RequestBuffer->Name,
755 pFileHardLinkCB->TargetNameLength, (int)pFileHardLinkCB->TargetNameLength, pFileHardLinkCB->TargetName);
757 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
760 RDR_HardLinkFileEntry( userp,
762 RequestBuffer->NameLength,
763 RequestBuffer->FileId,
766 RequestBuffer->ResultBufferLength,
772 case AFS_REQUEST_TYPE_REQUEST_FILE_EXTENTS:
775 AFSRequestExtentsCB *pFileRequestExtentsCB = (AFSRequestExtentsCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
777 if (afsd_logp->enabled) {
778 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_REQUEST_FILE_EXTENTS Index %08lX File %08lX.%08lX.%08lX.%08lX %S",
779 RequestBuffer->RequestIndex,
780 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
781 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique,
782 BooleanFlagOn( RequestBuffer->RequestFlags, AFS_REQUEST_FLAG_SYNCHRONOUS) ? L"Sync" : L"Async");
784 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
787 if (BooleanFlagOn( RequestBuffer->RequestFlags, AFS_REQUEST_FLAG_SYNCHRONOUS))
788 osi_panic("SYNCHRONOUS AFS_REQUEST_TYPE_REQUEST_FILE_EXTENTS not supported",
791 bRetry = RDR_RequestFileExtentsAsync( userp, RequestBuffer->FileId,
792 pFileRequestExtentsCB,
794 &dwResultBufferLength,
795 &SetFileExtentsResultCB );
799 case AFS_REQUEST_TYPE_RELEASE_FILE_EXTENTS:
802 AFSReleaseExtentsCB *pFileReleaseExtentsCB = (AFSReleaseExtentsCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
804 if (afsd_logp->enabled) {
805 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_RELEASE_FILE_EXTENTS Index %08lX File %08lX.%08lX.%08lX.%08lX",
806 RequestBuffer->RequestIndex,
807 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
808 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
810 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
813 RDR_ReleaseFileExtents( userp, RequestBuffer->FileId,
814 pFileReleaseExtentsCB,
816 RequestBuffer->ResultBufferLength,
822 case AFS_REQUEST_TYPE_FLUSH_FILE:
824 if (afsd_logp->enabled) {
825 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_FLUSH_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX",
826 RequestBuffer->RequestIndex,
827 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
828 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
830 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
833 RDR_FlushFileEntry( userp, RequestBuffer->FileId,
835 RequestBuffer->ResultBufferLength,
840 case AFS_REQUEST_TYPE_OPEN_FILE:
842 AFSFileOpenCB *pFileOpenCB = (AFSFileOpenCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
844 if (afsd_logp->enabled) {
845 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_OPEN_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX",
846 RequestBuffer->RequestIndex,
847 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
848 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
850 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
853 RDR_OpenFileEntry( userp, RequestBuffer->FileId,
857 RequestBuffer->ResultBufferLength,
863 case AFS_REQUEST_TYPE_RELEASE_FILE_ACCESS:
865 AFSFileAccessReleaseCB *pFileAccessReleaseCB = (AFSFileAccessReleaseCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
867 if (afsd_logp->enabled) {
868 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_RELEASE_FILE_ACCESS Index %08lX File %08lX.%08lX.%08lX.%08lX",
869 RequestBuffer->RequestIndex,
870 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
871 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
873 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
876 RDR_ReleaseFileAccess( userp,
877 RequestBuffer->FileId,
878 pFileAccessReleaseCB,
880 RequestBuffer->ResultBufferLength,
886 case AFS_REQUEST_TYPE_PIOCTL_OPEN:
888 AFSPIOCtlOpenCloseRequestCB *pPioctlCB = (AFSPIOCtlOpenCloseRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
890 if (afsd_logp->enabled) {
891 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIOCTL_OPEN Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
892 RequestBuffer->RequestIndex,
893 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
894 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
896 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
899 RDR_PioctlOpen( userp,
900 RequestBuffer->FileId,
903 RequestBuffer->ResultBufferLength,
908 case AFS_REQUEST_TYPE_PIOCTL_WRITE:
910 AFSPIOCtlIORequestCB *pPioctlCB = (AFSPIOCtlIORequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
912 if (afsd_logp->enabled) {
913 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIOCTL_WRITE Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
914 RequestBuffer->RequestIndex,
915 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
916 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
918 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
921 RDR_PioctlWrite( userp,
922 RequestBuffer->FileId,
925 RequestBuffer->ResultBufferLength,
930 case AFS_REQUEST_TYPE_PIOCTL_READ:
932 AFSPIOCtlIORequestCB *pPioctlCB = (AFSPIOCtlIORequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
934 if (afsd_logp->enabled) {
935 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIOCTL_READ Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
936 RequestBuffer->RequestIndex,
937 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
938 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
940 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
943 RDR_PioctlRead( userp,
944 RequestBuffer->FileId,
948 RequestBuffer->ResultBufferLength,
953 case AFS_REQUEST_TYPE_PIOCTL_CLOSE:
955 AFSPIOCtlOpenCloseRequestCB *pPioctlCB = (AFSPIOCtlOpenCloseRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
957 if (afsd_logp->enabled) {
958 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIOCTL_CLOSE Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
959 RequestBuffer->RequestIndex,
960 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
961 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
963 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
966 RDR_PioctlClose( userp,
967 RequestBuffer->FileId,
970 RequestBuffer->ResultBufferLength,
976 case AFS_REQUEST_TYPE_BYTE_RANGE_LOCK:
978 if (afsd_logp->enabled) {
979 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_BYTE_RANGE_LOCK Index %08lX File %08lX.%08lX.%08lX.%08lX %S",
980 RequestBuffer->RequestIndex,
981 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
982 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique,
983 BooleanFlagOn( RequestBuffer->RequestFlags, AFS_REQUEST_FLAG_SYNCHRONOUS) ? L"Sync" : L"Async");
985 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
988 AFSByteRangeLockRequestCB *pBRLRequestCB = (AFSByteRangeLockRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
990 RDR_ByteRangeLockSync( userp,
991 RequestBuffer->FileId,
994 RequestBuffer->ResultBufferLength,
1000 case AFS_REQUEST_TYPE_BYTE_RANGE_UNLOCK:
1002 AFSByteRangeUnlockRequestCB *pBRURequestCB = (AFSByteRangeUnlockRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1004 if (afsd_logp->enabled) {
1005 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_BYTE_RANGE_UNLOCK Index %08lX File %08lX.%08lX.%08lX.%08lX",
1006 RequestBuffer->RequestIndex,
1007 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1008 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1010 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1013 RDR_ByteRangeUnlock( userp,
1014 RequestBuffer->FileId,
1017 RequestBuffer->ResultBufferLength,
1022 case AFS_REQUEST_TYPE_BYTE_RANGE_UNLOCK_ALL:
1024 AFSByteRangeUnlockRequestCB *pBRURequestCB = (AFSByteRangeUnlockRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1026 if (afsd_logp->enabled) {
1027 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_BYTE_RANGE_UNLOCK_ALL Index %08lX File %08lX.%08lX.%08lX.%08lX",
1028 RequestBuffer->RequestIndex,
1029 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1030 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1032 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1035 RDR_ByteRangeUnlockAll( userp,
1036 RequestBuffer->FileId,
1039 RequestBuffer->ResultBufferLength,
1044 case AFS_REQUEST_TYPE_GET_VOLUME_INFO:
1046 if (afsd_logp->enabled) {
1047 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_GET_VOLUME_INFO Index %08lX File %08lX.%08lX.%08lX.%08lX",
1048 RequestBuffer->RequestIndex,
1049 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1050 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1052 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1055 RDR_GetVolumeInfo( userp,
1056 RequestBuffer->FileId,
1058 RequestBuffer->ResultBufferLength,
1063 case AFS_REQUEST_TYPE_GET_VOLUME_SIZE_INFO:
1065 if (afsd_logp->enabled) {
1066 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_GET_VOLUME_SIZE_INFO Index %08lX File %08lX.%08lX.%08lX.%08lX",
1067 RequestBuffer->RequestIndex,
1068 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1069 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1071 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1074 RDR_GetVolumeSizeInfo( userp,
1075 RequestBuffer->FileId,
1077 RequestBuffer->ResultBufferLength,
1082 case AFS_REQUEST_TYPE_HOLD_FID:
1085 AFSHoldFidRequestCB *pHoldFidCB = (AFSHoldFidRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1087 if (afsd_logp->enabled) {
1088 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_HOLD_FID Index %08lX",
1089 RequestBuffer->RequestIndex);
1091 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1097 RequestBuffer->ResultBufferLength,
1103 case AFS_REQUEST_TYPE_RELEASE_FID:
1106 AFSReleaseFidRequestCB *pReleaseFidCB = (AFSReleaseFidRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1108 if (afsd_logp->enabled) {
1109 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_RELEASE_FID Index %08lX",
1110 RequestBuffer->RequestIndex);
1112 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1115 RDR_ReleaseFid( userp,
1118 RequestBuffer->ResultBufferLength,
1124 case AFS_REQUEST_TYPE_CLEANUP_PROCESSING:
1127 AFSFileCleanupCB *pCleanupCB = (AFSFileCleanupCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1129 if (afsd_logp->enabled) {
1130 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_CLEANUP_FILE Index %08lX File %08lX.%08lX.%08lX.%08lX",
1131 RequestBuffer->RequestIndex,
1132 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1133 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1135 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1138 RDR_CleanupFileEntry( userp,
1139 RequestBuffer->FileId,
1140 RequestBuffer->Name,
1141 RequestBuffer->NameLength,
1147 RequestBuffer->ResultBufferLength,
1153 case AFS_REQUEST_TYPE_PIPE_OPEN:
1155 AFSPipeOpenCloseRequestCB *pPipeCB = (AFSPipeOpenCloseRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1157 if (afsd_logp->enabled) {
1158 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_OPEN Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
1159 RequestBuffer->RequestIndex,
1160 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1161 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1163 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1166 RDR_PipeOpen( userp,
1167 RequestBuffer->FileId,
1168 RequestBuffer->Name,
1169 RequestBuffer->NameLength,
1172 RequestBuffer->ResultBufferLength,
1177 case AFS_REQUEST_TYPE_PIPE_WRITE:
1179 AFSPipeIORequestCB *pPipeCB = (AFSPipeIORequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1180 BYTE *pPipeData = ((BYTE *)RequestBuffer->Name + RequestBuffer->DataOffset + sizeof(AFSPipeIORequestCB));
1182 if (afsd_logp->enabled) {
1183 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_WRITE Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
1184 RequestBuffer->RequestIndex,
1185 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1186 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1188 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1191 RDR_PipeWrite( userp,
1192 RequestBuffer->FileId,
1196 RequestBuffer->ResultBufferLength,
1201 case AFS_REQUEST_TYPE_PIPE_READ:
1203 AFSPipeIORequestCB *pPipeCB = (AFSPipeIORequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1205 if (afsd_logp->enabled) {
1206 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_READ Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
1207 RequestBuffer->RequestIndex,
1208 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1209 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1211 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1214 RDR_PipeRead( userp,
1215 RequestBuffer->FileId,
1218 RequestBuffer->ResultBufferLength,
1223 case AFS_REQUEST_TYPE_PIPE_CLOSE:
1225 AFSPipeOpenCloseRequestCB *pPipeCB = (AFSPipeOpenCloseRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1227 if (afsd_logp->enabled) {
1228 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_CLOSE Index %08lX Parent %08lX.%08lX.%08lX.%08lX",
1229 RequestBuffer->RequestIndex,
1230 RequestBuffer->FileId.Cell, RequestBuffer->FileId.Volume,
1231 RequestBuffer->FileId.Vnode, RequestBuffer->FileId.Unique);
1233 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1236 RDR_PipeClose( userp,
1237 RequestBuffer->FileId,
1240 RequestBuffer->ResultBufferLength,
1246 case AFS_REQUEST_TYPE_PIPE_TRANSCEIVE:
1248 AFSPipeIORequestCB *pPipeCB = (AFSPipeIORequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1249 BYTE *pPipeData = ((BYTE *)RequestBuffer->Name + RequestBuffer->DataOffset + sizeof(AFSPipeIORequestCB));
1251 if (afsd_logp->enabled) {
1252 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_TRANSCEIVE Index %08lX",
1253 RequestBuffer->RequestIndex);
1255 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1258 RDR_PipeTransceive( userp,
1259 RequestBuffer->FileId,
1263 RequestBuffer->ResultBufferLength,
1268 case AFS_REQUEST_TYPE_PIPE_QUERY_INFO:
1270 AFSPipeInfoRequestCB *pPipeInfoCB = (AFSPipeInfoRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1272 if (afsd_logp->enabled) {
1273 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_QUERY_INFO Index %08lX",
1274 RequestBuffer->RequestIndex);
1276 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1279 RDR_PipeQueryInfo( userp,
1280 RequestBuffer->FileId,
1283 RequestBuffer->ResultBufferLength,
1288 case AFS_REQUEST_TYPE_PIPE_SET_INFO:
1290 AFSPipeInfoRequestCB *pPipeInfoCB = (AFSPipeInfoRequestCB *)((char *)RequestBuffer->Name + RequestBuffer->DataOffset);
1291 BYTE *pPipeData = ((BYTE *)RequestBuffer->Name + RequestBuffer->DataOffset + sizeof(AFSPipeInfoRequestCB));
1293 if (afsd_logp->enabled) {
1294 swprintf( wchBuffer, L"ProcessRequest Processing AFS_REQUEST_TYPE_PIPE_SET_INFO Index %08lX",
1295 RequestBuffer->RequestIndex);
1297 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1300 RDR_PipeSetInfo( userp,
1301 RequestBuffer->FileId,
1305 RequestBuffer->ResultBufferLength,
1312 bUnsupported = TRUE;
1314 if (afsd_logp->enabled) {
1315 swprintf( wchBuffer, L"ProcessRequest Received unknown request type %08lX Index %08lX",
1316 RequestBuffer->RequestType,
1317 RequestBuffer->RequestIndex);
1319 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1325 if( BooleanFlagOn( RequestBuffer->RequestFlags, AFS_REQUEST_FLAG_SYNCHRONOUS))
1328 if (pResultCB == NULL) {
1329 // We failed probably due to a memory allocation error
1330 // unless the unsupported flag was set.
1331 pResultCB = &stResultCB;
1332 memset(&stResultCB, 0, sizeof(stResultCB));
1334 pResultCB->ResultStatus = STATUS_NOT_IMPLEMENTED;
1336 pResultCB->ResultStatus = STATUS_NO_MEMORY;
1340 pResultCB->Authenticated = cm_HaveToken( userp,
1341 RequestBuffer->FileId.Cell);
1345 // This is how the filter associates the response information passed in the IOCtl below to the
1346 // original call. This request index is setup by the filter and should not be modified, otherwise the
1347 // filter will not be able to locate the request in its internal queue and the blocking thread will
1351 pResultCB->RequestIndex = RequestBuffer->RequestIndex;
1353 if (afsd_logp->enabled) {
1354 swprintf( wchBuffer,
1355 L"ProcessRequest Responding to Index %08lX Length %08lX",
1356 pResultCB->RequestIndex,
1357 pResultCB->ResultBufferLength);
1359 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1363 // Now post the result back to the driver.
1366 if( !RDR_DeviceIoControl( glDevHandle,
1367 IOCTL_AFS_PROCESS_IRP_RESULT,
1369 sizeof( AFSCommResult) + pResultCB->ResultBufferLength,
1374 char *pBuffer = (char *)wchBuffer;
1375 gle = GetLastError();
1376 if (afsd_logp->enabled) {
1377 swprintf( wchBuffer,
1378 L"Failed to post IOCTL_AFS_PROCESS_IRP_RESULT gle %X", gle);
1379 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1382 if (gle != ERROR_NOT_READY) {
1384 "Failed to post IOCTL_AFS_PROCESS_IRP_RESULT gle %X",
1386 osi_panic(pBuffer, __FILE__, __LINE__);
1391 else if (RequestBuffer->RequestType == AFS_REQUEST_TYPE_REQUEST_FILE_EXTENTS) {
1393 if (SetFileExtentsResultCB) {
1395 if (1 || afsd_logp->enabled) {
1396 if (SetFileExtentsResultCB->ResultStatus != 0)
1397 swprintf( wchBuffer,
1398 L"ProcessRequest Responding Asynchronously with FAILURE to REQUEST_FILE_EXTENTS Index %08lX Count %08lX Status %08lX",
1399 RequestBuffer->RequestIndex, SetFileExtentsResultCB->ExtentCount, SetFileExtentsResultCB->ResultStatus);
1401 swprintf( wchBuffer,
1402 L"ProcessRequest Responding Asynchronously with SUCCESS to REQUEST_FILE_EXTENTS Index %08lX Count %08lX",
1403 RequestBuffer->RequestIndex, SetFileExtentsResultCB->ExtentCount);
1405 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1408 if( (SetFileExtentsResultCB->ExtentCount != 0 ||
1409 SetFileExtentsResultCB->ResultStatus != 0) &&
1410 !RDR_DeviceIoControl( glDevHandle,
1411 IOCTL_AFS_SET_FILE_EXTENTS,
1412 (void *)SetFileExtentsResultCB,
1413 dwResultBufferLength,
1418 gle = GetLastError();
1419 if (afsd_logp->enabled) {
1420 swprintf( wchBuffer,
1421 L"Failed to post IOCTL_AFS_SET_FILE_EXTENTS gle %X",
1423 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1426 // The file system returns an error when it can't find the FID
1427 // This is a bug in the file system but we should try to avoid
1428 // the crash and clean up our own memory space.
1430 // Since we couldn't deliver the extents to the file system
1431 // we should release them.
1432 if ( SetFileExtentsResultCB->ExtentCount != 0)
1434 RDR_ReleaseFailedSetFileExtents( userp,
1435 SetFileExtentsResultCB,
1436 dwResultBufferLength);
1439 if (gle != ERROR_GEN_FAILURE &&
1440 gle != ERROR_NOT_READY) {
1442 "Failed to post IOCTL_AFS_SET_FILE_EXTENTS gle %X",
1444 osi_panic(pBuffer, __FILE__, __LINE__);
1448 free(SetFileExtentsResultCB);
1451 /* Must be out of memory */
1452 if (afsd_logp->enabled) {
1453 swprintf( wchBuffer,
1454 L"ProcessRequest Responding Asynchronously STATUS_NO_MEMORY to REQUEST_FILE_EXTENTS Index %08lX",
1455 RequestBuffer->RequestIndex);
1457 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1460 RDR_SetFileStatus2( &RequestBuffer->FileId, &RequestBuffer->AuthGroup, STATUS_NO_MEMORY);
1463 else if (RequestBuffer->RequestType == AFS_REQUEST_TYPE_BYTE_RANGE_LOCK) {
1465 if (afsd_logp->enabled) {
1466 swprintf( wchBuffer,
1467 L"ProcessRequest Responding Asynchronously to REQUEST_TYPE_BYTE_RANGELOCK Index %08lX",
1468 RequestBuffer->RequestIndex);
1470 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1474 if (SetByteRangeLockResultCB) {
1476 if( !RDR_DeviceIoControl( glDevHandle,
1477 IOCTL_AFS_SET_BYTE_RANGE_LOCKS,
1478 (void *)SetByteRangeLockResultCB,
1479 dwResultBufferLength,
1484 gle = GetLastError();
1486 if (afsd_logp->enabled) {
1487 swprintf( wchBuffer,
1488 L"Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle 0x%x", gle);
1489 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1493 if (gle != ERROR_NOT_READY) {
1494 // TODO - instead of a panic we should release the locks
1496 "Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle %X", gle);
1497 osi_panic(pBuffer, __FILE__, __LINE__);
1501 free(SetByteRangeLockResultCB);
1503 /* Must be out of memory */
1504 AFSSetByteRangeLockResultCB SetByteRangeLockResultCB;
1506 dwResultBufferLength = sizeof(AFSSetByteRangeLockResultCB);
1507 memset( &SetByteRangeLockResultCB, '\0', dwResultBufferLength );
1508 SetByteRangeLockResultCB.FileId = RequestBuffer->FileId;
1509 SetByteRangeLockResultCB.Result[0].Status = STATUS_NO_MEMORY;
1511 if( !RDR_DeviceIoControl( glDevHandle,
1512 IOCTL_AFS_SET_BYTE_RANGE_LOCKS,
1513 (void *)&SetByteRangeLockResultCB,
1514 dwResultBufferLength,
1519 gle = GetLastError();
1521 if (afsd_logp->enabled) {
1522 swprintf( wchBuffer,
1523 L"Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle 0x%x", gle);
1524 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1527 /* We were out of memory - nothing to do */
1533 if (afsd_logp->enabled) {
1534 swprintf( wchBuffer,
1535 L"ProcessRequest Not responding to async Index %08lX",
1536 RequestBuffer->RequestIndex);
1538 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1546 RDR_ReleaseUser(userp);
1549 if( pResultCB && pResultCB != &stResultCB)
1559 RDR_SetFileExtents( AFSSetFileExtentsCB *pSetFileExtentsResultCB,
1560 DWORD dwResultBufferLength)
1562 WCHAR wchBuffer[1024];
1563 DWORD bytesReturned;
1566 if (1 || afsd_logp->enabled) {
1567 if (pSetFileExtentsResultCB->ResultStatus != 0)
1568 swprintf( wchBuffer,
1569 L"RDR_SetFileExtents IOCTL_AFS_SET_FILE_EXTENTS FAILURE Count %08lX Status %08lX",
1570 pSetFileExtentsResultCB->ExtentCount, pSetFileExtentsResultCB->ResultStatus);
1572 swprintf( wchBuffer,
1573 L"RDR_SetFileExtents IOCTL_AFS_SET_FILE_EXTENTS SUCCESS Count %08lX",
1574 pSetFileExtentsResultCB->ExtentCount);
1576 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1579 if( !RDR_DeviceIoControl( glDevHandle,
1580 IOCTL_AFS_SET_FILE_EXTENTS,
1581 (void *)pSetFileExtentsResultCB,
1582 dwResultBufferLength,
1587 gle = GetLastError();
1596 RDR_SetFileStatus( cm_fid_t *fidp,
1600 WCHAR wchBuffer[1024];
1601 AFSExtentFailureCB SetFileStatusCB;
1602 DWORD bytesReturned;
1605 RDR_fid2FID(fidp, &SetFileStatusCB.FileId);
1606 memcpy(&SetFileStatusCB.AuthGroup, pAuthGroup, sizeof(GUID));
1607 SetFileStatusCB.FailureStatus = dwStatus;
1609 if (afsd_logp->enabled) {
1610 swprintf( wchBuffer, L"RDR_SetFileStatus IOCTL_AFS_EXTENT_FAILURE_CB Fid %08lX.%08lX.%08lX.%08lX Status 0x%lX",
1611 SetFileStatusCB.FileId.Cell, SetFileStatusCB.FileId.Volume,
1612 SetFileStatusCB.FileId.Vnode, SetFileStatusCB.FileId.Unique,
1615 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1618 if( !RDR_DeviceIoControl( glDevHandle,
1619 IOCTL_AFS_SET_FILE_EXTENT_FAILURE,
1620 (void *)&SetFileStatusCB,
1621 sizeof(AFSExtentFailureCB),
1626 gle = GetLastError();
1634 RDR_SetFileStatus2( AFSFileID *pFileId,
1638 WCHAR wchBuffer[1024];
1639 AFSExtentFailureCB SetFileStatusCB;
1640 DWORD bytesReturned;
1643 memcpy(&SetFileStatusCB.FileId, pFileId, sizeof(AFSFileID));
1644 memcpy(&SetFileStatusCB.AuthGroup, pAuthGroup, sizeof(GUID));
1645 SetFileStatusCB.FailureStatus = dwStatus;
1647 if (afsd_logp->enabled) {
1648 swprintf( wchBuffer, L"RDR_SetFileStatus2 IOCTL_AFS_EXTENT_FAILURE_CB Fid %08lX.%08lX.%08lX.%08lX Status 0x%lX",
1649 SetFileStatusCB.FileId.Cell, SetFileStatusCB.FileId.Volume,
1650 SetFileStatusCB.FileId.Vnode, SetFileStatusCB.FileId.Unique,
1653 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1656 if( !RDR_DeviceIoControl( glDevHandle,
1657 IOCTL_AFS_SET_FILE_EXTENT_FAILURE,
1658 (void *)&SetFileStatusCB,
1659 sizeof(AFSExtentFailureCB),
1664 gle = GetLastError();
1672 RDR_RequestExtentRelease(cm_fid_t *fidp, LARGE_INTEGER numOfHeldExtents, DWORD numOfExtents, AFSFileExtentCB *extentList)
1675 HANDLE hDevHandle = NULL;
1676 DWORD bytesReturned;
1677 AFSReleaseFileExtentsCB *requestBuffer = NULL;
1678 AFSReleaseFileExtentsResultCB *responseBuffer = NULL;
1679 DWORD requestBufferLen, responseBufferLen;
1680 bool bError = false;
1682 WCHAR wchBuffer[256];
1686 if (afsd_logp->enabled) {
1687 swprintf( wchBuffer,
1688 L"IOCTL_AFS_RELEASE_FILE_EXTENTS request ignored due to shutdown pending");
1690 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1693 OutputDebugString(L"RDR_RequestExtentRequest ignored - shutdown pending\n");
1694 return CM_ERROR_WOULDBLOCK;
1697 if (afsd_logp->enabled) {
1698 swprintf( wchBuffer,
1699 L"IOCTL_AFS_RELEASE_FILE_EXTENTS request - number %08lX",
1702 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1706 // We use the global handle to the control device instance
1709 hDevHandle = glDevHandle;
1712 // Allocate a request buffer.
1715 requestBufferLen = sizeof( AFSReleaseFileExtentsCB) + sizeof(AFSFileExtentCB) * numOfExtents;
1716 requestBuffer = (AFSReleaseFileExtentsCB *)malloc( requestBufferLen);
1717 responseBufferLen = (sizeof( AFSReleaseFileExtentsResultCB) + sizeof( AFSReleaseFileExtentsResultFileCB)) * numOfExtents;
1718 responseBuffer = (AFSReleaseFileExtentsResultCB *)malloc( responseBufferLen);
1721 if( requestBuffer && responseBuffer)
1724 memset( requestBuffer, '\0', sizeof( AFSReleaseFileExtentsCB));
1725 memset( responseBuffer, '\0', responseBufferLen);
1727 // If there is a FID provided, use it
1728 if (fidp && extentList)
1730 RDR_fid2FID( fidp, &requestBuffer->FileId);
1732 memcpy(&requestBuffer->FileExtents, extentList, numOfExtents * sizeof(AFSFileExtentCB));
1734 requestBuffer->Flags = 0;
1737 requestBuffer->Flags = AFS_RELEASE_EXTENTS_FLAGS_RELEASE_ALL;
1740 // Set the number of extents to be freed
1741 // Leave the rest of the structure as zeros to indicate free anything
1742 requestBuffer->ExtentCount = numOfExtents;
1744 requestBuffer->HeldExtentCount = numOfHeldExtents;
1746 if( !RDR_DeviceIoControl( hDevHandle,
1747 IOCTL_AFS_RELEASE_FILE_EXTENTS,
1748 (void *)requestBuffer,
1750 (void *)responseBuffer,
1755 // Error condition back from driver
1757 if (afsd_logp->enabled) {
1758 gle = GetLastError();
1759 swprintf( wchBuffer,
1760 L"Failed to post IOCTL_AFS_RELEASE_FILE_EXTENTS - gle 0x%x", gle);
1761 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1768 // Go process the request
1771 if (afsd_logp->enabled) {
1772 swprintf( wchBuffer,
1773 L"IOCTL_AFS_RELEASE_FILE_EXTENTS returns - serial number %08lX flags %lX FileCount %lX",
1774 responseBuffer->SerialNumber, responseBuffer->Flags, responseBuffer->FileCount);
1775 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1778 rc = RDR_ProcessReleaseFileExtentsResult( responseBuffer, bytesReturned);
1786 free( requestBuffer);
1788 free( responseBuffer);
1795 RDR_NetworkStatus(BOOLEAN status)
1798 HANDLE hDevHandle = NULL;
1799 DWORD bytesReturned;
1800 AFSNetworkStatusCB *requestBuffer = NULL;
1802 WCHAR wchBuffer[256];
1805 if (afsd_logp->enabled) {
1806 swprintf( wchBuffer,
1807 L"IOCTL_AFS_NETWORK_STATUS request - status %d",
1810 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1814 // We use the global handle to the control device instance
1817 hDevHandle = glDevHandle;
1820 // Allocate a request buffer.
1823 requestBuffer = (AFSNetworkStatusCB *)malloc( sizeof( AFSNetworkStatusCB));
1829 memset( requestBuffer, '\0', sizeof( AFSNetworkStatusCB));
1831 // Set the number of extents to be freed
1832 // Leave the rest of the structure as zeros to indicate free anything
1833 requestBuffer->Online = status;
1835 if( !RDR_DeviceIoControl( hDevHandle,
1836 IOCTL_AFS_NETWORK_STATUS,
1837 (void *)requestBuffer,
1838 sizeof( AFSNetworkStatusCB),
1844 // Error condition back from driver
1846 if (afsd_logp->enabled) {
1847 gle = GetLastError();
1848 swprintf( wchBuffer,
1849 L"Failed to post IOCTL_AFS_NETWORK_STATUS gle 0x%x",
1851 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1862 free( requestBuffer);
1870 RDR_VolumeStatus(ULONG cellID, ULONG volID, BOOLEAN online)
1873 HANDLE hDevHandle = NULL;
1874 DWORD bytesReturned;
1875 AFSVolumeStatusCB *requestBuffer = NULL;
1877 WCHAR wchBuffer[256];
1880 if (afsd_logp->enabled) {
1881 swprintf( wchBuffer,
1882 L"IOCTL_AFS_VOLUME_STATUS request - cell 0x%x vol 0x%x online %d",
1883 cellID, volID, online);
1885 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1889 // We use the global handle to the control device instance
1892 hDevHandle = glDevHandle;
1895 // Allocate a request buffer.
1898 requestBuffer = (AFSVolumeStatusCB *)malloc( sizeof( AFSVolumeStatusCB));
1904 memset( requestBuffer, '\0', sizeof( AFSVolumeStatusCB));
1906 requestBuffer->FileID.Cell = cellID;
1907 requestBuffer->FileID.Volume = volID;
1908 requestBuffer->Online = online;
1910 if( !RDR_DeviceIoControl( hDevHandle,
1911 IOCTL_AFS_VOLUME_STATUS,
1912 (void *)requestBuffer,
1913 sizeof( AFSVolumeStatusCB),
1919 // Error condition back from driver
1922 if (afsd_logp->enabled) {
1923 gle = GetLastError();
1924 swprintf( wchBuffer,
1925 L"Failed to post IOCTL_AFS_VOLUME_STATUS gle 0x%x", gle);
1926 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1937 free( requestBuffer);
1943 RDR_NetworkAddrChange(void)
1950 RDR_InvalidateVolume(ULONG cellID, ULONG volID, ULONG reason)
1953 HANDLE hDevHandle = NULL;
1954 DWORD bytesReturned;
1955 AFSInvalidateCacheCB *requestBuffer = NULL;
1957 WCHAR wchBuffer[256];
1960 if (afsd_logp->enabled) {
1961 swprintf( wchBuffer,
1962 L"IOCTL_AFS_INVALIDATE_CACHE (vol) request - cell 0x%x vol 0x%x reason %d",
1963 cellID, volID, reason);
1965 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1969 // We use the global handle to the control device instance
1972 hDevHandle = glDevHandle;
1975 // Allocate a request buffer.
1978 requestBuffer = (AFSInvalidateCacheCB *)malloc( sizeof( AFSInvalidateCacheCB));
1984 memset( requestBuffer, '\0', sizeof( AFSInvalidateCacheCB));
1986 requestBuffer->FileID.Cell = cellID;
1987 requestBuffer->FileID.Volume = volID;
1988 requestBuffer->WholeVolume = TRUE;
1989 requestBuffer->Reason = reason;
1991 if( !RDR_DeviceIoControl( hDevHandle,
1992 IOCTL_AFS_INVALIDATE_CACHE,
1993 (void *)requestBuffer,
1994 sizeof( AFSInvalidateCacheCB),
2000 // Error condition back from driver
2003 if (afsd_logp->enabled) {
2004 gle = GetLastError();
2005 swprintf( wchBuffer,
2006 L"Failed to post IOCTL_AFS_INVALIDATE_VOLUME gle 0x%x", gle);
2007 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2018 free( requestBuffer);
2025 RDR_InvalidateObject(ULONG cellID, ULONG volID, ULONG vnode, ULONG uniq, ULONG hash, ULONG fileType, ULONG reason)
2028 HANDLE hDevHandle = NULL;
2029 DWORD bytesReturned;
2030 AFSInvalidateCacheCB *requestBuffer = NULL;
2032 WCHAR wchBuffer[256];
2035 if (afsd_logp->enabled) {
2036 swprintf( wchBuffer,
2037 L"IOCTL_AFS_INVALIDATE_CACHE (obj) request - cell 0x%x vol 0x%x vn 0x%x uniq 0x%x hash 0x%x type 0x%x reason %d",
2038 cellID, volID, vnode, uniq, hash, fileType, reason);
2040 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2044 // We use the global handle to the control device instance
2047 hDevHandle = glDevHandle;
2050 // Allocate a request buffer.
2053 requestBuffer = (AFSInvalidateCacheCB *)malloc( sizeof( AFSInvalidateCacheCB));
2059 memset( requestBuffer, '\0', sizeof( AFSInvalidateCacheCB));
2061 requestBuffer->FileID.Cell = cellID;
2062 requestBuffer->FileID.Volume = volID;
2063 requestBuffer->FileID.Vnode = vnode;
2064 requestBuffer->FileID.Unique = uniq;
2065 requestBuffer->FileID.Hash = hash;
2066 requestBuffer->FileType = fileType;
2067 requestBuffer->WholeVolume = FALSE;
2068 requestBuffer->Reason = reason;
2070 if( !RDR_DeviceIoControl( hDevHandle,
2071 IOCTL_AFS_INVALIDATE_CACHE,
2072 (void *)requestBuffer,
2073 sizeof( AFSInvalidateCacheCB),
2079 // Error condition back from driver
2081 if (afsd_logp->enabled) {
2082 gle = GetLastError();
2083 swprintf( wchBuffer,
2084 L"Failed to post IOCTL_AFS_INVALIDATE_CACHE gle 0x%x", gle);
2085 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2096 free( requestBuffer);
2104 RDR_SysName(ULONG Architecture, ULONG Count, WCHAR **NameList)
2107 HANDLE hDevHandle = NULL;
2108 DWORD bytesReturned;
2109 AFSSysNameNotificationCB *requestBuffer = NULL;
2111 WCHAR wchBuffer[256];
2115 if (afsd_logp->enabled) {
2116 swprintf( wchBuffer,
2117 L"IOCTL_AFS_SYSNAME_NOTIFICATION request - Arch %d Count %d",
2118 Architecture, Count);
2120 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2123 if (Count <= 0 || NameList == NULL)
2127 // We use the global handle to the control device instance
2130 hDevHandle = glDevHandle;
2133 // Allocate a request buffer.
2136 Length = sizeof (AFSSysNameNotificationCB) + (Count - 1) * sizeof (AFSSysName);
2137 requestBuffer = (AFSSysNameNotificationCB *)malloc( Length );
2144 memset( requestBuffer, '\0', Length);
2146 requestBuffer->Architecture = Architecture;
2147 requestBuffer->NumberOfNames = Count;
2148 for ( i=0 ; i<Count; i++) {
2149 size_t len = wcslen(NameList[i]);
2150 requestBuffer->SysNames[i].Length = (ULONG) (len * sizeof(WCHAR));
2151 StringCchCopyNW(requestBuffer->SysNames[i].String, AFS_MAX_SYSNAME_LENGTH,
2155 if( !RDR_DeviceIoControl( hDevHandle,
2156 IOCTL_AFS_SYSNAME_NOTIFICATION,
2157 (void *)requestBuffer,
2164 // Error condition back from driver
2166 if (afsd_logp->enabled) {
2167 gle = GetLastError();
2168 swprintf( wchBuffer,
2169 L"Failed to post IOCTL_AFS_SYSNAME_NOTIFICATION gle 0x%x", gle);
2170 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2181 free( requestBuffer);
2189 ResetEvent( RDR_SuspendEvent);
2195 SetEvent( RDR_SuspendEvent);