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));
1326 pResultCB->Authenticated = cm_HaveToken( userp,
1327 RequestBuffer->FileId.Cell);
1330 if( BooleanFlagOn( RequestBuffer->RequestFlags, AFS_REQUEST_FLAG_SYNCHRONOUS))
1332 if (pResultCB == NULL) {
1333 // We failed probably due to a memory allocation error
1334 // unless the unsupported flag was set.
1335 pResultCB = &stResultCB;
1336 memset(&stResultCB, 0, sizeof(stResultCB));
1338 pResultCB->ResultStatus = STATUS_NOT_IMPLEMENTED;
1340 pResultCB->ResultStatus = STATUS_NO_MEMORY;
1344 // This is how the filter associates the response information passed in the IOCtl below to the
1345 // original call. This request index is setup by the filter and should not be modified, otherwise the
1346 // filter will not be able to locate the request in its internal queue and the blocking thread will
1350 pResultCB->RequestIndex = RequestBuffer->RequestIndex;
1352 if (afsd_logp->enabled) {
1353 swprintf( wchBuffer,
1354 L"ProcessRequest Responding to Index %08lX Length %08lX",
1355 pResultCB->RequestIndex,
1356 pResultCB->ResultBufferLength);
1358 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1362 // Now post the result back to the driver.
1365 if( !RDR_DeviceIoControl( glDevHandle,
1366 IOCTL_AFS_PROCESS_IRP_RESULT,
1368 sizeof( AFSCommResult) + pResultCB->ResultBufferLength,
1373 char *pBuffer = (char *)wchBuffer;
1374 gle = GetLastError();
1375 if (afsd_logp->enabled) {
1376 swprintf( wchBuffer,
1377 L"Failed to post IOCTL_AFS_PROCESS_IRP_RESULT gle %X", gle);
1378 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1381 if (gle != ERROR_NOT_READY) {
1383 "Failed to post IOCTL_AFS_PROCESS_IRP_RESULT gle %X",
1385 osi_panic(pBuffer, __FILE__, __LINE__);
1390 else if (RequestBuffer->RequestType == AFS_REQUEST_TYPE_REQUEST_FILE_EXTENTS) {
1392 if (SetFileExtentsResultCB) {
1394 if (1 || afsd_logp->enabled) {
1395 if (SetFileExtentsResultCB->ResultStatus != 0)
1396 swprintf( wchBuffer,
1397 L"ProcessRequest Responding Asynchronously with FAILURE to REQUEST_FILE_EXTENTS Index %08lX Count %08lX Status %08lX",
1398 RequestBuffer->RequestIndex, SetFileExtentsResultCB->ExtentCount, SetFileExtentsResultCB->ResultStatus);
1400 swprintf( wchBuffer,
1401 L"ProcessRequest Responding Asynchronously with SUCCESS to REQUEST_FILE_EXTENTS Index %08lX Count %08lX",
1402 RequestBuffer->RequestIndex, SetFileExtentsResultCB->ExtentCount);
1404 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1407 if( (SetFileExtentsResultCB->ExtentCount != 0 ||
1408 SetFileExtentsResultCB->ResultStatus != 0) &&
1409 !RDR_DeviceIoControl( glDevHandle,
1410 IOCTL_AFS_SET_FILE_EXTENTS,
1411 (void *)SetFileExtentsResultCB,
1412 dwResultBufferLength,
1417 gle = GetLastError();
1418 if (afsd_logp->enabled) {
1419 swprintf( wchBuffer,
1420 L"Failed to post IOCTL_AFS_SET_FILE_EXTENTS gle %X",
1422 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1425 // The file system returns an error when it can't find the FID
1426 // This is a bug in the file system but we should try to avoid
1427 // the crash and clean up our own memory space.
1429 // Since we couldn't deliver the extents to the file system
1430 // we should release them.
1431 if ( SetFileExtentsResultCB->ExtentCount != 0)
1433 RDR_ReleaseFailedSetFileExtents( userp,
1434 SetFileExtentsResultCB,
1435 dwResultBufferLength);
1438 if (gle != ERROR_GEN_FAILURE &&
1439 gle != ERROR_NOT_READY) {
1441 "Failed to post IOCTL_AFS_SET_FILE_EXTENTS gle %X",
1443 osi_panic(pBuffer, __FILE__, __LINE__);
1447 free(SetFileExtentsResultCB);
1450 /* Must be out of memory */
1451 if (afsd_logp->enabled) {
1452 swprintf( wchBuffer,
1453 L"ProcessRequest Responding Asynchronously STATUS_NO_MEMORY to REQUEST_FILE_EXTENTS Index %08lX",
1454 RequestBuffer->RequestIndex);
1456 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1459 RDR_SetFileStatus2( &RequestBuffer->FileId, &RequestBuffer->AuthGroup, STATUS_NO_MEMORY);
1462 else if (RequestBuffer->RequestType == AFS_REQUEST_TYPE_BYTE_RANGE_LOCK) {
1464 if (afsd_logp->enabled) {
1465 swprintf( wchBuffer,
1466 L"ProcessRequest Responding Asynchronously to REQUEST_TYPE_BYTE_RANGELOCK Index %08lX",
1467 RequestBuffer->RequestIndex);
1469 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1473 if (SetByteRangeLockResultCB) {
1475 if( !RDR_DeviceIoControl( glDevHandle,
1476 IOCTL_AFS_SET_BYTE_RANGE_LOCKS,
1477 (void *)SetByteRangeLockResultCB,
1478 dwResultBufferLength,
1483 gle = GetLastError();
1485 if (afsd_logp->enabled) {
1486 swprintf( wchBuffer,
1487 L"Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle 0x%x", gle);
1488 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1492 if (gle != ERROR_NOT_READY) {
1493 // TODO - instead of a panic we should release the locks
1495 "Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle %X", gle);
1496 osi_panic(pBuffer, __FILE__, __LINE__);
1500 free(SetByteRangeLockResultCB);
1502 /* Must be out of memory */
1503 AFSSetByteRangeLockResultCB SetByteRangeLockResultCB;
1505 dwResultBufferLength = sizeof(AFSSetByteRangeLockResultCB);
1506 memset( &SetByteRangeLockResultCB, '\0', dwResultBufferLength );
1507 SetByteRangeLockResultCB.FileId = RequestBuffer->FileId;
1508 SetByteRangeLockResultCB.Result[0].Status = STATUS_NO_MEMORY;
1510 if( !RDR_DeviceIoControl( glDevHandle,
1511 IOCTL_AFS_SET_BYTE_RANGE_LOCKS,
1512 (void *)&SetByteRangeLockResultCB,
1513 dwResultBufferLength,
1518 gle = GetLastError();
1520 if (afsd_logp->enabled) {
1521 swprintf( wchBuffer,
1522 L"Failed to post IOCTL_AFS_SET_BYTE_RANGE_LOCKS gle 0x%x", gle);
1523 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1526 /* We were out of memory - nothing to do */
1532 if (afsd_logp->enabled) {
1533 swprintf( wchBuffer,
1534 L"ProcessRequest Not responding to async Index %08lX",
1535 RequestBuffer->RequestIndex);
1537 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1545 RDR_ReleaseUser(userp);
1548 if( pResultCB && pResultCB != &stResultCB)
1558 RDR_SetFileExtents( AFSSetFileExtentsCB *pSetFileExtentsResultCB,
1559 DWORD dwResultBufferLength)
1561 WCHAR wchBuffer[1024];
1562 DWORD bytesReturned;
1565 if (1 || afsd_logp->enabled) {
1566 if (pSetFileExtentsResultCB->ResultStatus != 0)
1567 swprintf( wchBuffer,
1568 L"RDR_SetFileExtents IOCTL_AFS_SET_FILE_EXTENTS FAILURE Count %08lX Status %08lX",
1569 pSetFileExtentsResultCB->ExtentCount, pSetFileExtentsResultCB->ResultStatus);
1571 swprintf( wchBuffer,
1572 L"RDR_SetFileExtents IOCTL_AFS_SET_FILE_EXTENTS SUCCESS Count %08lX",
1573 pSetFileExtentsResultCB->ExtentCount);
1575 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1578 if( !RDR_DeviceIoControl( glDevHandle,
1579 IOCTL_AFS_SET_FILE_EXTENTS,
1580 (void *)pSetFileExtentsResultCB,
1581 dwResultBufferLength,
1586 gle = GetLastError();
1595 RDR_SetFileStatus( cm_fid_t *fidp,
1599 WCHAR wchBuffer[1024];
1600 AFSExtentFailureCB SetFileStatusCB;
1601 DWORD bytesReturned;
1604 RDR_fid2FID(fidp, &SetFileStatusCB.FileId);
1605 memcpy(&SetFileStatusCB.AuthGroup, pAuthGroup, sizeof(GUID));
1606 SetFileStatusCB.FailureStatus = dwStatus;
1608 if (afsd_logp->enabled) {
1609 swprintf( wchBuffer, L"RDR_SetFileStatus IOCTL_AFS_EXTENT_FAILURE_CB Fid %08lX.%08lX.%08lX.%08lX Status 0x%lX",
1610 SetFileStatusCB.FileId.Cell, SetFileStatusCB.FileId.Volume,
1611 SetFileStatusCB.FileId.Vnode, SetFileStatusCB.FileId.Unique,
1614 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1617 if( !RDR_DeviceIoControl( glDevHandle,
1618 IOCTL_AFS_SET_FILE_EXTENT_FAILURE,
1619 (void *)&SetFileStatusCB,
1620 sizeof(AFSExtentFailureCB),
1625 gle = GetLastError();
1633 RDR_SetFileStatus2( AFSFileID *pFileId,
1637 WCHAR wchBuffer[1024];
1638 AFSExtentFailureCB SetFileStatusCB;
1639 DWORD bytesReturned;
1642 memcpy(&SetFileStatusCB.FileId, pFileId, sizeof(AFSFileID));
1643 memcpy(&SetFileStatusCB.AuthGroup, pAuthGroup, sizeof(GUID));
1644 SetFileStatusCB.FailureStatus = dwStatus;
1646 if (afsd_logp->enabled) {
1647 swprintf( wchBuffer, L"RDR_SetFileStatus2 IOCTL_AFS_EXTENT_FAILURE_CB Fid %08lX.%08lX.%08lX.%08lX Status 0x%lX",
1648 SetFileStatusCB.FileId.Cell, SetFileStatusCB.FileId.Volume,
1649 SetFileStatusCB.FileId.Vnode, SetFileStatusCB.FileId.Unique,
1652 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1655 if( !RDR_DeviceIoControl( glDevHandle,
1656 IOCTL_AFS_SET_FILE_EXTENT_FAILURE,
1657 (void *)&SetFileStatusCB,
1658 sizeof(AFSExtentFailureCB),
1663 gle = GetLastError();
1671 RDR_RequestExtentRelease(cm_fid_t *fidp, LARGE_INTEGER numOfHeldExtents, DWORD numOfExtents, AFSFileExtentCB *extentList)
1674 HANDLE hDevHandle = NULL;
1675 DWORD bytesReturned;
1676 AFSReleaseFileExtentsCB *requestBuffer = NULL;
1677 AFSReleaseFileExtentsResultCB *responseBuffer = NULL;
1678 DWORD requestBufferLen, responseBufferLen;
1679 bool bError = false;
1681 WCHAR wchBuffer[256];
1685 if (afsd_logp->enabled) {
1686 swprintf( wchBuffer,
1687 L"IOCTL_AFS_RELEASE_FILE_EXTENTS request ignored due to shutdown pending");
1689 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1692 OutputDebugString(L"RDR_RequestExtentRequest ignored - shutdown pending\n");
1693 return CM_ERROR_WOULDBLOCK;
1696 if (afsd_logp->enabled) {
1697 swprintf( wchBuffer,
1698 L"IOCTL_AFS_RELEASE_FILE_EXTENTS request - number %08lX",
1701 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1705 // We use the global handle to the control device instance
1708 hDevHandle = glDevHandle;
1711 // Allocate a request buffer.
1714 requestBufferLen = sizeof( AFSReleaseFileExtentsCB) + sizeof(AFSFileExtentCB) * numOfExtents;
1715 requestBuffer = (AFSReleaseFileExtentsCB *)malloc( requestBufferLen);
1716 responseBufferLen = (sizeof( AFSReleaseFileExtentsResultCB) + sizeof( AFSReleaseFileExtentsResultFileCB)) * numOfExtents;
1717 responseBuffer = (AFSReleaseFileExtentsResultCB *)malloc( responseBufferLen);
1720 if( requestBuffer && responseBuffer)
1723 memset( requestBuffer, '\0', sizeof( AFSReleaseFileExtentsCB));
1724 memset( responseBuffer, '\0', responseBufferLen);
1726 // If there is a FID provided, use it
1727 if (fidp && extentList)
1729 RDR_fid2FID( fidp, &requestBuffer->FileId);
1731 memcpy(&requestBuffer->FileExtents, extentList, numOfExtents * sizeof(AFSFileExtentCB));
1733 requestBuffer->Flags = 0;
1736 requestBuffer->Flags = AFS_RELEASE_EXTENTS_FLAGS_RELEASE_ALL;
1739 // Set the number of extents to be freed
1740 // Leave the rest of the structure as zeros to indicate free anything
1741 requestBuffer->ExtentCount = numOfExtents;
1743 requestBuffer->HeldExtentCount = numOfHeldExtents;
1745 if( !RDR_DeviceIoControl( hDevHandle,
1746 IOCTL_AFS_RELEASE_FILE_EXTENTS,
1747 (void *)requestBuffer,
1749 (void *)responseBuffer,
1754 // Error condition back from driver
1756 if (afsd_logp->enabled) {
1757 gle = GetLastError();
1758 swprintf( wchBuffer,
1759 L"Failed to post IOCTL_AFS_RELEASE_FILE_EXTENTS - gle 0x%x", gle);
1760 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1767 // Go process the request
1770 if (afsd_logp->enabled) {
1771 swprintf( wchBuffer,
1772 L"IOCTL_AFS_RELEASE_FILE_EXTENTS returns - serial number %08lX flags %lX FileCount %lX",
1773 responseBuffer->SerialNumber, responseBuffer->Flags, responseBuffer->FileCount);
1774 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1777 rc = RDR_ProcessReleaseFileExtentsResult( responseBuffer, bytesReturned);
1785 free( requestBuffer);
1787 free( responseBuffer);
1794 RDR_NetworkStatus(BOOLEAN status)
1797 HANDLE hDevHandle = NULL;
1798 DWORD bytesReturned;
1799 AFSNetworkStatusCB *requestBuffer = NULL;
1801 WCHAR wchBuffer[256];
1804 if (afsd_logp->enabled) {
1805 swprintf( wchBuffer,
1806 L"IOCTL_AFS_NETWORK_STATUS request - status %d",
1809 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1813 // We use the global handle to the control device instance
1816 hDevHandle = glDevHandle;
1819 // Allocate a request buffer.
1822 requestBuffer = (AFSNetworkStatusCB *)malloc( sizeof( AFSNetworkStatusCB));
1828 memset( requestBuffer, '\0', sizeof( AFSNetworkStatusCB));
1830 // Set the number of extents to be freed
1831 // Leave the rest of the structure as zeros to indicate free anything
1832 requestBuffer->Online = status;
1834 if( !RDR_DeviceIoControl( hDevHandle,
1835 IOCTL_AFS_NETWORK_STATUS,
1836 (void *)requestBuffer,
1837 sizeof( AFSNetworkStatusCB),
1843 // Error condition back from driver
1845 if (afsd_logp->enabled) {
1846 gle = GetLastError();
1847 swprintf( wchBuffer,
1848 L"Failed to post IOCTL_AFS_NETWORK_STATUS gle 0x%x",
1850 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1861 free( requestBuffer);
1869 RDR_VolumeStatus(ULONG cellID, ULONG volID, BOOLEAN online)
1872 HANDLE hDevHandle = NULL;
1873 DWORD bytesReturned;
1874 AFSVolumeStatusCB *requestBuffer = NULL;
1876 WCHAR wchBuffer[256];
1879 if (afsd_logp->enabled) {
1880 swprintf( wchBuffer,
1881 L"IOCTL_AFS_VOLUME_STATUS request - cell 0x%x vol 0x%x online %d",
1882 cellID, volID, online);
1884 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1888 // We use the global handle to the control device instance
1891 hDevHandle = glDevHandle;
1894 // Allocate a request buffer.
1897 requestBuffer = (AFSVolumeStatusCB *)malloc( sizeof( AFSVolumeStatusCB));
1903 memset( requestBuffer, '\0', sizeof( AFSVolumeStatusCB));
1905 requestBuffer->FileID.Cell = cellID;
1906 requestBuffer->FileID.Volume = volID;
1907 requestBuffer->Online = online;
1909 if( !RDR_DeviceIoControl( hDevHandle,
1910 IOCTL_AFS_VOLUME_STATUS,
1911 (void *)requestBuffer,
1912 sizeof( AFSVolumeStatusCB),
1918 // Error condition back from driver
1921 if (afsd_logp->enabled) {
1922 gle = GetLastError();
1923 swprintf( wchBuffer,
1924 L"Failed to post IOCTL_AFS_VOLUME_STATUS gle 0x%x", gle);
1925 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1936 free( requestBuffer);
1942 RDR_NetworkAddrChange(void)
1949 RDR_InvalidateVolume(ULONG cellID, ULONG volID, ULONG reason)
1952 HANDLE hDevHandle = NULL;
1953 DWORD bytesReturned;
1954 AFSInvalidateCacheCB *requestBuffer = NULL;
1956 WCHAR wchBuffer[256];
1959 if (afsd_logp->enabled) {
1960 swprintf( wchBuffer,
1961 L"IOCTL_AFS_INVALIDATE_CACHE (vol) request - cell 0x%x vol 0x%x reason %d",
1962 cellID, volID, reason);
1964 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
1968 // We use the global handle to the control device instance
1971 hDevHandle = glDevHandle;
1974 // Allocate a request buffer.
1977 requestBuffer = (AFSInvalidateCacheCB *)malloc( sizeof( AFSInvalidateCacheCB));
1983 memset( requestBuffer, '\0', sizeof( AFSInvalidateCacheCB));
1985 requestBuffer->FileID.Cell = cellID;
1986 requestBuffer->FileID.Volume = volID;
1987 requestBuffer->WholeVolume = TRUE;
1988 requestBuffer->Reason = reason;
1990 if( !RDR_DeviceIoControl( hDevHandle,
1991 IOCTL_AFS_INVALIDATE_CACHE,
1992 (void *)requestBuffer,
1993 sizeof( AFSInvalidateCacheCB),
1999 // Error condition back from driver
2002 if (afsd_logp->enabled) {
2003 gle = GetLastError();
2004 swprintf( wchBuffer,
2005 L"Failed to post IOCTL_AFS_INVALIDATE_VOLUME gle 0x%x", gle);
2006 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2017 free( requestBuffer);
2024 RDR_InvalidateObject(ULONG cellID, ULONG volID, ULONG vnode, ULONG uniq, ULONG hash, ULONG fileType, ULONG reason)
2027 HANDLE hDevHandle = NULL;
2028 DWORD bytesReturned;
2029 AFSInvalidateCacheCB *requestBuffer = NULL;
2031 WCHAR wchBuffer[256];
2034 if (afsd_logp->enabled) {
2035 swprintf( wchBuffer,
2036 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",
2037 cellID, volID, vnode, uniq, hash, fileType, reason);
2039 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2043 // We use the global handle to the control device instance
2046 hDevHandle = glDevHandle;
2049 // Allocate a request buffer.
2052 requestBuffer = (AFSInvalidateCacheCB *)malloc( sizeof( AFSInvalidateCacheCB));
2058 memset( requestBuffer, '\0', sizeof( AFSInvalidateCacheCB));
2060 requestBuffer->FileID.Cell = cellID;
2061 requestBuffer->FileID.Volume = volID;
2062 requestBuffer->FileID.Vnode = vnode;
2063 requestBuffer->FileID.Unique = uniq;
2064 requestBuffer->FileID.Hash = hash;
2065 requestBuffer->FileType = fileType;
2066 requestBuffer->WholeVolume = FALSE;
2067 requestBuffer->Reason = reason;
2069 if( !RDR_DeviceIoControl( hDevHandle,
2070 IOCTL_AFS_INVALIDATE_CACHE,
2071 (void *)requestBuffer,
2072 sizeof( AFSInvalidateCacheCB),
2078 // Error condition back from driver
2080 if (afsd_logp->enabled) {
2081 gle = GetLastError();
2082 swprintf( wchBuffer,
2083 L"Failed to post IOCTL_AFS_INVALIDATE_CACHE gle 0x%x", gle);
2084 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2095 free( requestBuffer);
2103 RDR_SysName(ULONG Architecture, ULONG Count, WCHAR **NameList)
2106 HANDLE hDevHandle = NULL;
2107 DWORD bytesReturned;
2108 AFSSysNameNotificationCB *requestBuffer = NULL;
2110 WCHAR wchBuffer[256];
2114 if (afsd_logp->enabled) {
2115 swprintf( wchBuffer,
2116 L"IOCTL_AFS_SYSNAME_NOTIFICATION request - Arch %d Count %d",
2117 Architecture, Count);
2119 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2122 if (Count <= 0 || NameList == NULL)
2126 // We use the global handle to the control device instance
2129 hDevHandle = glDevHandle;
2132 // Allocate a request buffer.
2135 Length = sizeof (AFSSysNameNotificationCB) + (Count - 1) * sizeof (AFSSysName);
2136 requestBuffer = (AFSSysNameNotificationCB *)malloc( Length );
2143 memset( requestBuffer, '\0', Length);
2145 requestBuffer->Architecture = Architecture;
2146 requestBuffer->NumberOfNames = Count;
2147 for ( i=0 ; i<Count; i++) {
2148 size_t len = wcslen(NameList[i]);
2149 requestBuffer->SysNames[i].Length = (ULONG) (len * sizeof(WCHAR));
2150 StringCchCopyNW(requestBuffer->SysNames[i].String, AFS_MAX_SYSNAME_LENGTH,
2154 if( !RDR_DeviceIoControl( hDevHandle,
2155 IOCTL_AFS_SYSNAME_NOTIFICATION,
2156 (void *)requestBuffer,
2163 // Error condition back from driver
2165 if (afsd_logp->enabled) {
2166 gle = GetLastError();
2167 swprintf( wchBuffer,
2168 L"Failed to post IOCTL_AFS_SYSNAME_NOTIFICATION gle 0x%x", gle);
2169 osi_Log1(afsd_logp, "%S", osi_LogSaveStringW(afsd_logp, wchBuffer));
2180 free( requestBuffer);
2188 ResetEvent( RDR_SuspendEvent);
2194 SetEvent( RDR_SuspendEvent);