diff options
Diffstat (limited to 'hcid/security.c')
| -rw-r--r-- | hcid/security.c | 21 | 
1 files changed, 14 insertions, 7 deletions
| diff --git a/hcid/security.c b/hcid/security.c index 58b049ed..2c76f167 100644 --- a/hcid/security.c +++ b/hcid/security.c @@ -51,7 +51,12 @@  #include "hcid.h"  #include "lib.h" -static GIOChannel *io_chan[HCI_MAX_DEV]; +struct g_io_info { +	GIOChannel	*channel; +	int		watch_id; +}; + +static struct g_io_info io_data[HCI_MAX_DEV];  static int pairing; @@ -701,7 +706,7 @@ static gboolean io_security_event(GIOChannel *chan, GIOCondition cond, gpointer  void start_security_manager(int hdev)  { -	GIOChannel *chan = io_chan[hdev]; +	GIOChannel *chan = io_data[hdev].channel;  	struct hci_dev_info *di;  	struct hci_filter flt;  	read_stored_link_key_cp cp; @@ -761,10 +766,10 @@ void start_security_manager(int hdev)  	}  	chan = g_io_channel_unix_new(dev); -	g_io_add_watch(chan, G_IO_IN | G_IO_NVAL | G_IO_HUP | G_IO_ERR, -			io_security_event, (void *) di); +	io_data[hdev].watch_id = g_io_add_watch(chan, G_IO_IN | G_IO_NVAL | G_IO_HUP | G_IO_ERR, +						io_security_event, (void *) di); -	io_chan[hdev] = chan; +	io_data[hdev].channel = chan;  	if (hci_test_bit(HCI_RAW, &di->flags))  		return; @@ -778,7 +783,7 @@ void start_security_manager(int hdev)  void stop_security_manager(int hdev)  { -	GIOChannel *chan = io_chan[hdev]; +	GIOChannel *chan = io_data[hdev].channel;  	if (!chan)  		return; @@ -789,7 +794,9 @@ void stop_security_manager(int hdev)  	   loop to call us right back with G_IO_NVAL set, at which  	   point we will see it and clean things up */  	close(g_io_channel_unix_get_fd(chan)); -	io_chan[hdev] = NULL; +	g_io_remove_watch(io_data[hdev].watch_id); +	io_data[hdev].watch_id = -1; +	io_data[hdev].channel = NULL;  }  void init_security_data(void) | 
