VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/SharedFolders/driver/Win2kWorkarounds.c@ 50035

Last change on this file since 50035 was 42302, checked in by vboxsync, 13 years ago

VBoxSF: Windows 2000 hacks. Using the W2K3 libs works, XP libs doesn't.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.0 KB
Line 
1/* $Id: Win2kWorkarounds.c 42302 2012-07-22 01:26:51Z vboxsync $ */
2/** @file
3 * VirtualBox Windows Guest Shared Folders - Windows 2000 Hacks.
4 */
5
6/*
7 * Copyright (C) 2012 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18
19/*******************************************************************************
20* Header Files *
21*******************************************************************************/
22#define FsRtlTeardownPerStreamContexts FsRtlTeardownPerStreamContexts_AvoidIt
23#define RtlGetVersion RtlGetVersion_AvoidIt
24#define PsGetProcessImageFileName PsGetProcessImageFileName_AvoidIt
25#include "vbsf.h"
26
27#include <iprt/asm.h>
28
29
30#if 0
31/*
32 * FsRtlTeardownPerStreamContexts.
33 */
34static VOID __stdcall Resolve_FsRtlTeardownPerStreamContexts(PFSRTL_ADVANCED_FCB_HEADER);
35static volatile PFN_FSRTLTEARDOWNPERSTREAMCONTEXTS g_pfnFsRtlTeardownPerStreamContexts = Resolve_FsRtlTeardownPerStreamContexts;
36
37
38static VOID __stdcall Fake_FsRtlTeardownPerStreamContexts(PFSRTL_ADVANCED_FCB_HEADER pAdvancedHeader)
39{
40 PLIST_ENTRY pCur;
41
42 ExAcquireFastMutex(pAdvancedHeader->FastMutex);
43
44 pCur = pAdvancedHeader->FilterContexts.Flink;
45 while (pCur != &pAdvancedHeader->FilterContexts)
46 {
47 PLIST_ENTRY pNext = pCur->Flink;
48 PFSRTL_PER_STREAM_CONTEXT pCtx = CONTAINING_RECORD(pCur, FSRTL_PER_STREAM_CONTEXT, Links);
49 Log(("Fake_FsRtlTeardownPerStreamContexts: %p\n", pCtx));
50 pCtx->FreeCallback(pCtx);
51 pCur = pNext;
52 }
53 InitializeListHead(&pAdvancedHeader->FilterContexts);
54
55 ExReleaseFastMutex(pAdvancedHeader->FastMutex);
56 return;
57}
58
59
60static VOID __stdcall Resolve_FsRtlTeardownPerStreamContexts(PFSRTL_ADVANCED_FCB_HEADER pAdvancedHeader)
61{
62 UNICODE_STRING RoutineName;
63 PFN_FSRTLTEARDOWNPERSTREAMCONTEXTS pfn;
64 Log(("Resolve_FsRtlTeardownPerStreamContexts: %p\n", pAdvancedHeader));
65
66 RtlInitUnicodeString(&RoutineName, L"KeIpiGenericCall");
67 pfn = (PFN_FSRTLTEARDOWNPERSTREAMCONTEXTS)MmGetSystemRoutineAddress(&RoutineName);
68 if (!pfn)
69 pfn = Fake_FsRtlTeardownPerStreamContexts;
70 ASMAtomicWritePtr(&g_pfnFsRtlTeardownPerStreamContexts, pfn);
71 pfn(pAdvancedHeader);
72}
73
74
75#undef FsRtlTeardownPerStreamContexts
76__declspec(dllexport) VOID
77FsRtlTeardownPerStreamContexts(PFSRTL_ADVANCED_FCB_HEADER pAdvancedHeader)
78{
79 Log(("FsRtlTeardownPerStreamContexts: %p\n", pAdvancedHeader));
80 g_pfnFsRtlTeardownPerStreamContexts(pAdvancedHeader);
81 Log(("FsRtlTeardownPerStreamContexts: returns\n"));
82}
83#endif
84
85
86/*
87 * RtlGetVersion
88 */
89typedef NTSTATUS (__stdcall * PFNRTLGETVERSION)(PRTL_OSVERSIONINFOW);
90static NTSTATUS __stdcall Resolve_RtlGetVersion(PRTL_OSVERSIONINFOW pVerInfo);
91static volatile PFNRTLGETVERSION g_pfnRtlGetVersion = Resolve_RtlGetVersion;
92
93
94static NTSTATUS __stdcall Fake_RtlGetVersion(PRTL_OSVERSIONINFOW pVerInfo)
95{
96 Log(("Fake_RtlGetVersion: %p\n", pVerInfo));
97 if (pVerInfo->dwOSVersionInfoSize < sizeof(*pVerInfo))
98 {
99 Log(("Fake_RtlGetVersion: -> STATUS_INVALID_PARAMETER (size = %#x)\n", pVerInfo->dwOSVersionInfoSize));
100 return STATUS_INVALID_PARAMETER;
101 }
102
103 /* Report Windows 2000 w/o SP. */
104 pVerInfo->dwMajorVersion = 5;
105 pVerInfo->dwMinorVersion = 0;
106 pVerInfo->dwBuildNumber = 2195;
107 pVerInfo->dwPlatformId = VER_PLATFORM_WIN32_NT;
108 pVerInfo->szCSDVersion[0] = '\0';
109
110 if (pVerInfo->dwOSVersionInfoSize >= sizeof(RTL_OSVERSIONINFOEXW))
111 {
112 PRTL_OSVERSIONINFOEXW pVerInfoEx = (PRTL_OSVERSIONINFOEXW)pVerInfo;
113 pVerInfoEx->wServicePackMajor = 0;
114 pVerInfoEx->wServicePackMinor = 0;
115 pVerInfoEx->wSuiteMask = 0;
116 pVerInfoEx->wProductType = VER_NT_WORKSTATION;
117 pVerInfoEx->wReserved = 0;
118 }
119
120 return STATUS_SUCCESS;
121}
122
123
124static NTSTATUS __stdcall Resolve_RtlGetVersion(PRTL_OSVERSIONINFOW pVerInfo)
125{
126 UNICODE_STRING RoutineName;
127 PFNRTLGETVERSION pfn;
128 Log(("Resolve_RtlGetVersion: %p\n", pVerInfo));
129
130 RtlInitUnicodeString(&RoutineName, L"RtlGetVersion");
131 pfn = (PFNRTLGETVERSION)MmGetSystemRoutineAddress(&RoutineName);
132 if (!pfn)
133 pfn = Fake_RtlGetVersion;
134 ASMAtomicWritePtr(&g_pfnRtlGetVersion, pfn);
135
136 return pfn(pVerInfo);
137}
138
139
140#undef RtlGetVersion
141__declspec(dllexport) NTSTATUS __stdcall
142RtlGetVersion(PRTL_OSVERSIONINFOW pVerInfo)
143{
144 return g_pfnRtlGetVersion(pVerInfo);
145}
146
147
148/*
149 * PsGetProcessImageFileName
150 */
151
152typedef LPSTR (__stdcall * PFNPSGETPROCESSIMAGEFILENAME)(PEPROCESS pProcess);
153static LPSTR __stdcall Resolve_PsGetProcessImageFileName(PEPROCESS pProcess);
154static volatile PFNPSGETPROCESSIMAGEFILENAME g_pfnPsGetProcessImageFileName = Resolve_PsGetProcessImageFileName;
155
156
157static LPSTR __stdcall Fake_PsGetProcessImageFileName(PEPROCESS pProcess)
158{
159 Log(("Fake_PsGetProcessImageFileName: %p\n", pProcess));
160 return "Fake_PsGetProcessImageFileName";
161}
162
163
164static LPSTR __stdcall Resolve_PsGetProcessImageFileName(PEPROCESS pProcess)
165{
166 UNICODE_STRING RoutineName;
167 PFNPSGETPROCESSIMAGEFILENAME pfn;
168 Log(("Resolve_PsGetProcessImageFileName: %p\n", pProcess));
169
170 RtlInitUnicodeString(&RoutineName, L"PsGetProcessImageFileName");
171 pfn = (PFNPSGETPROCESSIMAGEFILENAME)MmGetSystemRoutineAddress(&RoutineName);
172 if (!pfn)
173 pfn = Fake_PsGetProcessImageFileName;
174 ASMAtomicWritePtr(&g_pfnPsGetProcessImageFileName, pfn);
175
176 return pfn(pProcess);
177}
178
179
180#undef PsGetProcessImageFileName
181__declspec(dllexport) LPSTR __stdcall
182PsGetProcessImageFileName(PEPROCESS pProcess)
183{
184 return g_pfnPsGetProcessImageFileName(pProcess);
185}
186
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette