Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
95615a4a
Commit
95615a4a
authored
Nov 26, 2021
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mountmgr: Move the DBus support to the Unix library.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
c210a0e6
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
237 additions
and
70 deletions
+237
-70
dbus.c
dlls/mountmgr.sys/dbus.c
+64
-68
mountmgr.c
dlls/mountmgr.sys/mountmgr.c
+49
-1
mountmgr.h
dlls/mountmgr.sys/mountmgr.h
+2
-1
unixlib.c
dlls/mountmgr.sys/unixlib.c
+67
-0
unixlib.h
dlls/mountmgr.sys/unixlib.h
+55
-0
No files found.
dlls/mountmgr.sys/dbus.c
View file @
95615a4a
...
@@ -18,27 +18,29 @@
...
@@ -18,27 +18,29 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
*/
#if 0
#pragma makedep unix
#endif
#include "config.h"
#include "config.h"
#include "wine/port.h"
#include <assert.h>
#include <errno.h>
#include <errno.h>
#include <stdarg.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdio.h>
#include <dlfcn.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#ifdef SONAME_LIBDBUS_1
#ifdef SONAME_LIBDBUS_1
# include <dbus/dbus.h>
# include <dbus/dbus.h>
#endif
#endif
#include "mountmgr.h"
#include "mountmgr.h"
#include "winnls.h"
#include "excpt.h"
#define USE_WS_PREFIX
#define USE_WS_PREFIX
#include "winsock2.h"
#include "winsock2.h"
#include "ws2ipdef.h"
#include "ip2string.h"
#include "dhcpcsdk.h"
#include "dhcpcsdk.h"
#include "unixlib.h"
#include "wine/exception.h"
#include "wine/debug.h"
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
mountmgr
);
WINE_DEFAULT_DEBUG_CHANNEL
(
mountmgr
);
...
@@ -82,13 +84,6 @@ DBUS_FUNCS;
...
@@ -82,13 +84,6 @@ DBUS_FUNCS;
static
int
udisks_timeout
=
-
1
;
static
int
udisks_timeout
=
-
1
;
static
DBusConnection
*
connection
;
static
DBusConnection
*
connection
;
static
LONG
WINAPI
assert_fault
(
EXCEPTION_POINTERS
*
eptr
)
{
if
(
eptr
->
ExceptionRecord
->
ExceptionCode
==
EXCEPTION_WINE_ASSERTION
)
return
EXCEPTION_EXECUTE_HANDLER
;
return
EXCEPTION_CONTINUE_SEARCH
;
}
static
inline
int
starts_with
(
const
char
*
str
,
const
char
*
prefix
)
static
inline
int
starts_with
(
const
char
*
str
,
const
char
*
prefix
)
{
{
return
!
strncmp
(
str
,
prefix
,
strlen
(
prefix
)
);
return
!
strncmp
(
str
,
prefix
,
strlen
(
prefix
)
);
...
@@ -97,19 +92,32 @@ static inline int starts_with( const char *str, const char *prefix )
...
@@ -97,19 +92,32 @@ static inline int starts_with( const char *str, const char *prefix )
static
GUID
*
parse_uuid
(
GUID
*
guid
,
const
char
*
str
)
static
GUID
*
parse_uuid
(
GUID
*
guid
,
const
char
*
str
)
{
{
/* standard uuid format */
/* standard uuid format */
if
(
strlen
(
str
)
==
36
)
if
(
strlen
(
str
)
==
36
&&
str
[
8
]
==
'-'
&&
str
[
13
]
==
'-'
&&
str
[
18
]
==
'-'
&&
str
[
23
]
==
'-'
)
{
{
UNICODE_STRING
strW
;
int
i
;
WCHAR
buffer
[
39
]
;
unsigned
char
*
out
=
guid
->
Data4
;
if
(
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
str
,
36
,
buffer
+
1
,
36
))
if
(
sscanf
(
str
,
"%x-%hx-%hx-"
,
&
guid
->
Data1
,
&
guid
->
Data2
,
&
guid
->
Data3
)
!=
3
)
return
NULL
;
for
(
i
=
19
;
i
<
36
;
i
++
)
{
{
buffer
[
0
]
=
'{'
;
unsigned
char
val
;
buffer
[
37
]
=
'}'
;
buffer
[
38
]
=
0
;
if
(
i
==
23
)
continue
;
RtlInitUnicodeString
(
&
strW
,
buffer
);
if
(
!
RtlGUIDFromString
(
&
strW
,
guid
))
return
guid
;
if
(
str
[
i
]
>=
'0'
&&
str
[
i
]
<=
'9'
)
val
=
str
[
i
]
-
'0'
;
else
if
(
str
[
i
]
>=
'a'
&&
str
[
i
]
<=
'f'
)
val
=
str
[
i
]
-
'a'
+
10
;
else
if
(
str
[
i
]
>=
'A'
&&
str
[
i
]
<=
'F'
)
val
=
str
[
i
]
-
'A'
+
10
;
else
return
NULL
;
val
<<=
4
;
i
++
;
if
(
str
[
i
]
>=
'0'
&&
str
[
i
]
<=
'9'
)
val
+=
str
[
i
]
-
'0'
;
else
if
(
str
[
i
]
>=
'a'
&&
str
[
i
]
<=
'f'
)
val
+=
str
[
i
]
-
'a'
+
10
;
else
if
(
str
[
i
]
>=
'A'
&&
str
[
i
]
<=
'F'
)
val
+=
str
[
i
]
-
'A'
+
10
;
else
return
NULL
;
*
out
++
=
val
;
}
}
return
guid
;
}
}
/* check for xxxx-xxxx format (FAT serial number) */
/* check for xxxx-xxxx format (FAT serial number) */
...
@@ -257,8 +265,8 @@ static void udisks_new_device( const char *udi )
...
@@ -257,8 +265,8 @@ static void udisks_new_device( const char *udi )
if
(
device
)
if
(
device
)
{
{
if
(
removable
)
add_dos_device
(
-
1
,
udi
,
device
,
mount_point
,
drive_type
,
guid_ptr
,
NULL
);
if
(
removable
)
queue_device_op
(
ADD_DOS_DEVICE
,
udi
,
device
,
mount_point
,
drive_type
,
guid_ptr
,
NULL
,
NULL
);
else
if
(
guid_ptr
)
add_volume
(
udi
,
device
,
mount_point
,
DEVICE_HARDDISK_VOL
,
guid_ptr
,
NULL
,
NULL
);
else
if
(
guid_ptr
)
queue_device_op
(
ADD_VOLUME
,
udi
,
device
,
mount_point
,
DEVICE_HARDDISK_VOL
,
guid_ptr
,
NULL
,
NULL
);
}
}
p_dbus_message_unref
(
reply
);
p_dbus_message_unref
(
reply
);
...
@@ -268,8 +276,7 @@ static void udisks_new_device( const char *udi )
...
@@ -268,8 +276,7 @@ static void udisks_new_device( const char *udi )
static
void
udisks_removed_device
(
const
char
*
udi
)
static
void
udisks_removed_device
(
const
char
*
udi
)
{
{
TRACE
(
"removed %s
\n
"
,
wine_dbgstr_a
(
udi
)
);
TRACE
(
"removed %s
\n
"
,
wine_dbgstr_a
(
udi
)
);
queue_device_op
(
REMOVE_DEVICE
,
udi
,
NULL
,
NULL
,
0
,
NULL
,
NULL
,
NULL
);
if
(
!
remove_dos_device
(
-
1
,
udi
))
remove_volume
(
udi
);
}
}
/* UDisks callback for changed device */
/* UDisks callback for changed device */
...
@@ -426,8 +433,8 @@ static void udisks2_add_device( const char *udi, DBusMessageIter *dict, DBusMess
...
@@ -426,8 +433,8 @@ static void udisks2_add_device( const char *udi, DBusMessageIter *dict, DBusMess
}
}
if
(
device
)
if
(
device
)
{
{
if
(
removable
)
add_dos_device
(
-
1
,
udi
,
device
,
mount_point
,
drive_type
,
guid_ptr
,
NULL
);
if
(
removable
)
queue_device_op
(
ADD_DOS_DEVICE
,
udi
,
device
,
mount_point
,
drive_type
,
guid_ptr
,
id
,
NULL
);
else
if
(
guid_ptr
)
add_volume
(
udi
,
device
,
mount_point
,
DEVICE_HARDDISK_VOL
,
guid_ptr
,
id
,
NULL
);
else
if
(
guid_ptr
)
queue_device_op
(
ADD_VOLUME
,
udi
,
device
,
mount_point
,
DEVICE_HARDDISK_VOL
,
guid_ptr
,
id
,
NULL
);
}
}
}
}
...
@@ -522,7 +529,7 @@ static DBusHandlerResult udisks_filter( DBusConnection *ctx, DBusMessage *msg, v
...
@@ -522,7 +529,7 @@ static DBusHandlerResult udisks_filter( DBusConnection *ctx, DBusMessage *msg, v
return
DBUS_HANDLER_RESULT_NOT_YET_HANDLED
;
return
DBUS_HANDLER_RESULT_NOT_YET_HANDLED
;
}
}
static
DWORD
WINAPI
dbus_thread
(
void
*
arg
)
void
run_dbus_loop
(
void
)
{
{
static
const
char
udisks_match
[]
=
"type='signal',"
static
const
char
udisks_match
[]
=
"type='signal',"
"interface='org.freedesktop.UDisks',"
"interface='org.freedesktop.UDisks',"
...
@@ -536,12 +543,14 @@ static DWORD WINAPI dbus_thread( void *arg )
...
@@ -536,12 +543,14 @@ static DWORD WINAPI dbus_thread( void *arg )
DBusError
error
;
DBusError
error
;
if
(
!
load_dbus_functions
())
return
;
p_dbus_error_init
(
&
error
);
p_dbus_error_init
(
&
error
);
if
(
!
(
connection
=
p_dbus_bus_get
(
DBUS_BUS_SYSTEM
,
&
error
)))
if
(
!
(
connection
=
p_dbus_bus_get
(
DBUS_BUS_SYSTEM
,
&
error
)))
{
{
WARN
(
"failed to get system dbus connection: %s
\n
"
,
error
.
message
);
WARN
(
"failed to get system dbus connection: %s
\n
"
,
error
.
message
);
p_dbus_error_free
(
&
error
);
p_dbus_error_free
(
&
error
);
return
1
;
return
;
}
}
/* first try UDisks2 */
/* first try UDisks2 */
...
@@ -561,27 +570,7 @@ static DWORD WINAPI dbus_thread( void *arg )
...
@@ -561,27 +570,7 @@ static DWORD WINAPI dbus_thread( void *arg )
p_dbus_connection_remove_filter
(
connection
,
udisks_filter
,
NULL
);
p_dbus_connection_remove_filter
(
connection
,
udisks_filter
,
NULL
);
found:
found:
__TRY
while
(
p_dbus_connection_read_write_dispatch
(
connection
,
-
1
))
/* nothing */
;
{
while
(
p_dbus_connection_read_write_dispatch
(
connection
,
-
1
))
/* nothing */
;
}
__EXCEPT
(
assert_fault
)
{
WARN
(
"dbus assertion failure, disabling support
\n
"
);
return
1
;
}
__ENDTRY
;
return
0
;
}
void
initialize_dbus
(
void
)
{
HANDLE
handle
;
if
(
!
load_dbus_functions
())
return
;
if
(
!
(
handle
=
CreateThread
(
NULL
,
0
,
dbus_thread
,
NULL
,
0
,
NULL
)))
return
;
CloseHandle
(
handle
);
}
}
#if !defined(HAVE_SYSTEMCONFIGURATION_SCDYNAMICSTORECOPYDHCPINFO_H) || !defined(HAVE_SYSTEMCONFIGURATION_SCNETWORKCONFIGURATION_H)
#if !defined(HAVE_SYSTEMCONFIGURATION_SCDYNAMICSTORECOPYDHCPINFO_H) || !defined(HAVE_SYSTEMCONFIGURATION_SCNETWORKCONFIGURATION_H)
...
@@ -776,28 +765,29 @@ static const char *map_option( ULONG option )
...
@@ -776,28 +765,29 @@ static const char *map_option( ULONG option )
}
}
}
}
ULONG
get_dhcp_request_param
(
const
char
*
unix_name
,
struct
mountmgr_dhcp_request_param
*
param
,
char
*
buf
,
ULONG
offset
,
NTSTATUS
dhcp_request
(
void
*
args
)
ULONG
size
)
{
{
const
struct
dhcp_request_params
*
params
=
args
;
DBusMessage
*
reply
;
DBusMessage
*
reply
;
const
char
*
value
;
const
char
*
value
;
ULONG
ret
=
0
;
ULONG
ret
=
0
;
param
->
offset
=
param
->
size
=
0
;
param
s
->
req
->
offset
=
params
->
req
->
size
=
0
;
if
(
!
(
reply
=
dhcp4_config_option_request
(
unix_name
,
map_option
(
param
->
id
),
&
value
)))
return
0
;
if
(
!
(
reply
=
dhcp4_config_option_request
(
params
->
unix_name
,
map_option
(
params
->
req
->
id
),
&
value
)))
return
0
;
switch
(
param
->
id
)
switch
(
param
s
->
req
->
id
)
{
{
case
OPTION_SUBNET_MASK
:
case
OPTION_SUBNET_MASK
:
case
OPTION_ROUTER_ADDRESS
:
case
OPTION_ROUTER_ADDRESS
:
case
OPTION_BROADCAST_ADDRESS
:
case
OPTION_BROADCAST_ADDRESS
:
{
{
IN_ADDR
*
ptr
=
(
IN_ADDR
*
)(
buf
+
offset
);
IN_ADDR
*
ptr
=
(
IN_ADDR
*
)(
params
->
buffer
+
params
->
offset
);
if
(
value
&&
size
>=
sizeof
(
IN_ADDR
)
&&
!
RtlIpv4StringToAddressA
(
value
,
TRUE
,
NULL
,
ptr
))
if
(
value
&&
params
->
size
>=
sizeof
(
IN_ADDR
))
{
{
param
->
offset
=
offset
;
ptr
->
S_un
.
S_addr
=
inet_addr
(
value
);
param
->
size
=
sizeof
(
*
ptr
);
params
->
req
->
offset
=
params
->
offset
;
params
->
req
->
size
=
sizeof
(
*
ptr
);
TRACE
(
"returning %08x
\n
"
,
*
(
DWORD
*
)
ptr
);
TRACE
(
"returning %08x
\n
"
,
*
(
DWORD
*
)
ptr
);
}
}
ret
=
sizeof
(
*
ptr
);
ret
=
sizeof
(
*
ptr
);
...
@@ -807,33 +797,39 @@ ULONG get_dhcp_request_param( const char *unix_name, struct mountmgr_dhcp_reques
...
@@ -807,33 +797,39 @@ ULONG get_dhcp_request_param( const char *unix_name, struct mountmgr_dhcp_reques
case
OPTION_DOMAIN_NAME
:
case
OPTION_DOMAIN_NAME
:
case
OPTION_MSFT_IE_PROXY
:
case
OPTION_MSFT_IE_PROXY
:
{
{
char
*
ptr
=
buf
+
offset
;
char
*
ptr
=
params
->
buffer
+
params
->
offset
;
int
len
=
value
?
strlen
(
value
)
:
0
;
int
len
=
value
?
strlen
(
value
)
:
0
;
if
(
len
&&
size
>=
len
)
if
(
len
&&
params
->
size
>=
len
)
{
{
memcpy
(
ptr
,
value
,
len
);
memcpy
(
ptr
,
value
,
len
);
param
->
offset
=
offset
;
param
s
->
req
->
offset
=
params
->
offset
;
param
->
size
=
len
;
param
s
->
req
->
size
=
len
;
TRACE
(
"returning %s
\n
"
,
debugstr_an
(
ptr
,
len
)
);
TRACE
(
"returning %s
\n
"
,
debugstr_an
(
ptr
,
len
)
);
}
}
ret
=
len
;
ret
=
len
;
break
;
break
;
}
}
default:
default:
FIXME
(
"option %u not supported
\n
"
,
param
->
id
);
FIXME
(
"option %u not supported
\n
"
,
param
s
->
req
->
id
);
break
;
break
;
}
}
p_dbus_message_unref
(
reply
);
p_dbus_message_unref
(
reply
);
return
ret
;
*
params
->
ret_size
=
ret
;
return
STATUS_SUCCESS
;
}
}
#endif
#endif
#else
/* SONAME_LIBDBUS_1 */
#else
/* SONAME_LIBDBUS_1 */
void
initialize_dbus
(
void
)
void
run_dbus_loop
(
void
)
{
{
TRACE
(
"Skipping, DBUS support not compiled in
\n
"
);
TRACE
(
"Skipping, DBUS support not compiled in
\n
"
);
}
}
NTSTATUS
dhcp_request
(
void
*
args
)
{
return
STATUS_NOT_SUPPORTED
;
}
#endif
/* SONAME_LIBDBUS_1 */
#endif
/* SONAME_LIBDBUS_1 */
dlls/mountmgr.sys/mountmgr.c
View file @
95615a4a
...
@@ -408,7 +408,15 @@ static void WINAPI query_dhcp_request_params( TP_CALLBACK_INSTANCE *instance, vo
...
@@ -408,7 +408,15 @@ static void WINAPI query_dhcp_request_params( TP_CALLBACK_INSTANCE *instance, vo
offset
=
FIELD_OFFSET
(
struct
mountmgr_dhcp_request_params
,
params
[
query
->
count
]);
offset
=
FIELD_OFFSET
(
struct
mountmgr_dhcp_request_params
,
params
[
query
->
count
]);
for
(
i
=
0
;
i
<
query
->
count
;
i
++
)
for
(
i
=
0
;
i
<
query
->
count
;
i
++
)
{
{
#ifdef __APPLE__
offset
+=
get_dhcp_request_param
(
query
->
unix_name
,
&
query
->
params
[
i
],
(
char
*
)
query
,
offset
,
outsize
-
offset
);
offset
+=
get_dhcp_request_param
(
query
->
unix_name
,
&
query
->
params
[
i
],
(
char
*
)
query
,
offset
,
outsize
-
offset
);
#else
ULONG
ret_size
;
struct
dhcp_request_params
params
=
{
query
->
unix_name
,
&
query
->
params
[
i
],
(
char
*
)
query
,
offset
,
outsize
-
offset
,
&
ret_size
};
MOUNTMGR_CALL
(
dhcp_request
,
&
params
);
offset
+=
ret_size
;
#endif
if
(
offset
>
outsize
)
if
(
offset
>
outsize
)
{
{
if
(
offset
>=
sizeof
(
query
->
size
))
query
->
size
=
offset
;
if
(
offset
>=
sizeof
(
query
->
size
))
query
->
size
=
offset
;
...
@@ -438,6 +446,30 @@ static void WINAPI query_symbol_file_callback( TP_CALLBACK_INSTANCE *instance, v
...
@@ -438,6 +446,30 @@ static void WINAPI query_symbol_file_callback( TP_CALLBACK_INSTANCE *instance, v
IoCompleteRequest
(
irp
,
IO_NO_INCREMENT
);
IoCompleteRequest
(
irp
,
IO_NO_INCREMENT
);
}
}
/* NT APC called from Unix side to add/remove devices */
static
void
CALLBACK
device_op
(
ULONG_PTR
arg1
,
ULONG_PTR
arg2
,
ULONG_PTR
arg3
)
{
struct
device_info
info
;
struct
dequeue_device_op_params
params
=
{
arg1
,
&
info
};
if
(
MOUNTMGR_CALL
(
dequeue_device_op
,
&
params
))
return
;
switch
(
info
.
op
)
{
case
ADD_DOS_DEVICE
:
add_dos_device
(
-
1
,
info
.
udi
,
info
.
device
,
info
.
mount_point
,
info
.
type
,
info
.
guid
,
info
.
scsi_info
);
break
;
case
ADD_VOLUME
:
add_volume
(
info
.
udi
,
info
.
device
,
info
.
mount_point
,
DEVICE_HARDDISK_VOL
,
info
.
guid
,
info
.
serial
,
info
.
scsi_info
);
break
;
case
REMOVE_DEVICE
:
if
(
!
remove_dos_device
(
-
1
,
info
.
udi
))
remove_volume
(
info
.
udi
);
break
;
}
}
/* handler for ioctls on the mount manager device */
/* handler for ioctls on the mount manager device */
static
NTSTATUS
WINAPI
mountmgr_ioctl
(
DEVICE_OBJECT
*
device
,
IRP
*
irp
)
static
NTSTATUS
WINAPI
mountmgr_ioctl
(
DEVICE_OBJECT
*
device
,
IRP
*
irp
)
{
{
...
@@ -579,6 +611,18 @@ static NTSTATUS WINAPI mountmgr_ioctl( DEVICE_OBJECT *device, IRP *irp )
...
@@ -579,6 +611,18 @@ static NTSTATUS WINAPI mountmgr_ioctl( DEVICE_OBJECT *device, IRP *irp )
return
status
;
return
status
;
}
}
static
DWORD
WINAPI
device_op_thread
(
void
*
arg
)
{
for
(;;)
SleepEx
(
INFINITE
,
TRUE
);
/* wait for APCs */
return
0
;
}
static
DWORD
WINAPI
run_loop_thread
(
void
*
arg
)
{
return
MOUNTMGR_CALL
(
run_loop
,
arg
);
}
/* main entry point for the mount point manager driver */
/* main entry point for the mount point manager driver */
NTSTATUS
WINAPI
DriverEntry
(
DRIVER_OBJECT
*
driver
,
UNICODE_STRING
*
path
)
NTSTATUS
WINAPI
DriverEntry
(
DRIVER_OBJECT
*
driver
,
UNICODE_STRING
*
path
)
{
{
...
@@ -606,6 +650,7 @@ NTSTATUS WINAPI DriverEntry( DRIVER_OBJECT *driver, UNICODE_STRING *path )
...
@@ -606,6 +650,7 @@ NTSTATUS WINAPI DriverEntry( DRIVER_OBJECT *driver, UNICODE_STRING *path )
DEVICE_OBJECT
*
device
;
DEVICE_OBJECT
*
device
;
HKEY
devicemap_key
;
HKEY
devicemap_key
;
NTSTATUS
status
;
NTSTATUS
status
;
struct
run_loop_params
params
;
TRACE
(
"%s
\n
"
,
debugstr_w
(
path
->
Buffer
)
);
TRACE
(
"%s
\n
"
,
debugstr_w
(
path
->
Buffer
)
);
...
@@ -636,7 +681,10 @@ NTSTATUS WINAPI DriverEntry( DRIVER_OBJECT *driver, UNICODE_STRING *path )
...
@@ -636,7 +681,10 @@ NTSTATUS WINAPI DriverEntry( DRIVER_OBJECT *driver, UNICODE_STRING *path )
RtlInitUnicodeString
(
&
nameW
,
harddiskW
);
RtlInitUnicodeString
(
&
nameW
,
harddiskW
);
status
=
IoCreateDriver
(
&
nameW
,
harddisk_driver_entry
);
status
=
IoCreateDriver
(
&
nameW
,
harddisk_driver_entry
);
initialize_dbus
();
params
.
op_thread
=
CreateThread
(
NULL
,
0
,
device_op_thread
,
NULL
,
0
,
NULL
);
params
.
op_apc
=
device_op
;
CloseHandle
(
CreateThread
(
NULL
,
0
,
run_loop_thread
,
&
params
,
0
,
NULL
));
initialize_diskarbitration
();
initialize_diskarbitration
();
#ifdef _WIN64
#ifdef _WIN64
...
...
dlls/mountmgr.sys/mountmgr.h
View file @
95615a4a
...
@@ -36,7 +36,6 @@
...
@@ -36,7 +36,6 @@
#define WINE_MOUNTMGR_EXTENSIONS
#define WINE_MOUNTMGR_EXTENSIONS
#include "ddk/mountmgr.h"
#include "ddk/mountmgr.h"
extern
void
initialize_dbus
(
void
)
DECLSPEC_HIDDEN
;
extern
void
initialize_diskarbitration
(
void
)
DECLSPEC_HIDDEN
;
extern
void
initialize_diskarbitration
(
void
)
DECLSPEC_HIDDEN
;
extern
WCHAR
*
strdupW
(
const
WCHAR
*
)
DECLSPEC_HIDDEN
;
extern
WCHAR
*
strdupW
(
const
WCHAR
*
)
DECLSPEC_HIDDEN
;
...
@@ -115,6 +114,8 @@ extern struct mount_point *add_volume_mount_point( DEVICE_OBJECT *device, UNICOD
...
@@ -115,6 +114,8 @@ extern struct mount_point *add_volume_mount_point( DEVICE_OBJECT *device, UNICOD
extern
void
delete_mount_point
(
struct
mount_point
*
mount
)
DECLSPEC_HIDDEN
;
extern
void
delete_mount_point
(
struct
mount_point
*
mount
)
DECLSPEC_HIDDEN
;
extern
void
set_mount_point_id
(
struct
mount_point
*
mount
,
const
void
*
id
,
unsigned
int
id_len
)
DECLSPEC_HIDDEN
;
extern
void
set_mount_point_id
(
struct
mount_point
*
mount
,
const
void
*
id
,
unsigned
int
id_len
)
DECLSPEC_HIDDEN
;
#ifdef __APPLE__
extern
ULONG
get_dhcp_request_param
(
const
char
*
unix_name
,
struct
mountmgr_dhcp_request_param
*
param
,
extern
ULONG
get_dhcp_request_param
(
const
char
*
unix_name
,
struct
mountmgr_dhcp_request_param
*
param
,
char
*
buf
,
ULONG
offset
,
ULONG
size
)
DECLSPEC_HIDDEN
;
char
*
buf
,
ULONG
offset
,
ULONG
size
)
DECLSPEC_HIDDEN
;
#endif
#endif
/* __WINE_MOUNTMGR_H */
#endif
/* __WINE_MOUNTMGR_H */
dlls/mountmgr.sys/unixlib.c
View file @
95615a4a
...
@@ -34,6 +34,7 @@
...
@@ -34,6 +34,7 @@
#include "unixlib.h"
#include "unixlib.h"
static
struct
run_loop_params
run_loop_params
;
static
char
*
get_dosdevices_path
(
const
char
*
dev
)
static
char
*
get_dosdevices_path
(
const
char
*
dev
)
{
{
...
@@ -87,6 +88,69 @@ static void detect_devices( const char **paths, char *names, ULONG size )
...
@@ -87,6 +88,69 @@ static void detect_devices( const char **paths, char *names, ULONG size )
*
names
=
0
;
*
names
=
0
;
}
}
void
queue_device_op
(
enum
device_op
op
,
const
char
*
udi
,
const
char
*
device
,
const
char
*
mount_point
,
enum
device_type
type
,
const
GUID
*
guid
,
const
char
*
serial
,
const
struct
scsi_info
*
scsi_info
)
{
struct
device_info
*
info
;
char
*
str
,
*
end
;
info
=
calloc
(
1
,
sizeof
(
*
info
)
);
str
=
info
->
str_buffer
;
end
=
info
->
str_buffer
+
sizeof
(
info
->
str_buffer
);
info
->
op
=
op
;
info
->
type
=
type
;
#define ADD_STR(s) if (s && str + strlen(s) + 1 <= end) \
{ \
info->s = strcpy( str, s ); \
str += strlen(str) + 1; \
}
ADD_STR
(
udi
);
ADD_STR
(
device
);
ADD_STR
(
mount_point
);
ADD_STR
(
serial
);
#undef ADD_STR
if
(
guid
)
{
info
->
guid_buffer
=
*
guid
;
info
->
guid
=
&
info
->
guid_buffer
;
}
if
(
scsi_info
)
{
info
->
scsi_buffer
=
*
scsi_info
;
info
->
scsi_info
=
&
info
->
scsi_buffer
;
}
NtQueueApcThread
(
run_loop_params
.
op_thread
,
run_loop_params
.
op_apc
,
(
ULONG_PTR
)
info
,
0
,
0
);
}
static
NTSTATUS
run_loop
(
void
*
args
)
{
const
struct
run_loop_params
*
params
=
args
;
run_loop_params
=
*
params
;
run_dbus_loop
();
return
STATUS_SUCCESS
;
}
static
NTSTATUS
dequeue_device_op
(
void
*
args
)
{
const
struct
dequeue_device_op_params
*
params
=
args
;
struct
device_info
*
src
=
(
struct
device_info
*
)
params
->
arg
;
struct
device_info
*
dst
=
params
->
info
;
/* copy info to client address space and fix up pointers */
*
dst
=
*
src
;
if
(
dst
->
udi
)
dst
->
udi
=
(
char
*
)
dst
+
(
src
->
udi
-
(
char
*
)
src
);
if
(
dst
->
device
)
dst
->
device
=
(
char
*
)
dst
+
(
src
->
device
-
(
char
*
)
src
);
if
(
dst
->
mount_point
)
dst
->
mount_point
=
(
char
*
)
dst
+
(
src
->
mount_point
-
(
char
*
)
src
);
if
(
dst
->
serial
)
dst
->
serial
=
(
char
*
)
dst
+
(
src
->
serial
-
(
char
*
)
src
);
if
(
dst
->
guid
)
dst
->
guid
=
&
dst
->
guid_buffer
;
if
(
dst
->
scsi_info
)
dst
->
scsi_info
=
&
dst
->
scsi_buffer
;
free
(
src
);
return
STATUS_SUCCESS
;
}
/* find or create a DOS drive for the corresponding Unix device */
/* find or create a DOS drive for the corresponding Unix device */
static
NTSTATUS
add_drive
(
void
*
args
)
static
NTSTATUS
add_drive
(
void
*
args
)
{
{
...
@@ -361,6 +425,8 @@ static NTSTATUS get_shell_folder( void *args )
...
@@ -361,6 +425,8 @@ static NTSTATUS get_shell_folder( void *args )
const
unixlib_entry_t
__wine_unix_call_funcs
[]
=
const
unixlib_entry_t
__wine_unix_call_funcs
[]
=
{
{
run_loop
,
dequeue_device_op
,
add_drive
,
add_drive
,
get_dosdev_symlink
,
get_dosdev_symlink
,
set_dosdev_symlink
,
set_dosdev_symlink
,
...
@@ -371,4 +437,5 @@ const unixlib_entry_t __wine_unix_call_funcs[] =
...
@@ -371,4 +437,5 @@ const unixlib_entry_t __wine_unix_call_funcs[] =
detect_parallel_ports
,
detect_parallel_ports
,
set_shell_folder
,
set_shell_folder
,
get_shell_folder
,
get_shell_folder
,
dhcp_request
,
};
};
dlls/mountmgr.sys/unixlib.h
View file @
95615a4a
...
@@ -21,6 +21,42 @@
...
@@ -21,6 +21,42 @@
#include "mountmgr.h"
#include "mountmgr.h"
#include "wine/unixlib.h"
#include "wine/unixlib.h"
enum
device_op
{
ADD_DOS_DEVICE
,
ADD_VOLUME
,
REMOVE_DEVICE
};
struct
device_info
{
enum
device_op
op
;
enum
device_type
type
;
const
char
*
udi
;
const
char
*
device
;
const
char
*
mount_point
;
const
char
*
serial
;
GUID
*
guid
;
struct
scsi_info
*
scsi_info
;
/* buffer space for pointers */
GUID
guid_buffer
;
struct
scsi_info
scsi_buffer
;
char
str_buffer
[
1024
];
};
struct
run_loop_params
{
HANDLE
op_thread
;
PNTAPCFUNC
op_apc
;
};
struct
dequeue_device_op_params
{
ULONG_PTR
arg
;
struct
device_info
*
info
;
};
struct
add_drive_params
struct
add_drive_params
{
{
const
char
*
device
;
const
char
*
device
;
...
@@ -81,8 +117,20 @@ struct get_shell_folder_params
...
@@ -81,8 +117,20 @@ struct get_shell_folder_params
ULONG
size
;
ULONG
size
;
};
};
struct
dhcp_request_params
{
const
char
*
unix_name
;
struct
mountmgr_dhcp_request_param
*
req
;
char
*
buffer
;
ULONG
offset
;
ULONG
size
;
ULONG
*
ret_size
;
};
enum
mountmgr_funcs
enum
mountmgr_funcs
{
{
unix_run_loop
,
unix_dequeue_device_op
,
unix_add_drive
,
unix_add_drive
,
unix_get_dosdev_symlink
,
unix_get_dosdev_symlink
,
unix_set_dosdev_symlink
,
unix_set_dosdev_symlink
,
...
@@ -93,12 +141,19 @@ enum mountmgr_funcs
...
@@ -93,12 +141,19 @@ enum mountmgr_funcs
unix_detect_parallel_ports
,
unix_detect_parallel_ports
,
unix_set_shell_folder
,
unix_set_shell_folder
,
unix_get_shell_folder
,
unix_get_shell_folder
,
unix_dhcp_request
,
};
};
extern
unixlib_handle_t
mountmgr_handle
;
extern
unixlib_handle_t
mountmgr_handle
;
#define MOUNTMGR_CALL( func, params ) __wine_unix_call( mountmgr_handle, unix_ ## func, params )
#define MOUNTMGR_CALL( func, params ) __wine_unix_call( mountmgr_handle, unix_ ## func, params )
extern
void
queue_device_op
(
enum
device_op
op
,
const
char
*
udi
,
const
char
*
device
,
const
char
*
mount_point
,
enum
device_type
type
,
const
GUID
*
guid
,
const
char
*
disk_serial
,
const
struct
scsi_info
*
info
)
DECLSPEC_HIDDEN
;
extern
void
run_dbus_loop
(
void
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
dhcp_request
(
void
*
args
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
query_symbol_file
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
query_symbol_file
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
read_credential
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
read_credential
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
write_credential
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
extern
NTSTATUS
write_credential
(
void
*
buff
,
ULONG
insize
,
ULONG
outsize
,
ULONG
*
info
)
DECLSPEC_HIDDEN
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment