patch-2.3.16 linux/net/irda/irmod.c
Next file: linux/net/irda/irproc.c
Previous file: linux/net/irda/irlpt/irlpt_srvr_fsm.c
Back to the patch index
Back to the overall index
- Lines: 181
- Date:
Mon Aug 30 10:28:52 1999
- Orig file:
v2.3.15/linux/net/irda/irmod.c
- Orig date:
Mon Jul 5 20:03:14 1999
diff -u --recursive --new-file v2.3.15/linux/net/irda/irmod.c linux/net/irda/irmod.c
@@ -6,7 +6,7 @@
* Status: Experimental.
* Author: Dag Brattli <dagb@cs.uit.no>
* Created at: Mon Dec 15 13:55:39 1997
- * Modified at: Fri May 14 13:46:02 1999
+ * Modified at: Wed Aug 11 08:53:56 1999
* Modified by: Dag Brattli <dagb@cs.uit.no>
*
* Copyright (c) 1997, 1999 Dag Brattli, All Rights Reserved.
@@ -27,10 +27,10 @@
#include <linux/init.h>
#include <linux/poll.h>
-#include <asm/segment.h>
-
#include <linux/proc_fs.h>
+#include <asm/segment.h>
+
#include <net/irda/irda.h>
#include <net/irda/irmod.h>
#include <net/irda/irlap.h>
@@ -44,6 +44,7 @@
#include <net/irda/irda_device.h>
#include <net/irda/wrapper.h>
#include <net/irda/timer.h>
+#include <net/irda/parameters.h>
extern struct proc_dir_entry *proc_irda;
@@ -66,7 +67,7 @@
extern int irlan_client_init(void);
extern int irlan_server_init(void);
extern int ircomm_init(void);
-extern int irvtd_init(void);
+extern int ircomm_tty_init(void);
extern int irlpt_client_init(void);
extern int irlpt_server_init(void);
@@ -120,6 +121,11 @@
EXPORT_SYMBOL(irmanager_notify);
EXPORT_SYMBOL(irda_lock);
EXPORT_SYMBOL(proc_irda);
+EXPORT_SYMBOL(irda_param_insert);
+EXPORT_SYMBOL(irda_param_extract);
+EXPORT_SYMBOL(irda_param_extract_all);
+EXPORT_SYMBOL(irda_param_pack);
+EXPORT_SYMBOL(irda_param_unpack);
/* IrIAP/IrIAS */
EXPORT_SYMBOL(iriap_getvaluebyclass_request);
@@ -176,6 +182,8 @@
EXPORT_SYMBOL(irda_device_setup);
EXPORT_SYMBOL(irda_device_set_media_busy);
EXPORT_SYMBOL(irda_device_txqueue_empty);
+EXPORT_SYMBOL(irda_device_net_open);
+EXPORT_SYMBOL(irda_device_net_close);
EXPORT_SYMBOL(irda_device_init_dongle);
EXPORT_SYMBOL(irda_device_register_dongle);
@@ -184,22 +192,25 @@
EXPORT_SYMBOL(async_wrap_skb);
EXPORT_SYMBOL(async_unwrap_char);
EXPORT_SYMBOL(irda_start_timer);
-/* EXPORT_SYMBOL(irda_get_mtt); */
EXPORT_SYMBOL(setup_dma);
#ifdef CONFIG_IRTTY
EXPORT_SYMBOL(irtty_set_dtr_rts);
EXPORT_SYMBOL(irtty_register_dongle);
EXPORT_SYMBOL(irtty_unregister_dongle);
+EXPORT_SYMBOL(irtty_set_packet_mode);
#endif
-__initfunc(int irda_init(void))
+int __init irda_init(void)
{
- printk(KERN_INFO "IrDA (tm) Protocols for Linux-2.2 (Dag Brattli)\n");
+ printk(KERN_INFO "IrDA (tm) Protocols for Linux-2.3 (Dag Brattli)\n");
irlmp_init();
irlap_init();
- irda_device_init();
+
+#ifdef MODULE
+ irda_device_init(); /* Called by init/main.c when non-modular */
+#endif
iriap_init();
irttp_init();
@@ -210,12 +221,12 @@
#ifdef CONFIG_SYSCTL
irda_sysctl_register();
#endif
-
+ init_waitqueue_head(&irda.wait_queue);
irda.dev.minor = MISC_DYNAMIC_MINOR;
irda.dev.name = "irda";
irda.dev.fops = &irda_fops;
- misc_register( &irda.dev);
+ misc_register(&irda.dev);
irda.in_use = FALSE;
@@ -229,15 +240,7 @@
#endif
#ifdef CONFIG_IRCOMM
ircomm_init();
- irvtd_init();
-#endif
-
-#ifdef CONFIG_IRLPT_CLIENT
- irlpt_client_init();
-#endif
-
-#ifdef CONFIG_IRLPT_SERVER
- irlpt_server_init();
+ ircomm_tty_init();
#endif
#ifdef CONFIG_IRDA_COMPRESSION
@@ -252,7 +255,7 @@
#ifdef MODULE
void irda_cleanup(void)
{
- misc_deregister( &irda.dev);
+ misc_deregister(&irda.dev);
#ifdef CONFIG_SYSCTL
irda_sysctl_unregister();
@@ -261,7 +264,6 @@
#ifdef CONFIG_PROC_FS
irda_proc_unregister();
#endif
-
/* Remove higher layers */
irttp_cleanup();
iriap_cleanup();
@@ -296,7 +298,7 @@
* Used for initializing the notify structure
*
*/
-void irda_notify_init( struct notify_t *notify)
+void irda_notify_init(notify_t *notify)
{
notify->data_indication = NULL;
notify->udata_indication = NULL;
@@ -305,7 +307,7 @@
notify->disconnect_indication = NULL;
notify->flow_indication = NULL;
notify->instance = NULL;
- strncpy( notify->name, "Unknown", NOTIFY_MAX_NAME);
+ strncpy(notify->name, "Unknown", NOTIFY_MAX_NAME);
}
/*
@@ -340,12 +342,12 @@
new->param = param;
/* Queue todo */
- enqueue_last( &irda.todo_queue, (QUEUE *) new);
+ enqueue_last(&irda.todo_queue, (QUEUE *) new);
event.event = EVENT_NEED_PROCESS_CONTEXT;
/* Notify the user space manager */
- irmanager_notify( &event);
+ irmanager_notify(&event);
}
/*
@@ -475,6 +477,8 @@
return -ERESTARTSYS;
event = (struct irda_event *) dequeue_first( &irda.event_queue);
+ if (!event)
+ return 0;
len = sizeof(struct irmanager_event);
copy_to_user( buffer, &event->event, len);
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)