Commit b414b93d authored by Alexandre Julliard's avatar Alexandre Julliard

server: Allow a device file to be mapped directly to a Unix device.

parent b191519a
...@@ -18,7 +18,11 @@ ...@@ -18,7 +18,11 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#include "config.h"
#include "wine/port.h"
#include <assert.h> #include <assert.h>
#include <fcntl.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdarg.h> #include <stdarg.h>
...@@ -120,6 +124,7 @@ struct device ...@@ -120,6 +124,7 @@ struct device
{ {
struct object obj; /* object header */ struct object obj; /* object header */
struct device_manager *manager; /* manager for this device (or NULL if deleted) */ struct device_manager *manager; /* manager for this device (or NULL if deleted) */
char *unix_path; /* path to unix device if any */
client_ptr_t user_ptr; /* opaque ptr for client side */ client_ptr_t user_ptr; /* opaque ptr for client side */
struct list entry; /* entry in device manager list */ struct list entry; /* entry in device manager list */
struct list files; /* list of open files */ struct list files; /* list of open files */
...@@ -326,6 +331,7 @@ static void device_destroy( struct object *obj ) ...@@ -326,6 +331,7 @@ static void device_destroy( struct object *obj )
assert( list_empty( &device->files )); assert( list_empty( &device->files ));
free( device->unix_path );
if (device->manager) list_remove( &device->entry ); if (device->manager) list_remove( &device->entry );
} }
...@@ -340,7 +346,17 @@ static struct object *device_open_file( struct object *obj, unsigned int access, ...@@ -340,7 +346,17 @@ static struct object *device_open_file( struct object *obj, unsigned int access,
file->device = (struct device *)grab_object( device ); file->device = (struct device *)grab_object( device );
list_init( &file->requests ); list_init( &file->requests );
list_add_tail( &device->files, &file->entry ); list_add_tail( &device->files, &file->entry );
if (!(file->fd = alloc_pseudo_fd( &device_file_fd_ops, &file->obj, 0 ))) if (device->unix_path)
{
mode_t mode = 0666;
access = file->obj.ops->map_access( &file->obj, access );
file->fd = open_fd( NULL, device->unix_path, O_NONBLOCK | O_LARGEFILE,
&mode, access, sharing, options );
if (file->fd) set_fd_user( file->fd, &device_file_fd_ops, &file->obj );
}
else file->fd = alloc_pseudo_fd( &device_file_fd_ops, &file->obj, 0 );
if (!file->fd)
{ {
release_object( file ); release_object( file );
file = NULL; file = NULL;
...@@ -509,6 +525,7 @@ static struct device *create_device( struct directory *root, const struct unicod ...@@ -509,6 +525,7 @@ static struct device *create_device( struct directory *root, const struct unicod
if (get_error() != STATUS_OBJECT_NAME_EXISTS) if (get_error() != STATUS_OBJECT_NAME_EXISTS)
{ {
/* initialize it if it didn't already exist */ /* initialize it if it didn't already exist */
device->unix_path = NULL;
device->manager = manager; device->manager = manager;
list_add_tail( &manager->devices, &device->entry ); list_add_tail( &manager->devices, &device->entry );
list_init( &device->files ); list_init( &device->files );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment