Alexandre Julliard : mountmgr.sys: Added initial stub for the mount point manager device.

Alexandre Julliard julliard at winehq.org
Fri Jan 4 07:12:48 CST 2008


Module: wine
Branch: master
Commit: 43dc80e623d00781c726892ef0eddce7b03c9db7
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=43dc80e623d00781c726892ef0eddce7b03c9db7

Author: Alexandre Julliard <julliard at winehq.org>
Date:   Fri Jan  4 13:07:05 2008 +0100

mountmgr.sys: Added initial stub for the mount point manager device.

---

 Makefile.in                         |    2 +
 configure                           |    3 +
 configure.ac                        |    1 +
 dlls/Makefile.in                    |    1 +
 dlls/mountmgr.sys/Makefile.in       |   14 ++++++
 dlls/mountmgr.sys/mountmgr.c        |   86 +++++++++++++++++++++++++++++++++++
 dlls/mountmgr.sys/mountmgr.sys.spec |    1 +
 7 files changed, 108 insertions(+), 0 deletions(-)

diff --git a/Makefile.in b/Makefile.in
index fc4d43a..5be823d 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -288,6 +288,7 @@ ALL_MAKEFILES = \
 	dlls/mlang/tests/Makefile \
 	dlls/mmdevldr.vxd/Makefile \
 	dlls/monodebg.vxd/Makefile \
+	dlls/mountmgr.sys/Makefile \
 	dlls/mpr/Makefile \
 	dlls/mprapi/Makefile \
 	dlls/msacm32.drv/Makefile \
@@ -672,6 +673,7 @@ dlls/mlang/Makefile: dlls/mlang/Makefile.in dlls/Makedll.rules
 dlls/mlang/tests/Makefile: dlls/mlang/tests/Makefile.in dlls/Maketest.rules
 dlls/mmdevldr.vxd/Makefile: dlls/mmdevldr.vxd/Makefile.in dlls/Makedll.rules
 dlls/monodebg.vxd/Makefile: dlls/monodebg.vxd/Makefile.in dlls/Makedll.rules
+dlls/mountmgr.sys/Makefile: dlls/mountmgr.sys/Makefile.in dlls/Makedll.rules
 dlls/mpr/Makefile: dlls/mpr/Makefile.in dlls/Makedll.rules
 dlls/mprapi/Makefile: dlls/mprapi/Makefile.in dlls/Makedll.rules
 dlls/msacm32.drv/Makefile: dlls/msacm32.drv/Makefile.in dlls/Makedll.rules
diff --git a/configure b/configure
index 3b59e50..0c99eae 100755
--- a/configure
+++ b/configure
@@ -20868,6 +20868,8 @@ ac_config_files="$ac_config_files dlls/mmdevldr.vxd/Makefile"
 
 ac_config_files="$ac_config_files dlls/monodebg.vxd/Makefile"
 
+ac_config_files="$ac_config_files dlls/mountmgr.sys/Makefile"
+
 ac_config_files="$ac_config_files dlls/mpr/Makefile"
 
 ac_config_files="$ac_config_files dlls/mprapi/Makefile"
@@ -22042,6 +22044,7 @@ do
     "dlls/mlang/tests/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/mlang/tests/Makefile" ;;
     "dlls/mmdevldr.vxd/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/mmdevldr.vxd/Makefile" ;;
     "dlls/monodebg.vxd/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/monodebg.vxd/Makefile" ;;
+    "dlls/mountmgr.sys/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/mountmgr.sys/Makefile" ;;
     "dlls/mpr/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/mpr/Makefile" ;;
     "dlls/mprapi/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/mprapi/Makefile" ;;
     "dlls/msacm32.drv/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/msacm32.drv/Makefile" ;;
diff --git a/configure.ac b/configure.ac
index 3ca94d4..4694904 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1714,6 +1714,7 @@ AC_CONFIG_FILES([dlls/mlang/Makefile])
 AC_CONFIG_FILES([dlls/mlang/tests/Makefile])
 AC_CONFIG_FILES([dlls/mmdevldr.vxd/Makefile])
 AC_CONFIG_FILES([dlls/monodebg.vxd/Makefile])
+AC_CONFIG_FILES([dlls/mountmgr.sys/Makefile])
 AC_CONFIG_FILES([dlls/mpr/Makefile])
 AC_CONFIG_FILES([dlls/mprapi/Makefile])
 AC_CONFIG_FILES([dlls/msacm32.drv/Makefile])
diff --git a/dlls/Makefile.in b/dlls/Makefile.in
index cfb3247..907bceb 100644
--- a/dlls/Makefile.in
+++ b/dlls/Makefile.in
@@ -110,6 +110,7 @@ BASEDIRS = \
 	mlang \
 	mmdevldr.vxd \
 	monodebg.vxd \
+	mountmgr.sys \
 	mpr \
 	mprapi \
 	msacm32 \
diff --git a/dlls/mountmgr.sys/Makefile.in b/dlls/mountmgr.sys/Makefile.in
new file mode 100644
index 0000000..f73e4d4
--- /dev/null
+++ b/dlls/mountmgr.sys/Makefile.in
@@ -0,0 +1,14 @@
+TOPSRCDIR = @top_srcdir@
+TOPOBJDIR = ../..
+SRCDIR    = @srcdir@
+VPATH     = @srcdir@
+MODULE    = mountmgr.sys
+IMPORTS   = advapi32 ntoskrnl.exe kernel32 ntdll
+EXTRADLLFLAGS = -Wb,--subsystem,native
+
+C_SRCS = \
+	mountmgr.c
+
+ at MAKE_DLL_RULES@
+
+ at DEPENDENCIES@  # everything below this line is overwritten by make depend
diff --git a/dlls/mountmgr.sys/mountmgr.c b/dlls/mountmgr.sys/mountmgr.c
new file mode 100644
index 0000000..3bc9534
--- /dev/null
+++ b/dlls/mountmgr.sys/mountmgr.c
@@ -0,0 +1,86 @@
+/*
+ * Mount manager service implementation
+ *
+ * Copyright 2008 Alexandre Julliard
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <stdarg.h>
+#include <unistd.h>
+
+#define NONAMELESSUNION
+#define NONAMELESSSTRUCT
+
+#include "ntstatus.h"
+#define WIN32_NO_STATUS
+#include "windef.h"
+#include "winbase.h"
+#include "winternl.h"
+#include "winioctl.h"
+#include "ddk/wdm.h"
+#include "ddk/mountmgr.h"
+#include "wine/library.h"
+#include "wine/unicode.h"
+#include "wine/debug.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(mountmgr);
+
+/* handler for ioctls on the mount manager device */
+static NTSTATUS WINAPI mountmgr_ioctl( DEVICE_OBJECT *device, IRP *irp )
+{
+    IO_STACK_LOCATION *irpsp = irp->Tail.Overlay.s.u.CurrentStackLocation;
+
+    TRACE( "ioctl %x insize %u outsize %u\n",
+           irpsp->Parameters.DeviceIoControl.IoControlCode,
+           irpsp->Parameters.DeviceIoControl.InputBufferLength,
+           irpsp->Parameters.DeviceIoControl.OutputBufferLength );
+
+    switch(irpsp->Parameters.DeviceIoControl.IoControlCode)
+    {
+    default:
+        FIXME( "ioctl %x not supported\n", irpsp->Parameters.DeviceIoControl.IoControlCode );
+        irp->IoStatus.u.Status = STATUS_NOT_SUPPORTED;
+        break;
+    }
+    return irp->IoStatus.u.Status;
+}
+
+/* main entry point for the mount point manager driver */
+NTSTATUS WINAPI DriverEntry( DRIVER_OBJECT *driver, UNICODE_STRING *path )
+{
+    static const WCHAR device_mountmgrW[] = {'\\','D','e','v','i','c','e','\\','M','o','u','n','t','P','o','i','n','t','M','a','n','a','g','e','r',0};
+    static const WCHAR link_mountmgrW[] = {'\\','?','?','\\','M','o','u','n','t','P','o','i','n','t','M','a','n','a','g','e','r',0};
+
+    UNICODE_STRING nameW, linkW;
+    DEVICE_OBJECT *device;
+    NTSTATUS status;
+
+    TRACE( "%s\n", debugstr_w(path->Buffer) );
+
+    driver->MajorFunction[IRP_MJ_DEVICE_CONTROL] = mountmgr_ioctl;
+
+    RtlInitUnicodeString( &nameW, device_mountmgrW );
+    RtlInitUnicodeString( &linkW, link_mountmgrW );
+    if (!(status = IoCreateDevice( driver, 0, &nameW, 0, 0, FALSE, &device )))
+        status = IoCreateSymbolicLink( &linkW, &nameW );
+    if (status)
+    {
+        FIXME( "failed to create device error %x\n", status );
+        return status;
+    }
+
+    return status;
+}
diff --git a/dlls/mountmgr.sys/mountmgr.sys.spec b/dlls/mountmgr.sys/mountmgr.sys.spec
new file mode 100644
index 0000000..76421d7
--- /dev/null
+++ b/dlls/mountmgr.sys/mountmgr.sys.spec
@@ -0,0 +1 @@
+# nothing to export




More information about the wine-cvs mailing list