Commit e7c9a0e1 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

server: Use weak reference between console input and renderer objects.

parent b6b26674
...@@ -131,6 +131,7 @@ struct console_input_events ...@@ -131,6 +131,7 @@ struct console_input_events
{ {
struct object obj; /* object header */ struct object obj; /* object header */
struct fd *fd; /* pseudo-fd for ioctls */ struct fd *fd; /* pseudo-fd for ioctls */
struct console_input *console; /* attached console */
int num_alloc; /* number of allocated events */ int num_alloc; /* number of allocated events */
int num_used; /* number of actually used events */ int num_used; /* number of actually used events */
struct condrv_renderer_event *events; struct condrv_renderer_event *events;
...@@ -321,6 +322,7 @@ static void console_input_events_destroy( struct object *obj ) ...@@ -321,6 +322,7 @@ static void console_input_events_destroy( struct object *obj )
{ {
struct console_input_events *evts = (struct console_input_events *)obj; struct console_input_events *evts = (struct console_input_events *)obj;
assert( obj->ops == &console_input_events_ops ); assert( obj->ops == &console_input_events_ops );
if (evts->console) evts->console->evt = NULL;
free_async_queue( &evts->read_q ); free_async_queue( &evts->read_q );
if (evts->fd) release_object( evts->fd ); if (evts->fd) release_object( evts->fd );
free( evts->events ); free( evts->events );
...@@ -419,6 +421,7 @@ static struct object *create_console_input_events(void) ...@@ -419,6 +421,7 @@ static struct object *create_console_input_events(void)
struct console_input_events* evt; struct console_input_events* evt;
if (!(evt = alloc_object( &console_input_events_ops ))) return NULL; if (!(evt = alloc_object( &console_input_events_ops ))) return NULL;
evt->console = NULL;
evt->num_alloc = evt->num_used = 0; evt->num_alloc = evt->num_used = 0;
evt->events = NULL; evt->events = NULL;
init_async_queue( &evt->read_q ); init_async_queue( &evt->read_q );
...@@ -1177,10 +1180,7 @@ static void console_input_destroy( struct object *obj ) ...@@ -1177,10 +1180,7 @@ static void console_input_destroy( struct object *obj )
free_async_queue( &console_in->read_q ); free_async_queue( &console_in->read_q );
if (console_in->evt) if (console_in->evt)
{ console_in->evt->console = NULL;
release_object( console_in->evt );
console_in->evt = NULL;
}
if (console_in->event) if (console_in->event)
release_object( console_in->event ); release_object( console_in->event );
if (console_in->fd) if (console_in->fd)
...@@ -1898,10 +1898,11 @@ static int console_input_events_ioctl( struct fd *fd, ioctl_code_t code, struct ...@@ -1898,10 +1898,11 @@ static int console_input_events_ioctl( struct fd *fd, ioctl_code_t code, struct
0, &console_input_ops ); 0, &console_input_ops );
if (!console_input) return 0; if (!console_input) return 0;
if (!console_input->evt) if (!console_input->evt && !evts->console)
{ {
console_input->evt = (struct console_input_events *)grab_object( evts ); console_input->evt = evts;
console_input->renderer = current; console_input->renderer = current;
evts->console = console_input;
} }
else set_error( STATUS_INVALID_HANDLE ); else set_error( STATUS_INVALID_HANDLE );
......
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