1 /* $Id: kcapi.c,v 1.1.4.1 2001/11/20 14:19:34 kai Exp $
3 * Kernel CAPI 2.0 Module
5 * Copyright 1999 by Carsten Paeth <calle@calle.de>
7 * This software may be used and distributed according to the terms
8 * of the GNU General Public License, incorporated herein by reference.
12 #define CONFIG_AVMB1_COMPAT
14 #include <linux/config.h>
15 #include <linux/module.h>
16 #include <linux/kernel.h>
18 #include <linux/interrupt.h>
19 #include <linux/ioport.h>
20 #include <asm/segment.h>
21 #include <linux/proc_fs.h>
22 #include <linux/skbuff.h>
23 #include <linux/tqueue.h>
24 #include <linux/capi.h>
25 #include <linux/kernelcapi.h>
26 #include <linux/locks.h>
27 #include <linux/init.h>
28 #include <asm/uaccess.h>
32 #ifdef CONFIG_AVMB1_COMPAT
33 #include <linux/b1lli.h>
36 static char *revision = "$Revision: 1.1.4.1 $";
38 /* ------------------------------------------------------------- */
41 #define CARD_DETECTED 1
42 #define CARD_LOADING 2
43 #define CARD_RUNNING 3
45 /* ------------------------------------------------------------- */
47 static int showcapimsgs = 0;
49 MODULE_DESCRIPTION("CAPI4Linux: kernel CAPI layer");
50 MODULE_AUTHOR("Carsten Paeth");
51 MODULE_LICENSE("GPL");
52 MODULE_PARM(showcapimsgs, "i");
54 /* ------------------------------------------------------------- */
57 struct msgidqueue *next;
62 struct capi_ncci *next;
68 struct msgidqueue *msgidqueue;
69 struct msgidqueue *msgidlast;
70 struct msgidqueue *msgidfree;
71 struct msgidqueue msgidpool[CAPI_MAXDATAWINDOW];
76 capi_register_params rparam;
79 void (*signal) (__u16 applid, void *param);
80 struct sk_buff_head recv_queue;
82 struct capi_ncci *nccilist;
84 unsigned long nrecvctlpkt;
85 unsigned long nrecvdatapkt;
86 unsigned long nsentctlpkt;
87 unsigned long nsentdatapkt;
90 struct capi_notifier {
91 struct capi_notifier *next;
98 /* ------------------------------------------------------------- */
100 static struct capi_version driver_version = {2, 0, 1, 1<<4};
101 static char driver_serial[CAPI_SERIAL_LEN] = "0004711";
102 static char capi_manufakturer[64] = "AVM Berlin";
104 #define APPL(a) (&applications[(a)-1])
105 #define VALID_APPLID(a) ((a) && (a) <= CAPI_MAXAPPL && APPL(a)->applid == a)
106 #define APPL_IS_FREE(a) (APPL(a)->applid == 0)
107 #define APPL_MARK_FREE(a) do{ APPL(a)->applid=0; MOD_DEC_USE_COUNT; }while(0)
108 #define APPL_MARK_USED(a) do{ APPL(a)->applid=(a); MOD_INC_USE_COUNT; }while(0)
110 #define NCCI2CTRL(ncci) (((ncci) >> 24) & 0x7f)
112 #define VALID_CARD(c) ((c) > 0 && (c) <= CAPI_MAXCONTR)
113 #define CARD(c) (&cards[(c)-1])
114 #define CARDNR(cp) ((((cp)-cards)+1) & 0xff)
116 static struct capi_appl applications[CAPI_MAXAPPL];
117 static struct capi_ctr cards[CAPI_MAXCONTR];
118 static int ncards = 0;
119 static struct sk_buff_head recv_queue;
120 static struct capi_interface_user *capi_users = 0;
121 static spinlock_t capi_users_lock = SPIN_LOCK_UNLOCKED;
122 static struct capi_driver *drivers;
123 static spinlock_t drivers_lock = SPIN_LOCK_UNLOCKED;
125 static struct tq_struct tq_state_notify;
126 static struct tq_struct tq_recv_notify;
128 /* -------- util functions ------------------------------------ */
130 static char *cardstate2str(unsigned short cardstate)
134 case CARD_FREE: return "free";
135 case CARD_DETECTED: return "detected";
136 case CARD_LOADING: return "loading";
137 case CARD_RUNNING: return "running";
141 static inline int capi_cmd_valid(__u8 cmd)
146 case CAPI_CONNECT_ACTIVE:
147 case CAPI_CONNECT_B3_ACTIVE:
148 case CAPI_CONNECT_B3:
149 case CAPI_CONNECT_B3_T90_ACTIVE:
151 case CAPI_DISCONNECT_B3:
152 case CAPI_DISCONNECT:
156 case CAPI_MANUFACTURER:
158 case CAPI_SELECT_B_PROTOCOL:
164 static inline int capi_subcmd_valid(__u8 subcmd)
176 /* -------- /proc functions ----------------------------------- */
178 * /proc/capi/applications:
179 * applid l3cnt dblkcnt dblklen #ncci recvqueuelen
181 static int proc_applications_read_proc(char *page, char **start, off_t off,
182 int count, int *eof, void *data)
184 struct capi_appl *ap;
188 for (i=0; i < CAPI_MAXAPPL; i++) {
189 ap = &applications[i];
190 if (ap->applid == 0) continue;
191 len += sprintf(page+len, "%u %d %d %d %d %d\n",
193 ap->rparam.level3cnt,
194 ap->rparam.datablkcnt,
195 ap->rparam.datablklen,
197 skb_queue_len(&ap->recv_queue));
210 if (len>count) len = count;
217 * applid ncci winsize nblk
219 static int proc_ncci_read_proc(char *page, char **start, off_t off,
220 int count, int *eof, void *data)
222 struct capi_appl *ap;
223 struct capi_ncci *np;
227 for (i=0; i < CAPI_MAXAPPL; i++) {
228 ap = &applications[i];
229 if (ap->applid == 0) continue;
230 for (np = ap->nccilist; np; np = np->next) {
231 len += sprintf(page+len, "%d 0x%x %d %d\n",
249 if (len>count) len = count;
258 static int proc_driver_read_proc(char *page, char **start, off_t off,
259 int count, int *eof, void *data)
261 struct capi_driver *driver;
264 spin_lock(&drivers_lock);
265 for (driver = drivers; driver; driver = driver->next) {
266 len += sprintf(page+len, "%-32s %d %s\n",
279 spin_unlock(&drivers_lock);
283 if (len>count) len = count;
292 static int proc_users_read_proc(char *page, char **start, off_t off,
293 int count, int *eof, void *data)
295 struct capi_interface_user *cp;
298 spin_lock(&capi_users_lock);
299 for (cp = capi_users; cp ; cp = cp->next) {
300 len += sprintf(page+len, "%s\n", cp->name);
310 spin_unlock(&capi_users_lock);
314 if (len>count) len = count;
320 * /proc/capi/controller:
321 * cnr driver cardstate name driverinfo
323 static int proc_controller_read_proc(char *page, char **start, off_t off,
324 int count, int *eof, void *data)
330 for (i=0; i < CAPI_MAXCONTR; i++) {
332 if (cp->cardstate == CARD_FREE) continue;
333 len += sprintf(page+len, "%d %-10s %-8s %-16s %s\n",
334 cp->cnr, cp->driver->name,
335 cardstate2str(cp->cardstate),
337 cp->driver->procinfo ? cp->driver->procinfo(cp) : ""
351 if (len>count) len = count;
357 * /proc/capi/applstats:
358 * applid nrecvctlpkt nrecvdatapkt nsentctlpkt nsentdatapkt
360 static int proc_applstats_read_proc(char *page, char **start, off_t off,
361 int count, int *eof, void *data)
363 struct capi_appl *ap;
367 for (i=0; i < CAPI_MAXAPPL; i++) {
368 ap = &applications[i];
369 if (ap->applid == 0) continue;
370 len += sprintf(page+len, "%u %lu %lu %lu %lu\n",
388 if (len>count) len = count;
394 * /proc/capi/contrstats:
395 * cnr nrecvctlpkt nrecvdatapkt nsentctlpkt nsentdatapkt
397 static int proc_contrstats_read_proc(char *page, char **start, off_t off,
398 int count, int *eof, void *data)
404 for (i=0; i < CAPI_MAXCONTR; i++) {
406 if (cp->cardstate == CARD_FREE) continue;
407 len += sprintf(page+len, "%d %lu %lu %lu %lu\n",
425 if (len>count) len = count;
430 static struct procfsentries {
433 int (*read_proc)(char *page, char **start, off_t off,
434 int count, int *eof, void *data);
435 struct proc_dir_entry *procent;
436 } procfsentries[] = {
437 { "capi", S_IFDIR, 0 },
438 { "capi/applications", 0 , proc_applications_read_proc },
439 { "capi/ncci", 0 , proc_ncci_read_proc },
440 { "capi/driver", 0 , proc_driver_read_proc },
441 { "capi/users", 0 , proc_users_read_proc },
442 { "capi/controller", 0 , proc_controller_read_proc },
443 { "capi/applstats", 0 , proc_applstats_read_proc },
444 { "capi/contrstats", 0 , proc_contrstats_read_proc },
445 { "capi/drivers", S_IFDIR, 0 },
446 { "capi/controllers", S_IFDIR, 0 },
449 static void proc_capi_init(void)
451 int nelem = sizeof(procfsentries)/sizeof(procfsentries[0]);
454 for (i=0; i < nelem; i++) {
455 struct procfsentries *p = procfsentries + i;
456 p->procent = create_proc_entry(p->name, p->mode, 0);
457 if (p->procent) p->procent->read_proc = p->read_proc;
461 static void proc_capi_exit(void)
463 int nelem = sizeof(procfsentries)/sizeof(procfsentries[0]);
466 for (i=nelem-1; i >= 0; i--) {
467 struct procfsentries *p = procfsentries + i;
469 remove_proc_entry(p->name, 0);
475 /* -------- Notifier handling --------------------------------- */
477 static struct capi_notifier_list{
478 struct capi_notifier *head;
479 struct capi_notifier *tail;
482 static spinlock_t notifier_lock = SPIN_LOCK_UNLOCKED;
484 static inline void notify_enqueue(struct capi_notifier *np)
486 struct capi_notifier_list *q = ¬ifier_list;
489 spin_lock_irqsave(¬ifier_lock, flags);
494 q->head = q->tail = np;
496 spin_unlock_irqrestore(¬ifier_lock, flags);
499 static inline struct capi_notifier *notify_dequeue(void)
501 struct capi_notifier_list *q = ¬ifier_list;
502 struct capi_notifier *np = 0;
505 spin_lock_irqsave(¬ifier_lock, flags);
508 if ((q->head = np->next) == 0)
512 spin_unlock_irqrestore(¬ifier_lock, flags);
516 static int notify_push(unsigned int cmd, __u32 controller,
517 __u16 applid, __u32 ncci)
519 struct capi_notifier *np;
522 np = (struct capi_notifier *)kmalloc(sizeof(struct capi_notifier), GFP_ATOMIC);
527 memset(np, 0, sizeof(struct capi_notifier));
529 np->controller = controller;
534 * The notifier will result in adding/deleteing
535 * of devices. Devices can only removed in
536 * user process, not in bh.
539 if (schedule_task(&tq_state_notify) == 0)
544 /* -------- KCI_CONTRUP --------------------------------------- */
546 static void notify_up(__u32 contr)
548 struct capi_interface_user *p;
551 for (appl = 1; appl <= CAPI_MAXAPPL; appl++) {
552 if (!VALID_APPLID(appl)) continue;
553 if (APPL(appl)->releasing) continue;
554 CARD(contr)->driver->register_appl(CARD(contr), appl, &APPL(appl)->rparam);
556 printk(KERN_NOTICE "kcapi: notify up contr %d\n", contr);
557 spin_lock(&capi_users_lock);
558 for (p = capi_users; p; p = p->next) {
559 if (!p->callback) continue;
560 (*p->callback) (KCI_CONTRUP, contr, &CARD(contr)->profile);
562 spin_unlock(&capi_users_lock);
565 /* -------- KCI_CONTRDOWN ------------------------------------- */
567 static void notify_down(__u32 contr)
569 struct capi_interface_user *p;
570 printk(KERN_NOTICE "kcapi: notify down contr %d\n", contr);
571 spin_lock(&capi_users_lock);
572 for (p = capi_users; p; p = p->next) {
573 if (!p->callback) continue;
574 (*p->callback) (KCI_CONTRDOWN, contr, 0);
576 spin_unlock(&capi_users_lock);
579 /* -------- KCI_NCCIUP ---------------------------------------- */
581 static void notify_ncciup(__u32 contr, __u16 applid, __u32 ncci)
583 struct capi_interface_user *p;
584 struct capi_ncciinfo n;
587 /*printk(KERN_NOTICE "kcapi: notify up contr %d\n", contr);*/
588 spin_lock(&capi_users_lock);
589 for (p = capi_users; p; p = p->next) {
590 if (!p->callback) continue;
591 (*p->callback) (KCI_NCCIUP, contr, &n);
593 spin_unlock(&capi_users_lock);
596 /* -------- KCI_NCCIDOWN -------------------------------------- */
598 static void notify_nccidown(__u32 contr, __u16 applid, __u32 ncci)
600 struct capi_interface_user *p;
601 struct capi_ncciinfo n;
604 /*printk(KERN_NOTICE "kcapi: notify down contr %d\n", contr);*/
605 spin_lock(&capi_users_lock);
606 for (p = capi_users; p; p = p->next) {
607 if (!p->callback) continue;
608 (*p->callback) (KCI_NCCIDOWN, contr, &n);
610 spin_unlock(&capi_users_lock);
613 /* ------------------------------------------------------------ */
615 static void inline notify_doit(struct capi_notifier *np)
619 notify_up(np->controller);
622 notify_down(np->controller);
625 notify_ncciup(np->controller, np->applid, np->ncci);
628 notify_nccidown(np->controller, np->applid, np->ncci);
633 static void notify_handler(void *dummy)
635 struct capi_notifier *np;
637 while ((np = notify_dequeue()) != 0) {
645 /* -------- NCCI Handling ------------------------------------- */
647 static inline void mq_init(struct capi_ncci * np)
650 np->lock = SPIN_LOCK_UNLOCKED;
654 memset(np->msgidpool, 0, sizeof(np->msgidpool));
655 np->msgidfree = &np->msgidpool[0];
656 for (i = 1; i < np->winsize; i++) {
657 np->msgidpool[i].next = np->msgidfree;
658 np->msgidfree = &np->msgidpool[i];
662 static inline int mq_enqueue(struct capi_ncci * np, __u16 msgid)
664 struct msgidqueue *mq;
665 spin_lock_bh(&np->lock);
666 if ((mq = np->msgidfree) == 0) {
667 spin_unlock_bh(&np->lock);
670 np->msgidfree = mq->next;
674 np->msgidlast->next = mq;
679 spin_unlock_bh(&np->lock);
683 static inline int mq_dequeue(struct capi_ncci * np, __u16 msgid)
685 struct msgidqueue **pp;
686 spin_lock_bh(&np->lock);
687 for (pp = &np->msgidqueue; *pp; pp = &(*pp)->next) {
688 if ((*pp)->msgid == msgid) {
689 struct msgidqueue *mq = *pp;
691 if (mq == np->msgidlast)
693 mq->next = np->msgidfree;
696 spin_unlock_bh(&np->lock);
700 spin_unlock_bh(&np->lock);
704 static void controllercb_appl_registered(struct capi_ctr * card, __u16 appl)
708 static void controllercb_appl_released(struct capi_ctr * card, __u16 appl)
710 struct capi_ncci **pp, **nextpp;
711 for (pp = &APPL(appl)->nccilist; *pp; pp = nextpp) {
712 if (NCCI2CTRL((*pp)->ncci) == card->cnr) {
713 struct capi_ncci *np = *pp;
715 printk(KERN_INFO "kcapi: appl %d ncci 0x%x down!\n", appl, np->ncci);
720 nextpp = &(*pp)->next;
723 if (APPL(appl)->releasing) { /* only release if the application was marked for release */
724 printk(KERN_DEBUG "kcapi: appl %d releasing(%d)\n", appl, APPL(appl)->releasing);
725 APPL(appl)->releasing--;
726 if (APPL(appl)->releasing <= 0) {
727 APPL(appl)->signal = 0;
728 APPL_MARK_FREE(appl);
729 printk(KERN_INFO "kcapi: appl %d down\n", appl);
732 printk(KERN_WARNING "kcapi: appl %d card%d released without request\n", appl, card->cnr);
738 static void controllercb_new_ncci(struct capi_ctr * card,
739 __u16 appl, __u32 ncci, __u32 winsize)
741 struct capi_ncci *np;
742 if (!VALID_APPLID(appl)) {
743 printk(KERN_ERR "avmb1_handle_new_ncci: illegal appl %d\n", appl);
746 if ((np = (struct capi_ncci *) kmalloc(sizeof(struct capi_ncci), GFP_ATOMIC)) == 0) {
747 printk(KERN_ERR "capi_new_ncci: alloc failed ncci 0x%x\n", ncci);
750 if (winsize > CAPI_MAXDATAWINDOW) {
751 printk(KERN_ERR "capi_new_ncci: winsize %d too big, set to %d\n",
752 winsize, CAPI_MAXDATAWINDOW);
753 winsize = CAPI_MAXDATAWINDOW;
757 np->winsize = winsize;
759 np->next = APPL(appl)->nccilist;
760 APPL(appl)->nccilist = np;
762 printk(KERN_INFO "kcapi: appl %d ncci 0x%x up\n", appl, ncci);
764 notify_push(KCI_NCCIUP, CARDNR(card), appl, ncci);
767 static void controllercb_free_ncci(struct capi_ctr * card,
768 __u16 appl, __u32 ncci)
770 struct capi_ncci **pp;
771 if (!VALID_APPLID(appl)) {
772 printk(KERN_ERR "free_ncci: illegal appl %d\n", appl);
775 for (pp = &APPL(appl)->nccilist; *pp; pp = &(*pp)->next) {
776 if ((*pp)->ncci == ncci) {
777 struct capi_ncci *np = *pp;
781 printk(KERN_INFO "kcapi: appl %d ncci 0x%x down\n", appl, ncci);
782 notify_push(KCI_NCCIDOWN, CARDNR(card), appl, ncci);
786 printk(KERN_ERR "free_ncci: ncci 0x%x not found\n", ncci);
790 static struct capi_ncci *find_ncci(struct capi_appl * app, __u32 ncci)
792 struct capi_ncci *np;
793 for (np = app->nccilist; np; np = np->next) {
794 if (np->ncci == ncci)
800 /* -------- Receiver ------------------------------------------ */
802 static void recv_handler(void *dummy)
806 while ((skb = skb_dequeue(&recv_queue)) != 0) {
807 __u16 appl = CAPIMSG_APPID(skb->data);
808 struct capi_ncci *np;
809 if (!VALID_APPLID(appl)) {
810 printk(KERN_ERR "kcapi: recv_handler: applid %d ? (%s)\n",
811 appl, capi_message2str(skb->data));
815 if (APPL(appl)->signal == 0) {
816 printk(KERN_ERR "kcapi: recv_handler: applid %d has no signal function\n",
821 if ( CAPIMSG_COMMAND(skb->data) == CAPI_DATA_B3
822 && CAPIMSG_SUBCOMMAND(skb->data) == CAPI_CONF
823 && (np = find_ncci(APPL(appl), CAPIMSG_NCCI(skb->data))) != 0
824 && mq_dequeue(np, CAPIMSG_MSGID(skb->data)) == 0) {
825 printk(KERN_ERR "kcapi: msgid %hu ncci 0x%x not on queue\n",
826 CAPIMSG_MSGID(skb->data), np->ncci);
828 if ( CAPIMSG_COMMAND(skb->data) == CAPI_DATA_B3
829 && CAPIMSG_SUBCOMMAND(skb->data) == CAPI_IND) {
830 APPL(appl)->nrecvdatapkt++;
832 APPL(appl)->nrecvctlpkt++;
834 skb_queue_tail(&APPL(appl)->recv_queue, skb);
835 (APPL(appl)->signal) (APPL(appl)->applid, APPL(appl)->param);
839 static void controllercb_handle_capimsg(struct capi_ctr * card,
840 __u16 appl, struct sk_buff *skb)
845 if (card->cardstate != CARD_RUNNING) {
846 printk(KERN_INFO "kcapi: controller %d not active, got: %s",
847 card->cnr, capi_message2str(skb->data));
850 cmd = CAPIMSG_COMMAND(skb->data);
851 subcmd = CAPIMSG_SUBCOMMAND(skb->data);
852 if (cmd == CAPI_DATA_B3 && subcmd == CAPI_IND) {
853 card->nrecvdatapkt++;
854 if (card->traceflag > 2) showctl |= 2;
857 if (card->traceflag) showctl |= 2;
859 showctl |= (card->traceflag & 1);
862 printk(KERN_DEBUG "kcapi: got [0x%lx] id#%d %s len=%u\n",
863 (unsigned long) card->cnr,
864 CAPIMSG_APPID(skb->data),
865 capi_cmd2str(cmd, subcmd),
866 CAPIMSG_LEN(skb->data));
868 printk(KERN_DEBUG "kcapi: got [0x%lx] %s\n",
869 (unsigned long) card->cnr,
870 capi_message2str(skb->data));
874 skb_queue_tail(&recv_queue, skb);
875 queue_task(&tq_recv_notify, &tq_immediate);
876 mark_bh(IMMEDIATE_BH);
883 static void controllercb_ready(struct capi_ctr * card)
885 card->cardstate = CARD_RUNNING;
886 printk(KERN_NOTICE "kcapi: card %d \"%s\" ready.\n",
887 CARDNR(card), card->name);
889 notify_push(KCI_CONTRUP, CARDNR(card), 0, 0);
892 static void controllercb_reseted(struct capi_ctr * card)
896 if (card->cardstate == CARD_FREE)
898 if (card->cardstate == CARD_DETECTED)
901 card->cardstate = CARD_DETECTED;
903 memset(card->manu, 0, sizeof(card->manu));
904 memset(&card->version, 0, sizeof(card->version));
905 memset(&card->profile, 0, sizeof(card->profile));
906 memset(card->serial, 0, sizeof(card->serial));
908 for (appl = 1; appl <= CAPI_MAXAPPL; appl++) {
909 struct capi_ncci **pp, **nextpp;
910 for (pp = &APPL(appl)->nccilist; *pp; pp = nextpp) {
911 if (NCCI2CTRL((*pp)->ncci) == card->cnr) {
912 struct capi_ncci *np = *pp;
914 printk(KERN_INFO "kcapi: appl %d ncci 0x%x forced down!\n", appl, np->ncci);
915 notify_push(KCI_NCCIDOWN, CARDNR(card), appl, np->ncci);
919 nextpp = &(*pp)->next;
924 printk(KERN_NOTICE "kcapi: card %d down.\n", CARDNR(card));
926 notify_push(KCI_CONTRDOWN, CARDNR(card), 0, 0);
929 static void controllercb_suspend_output(struct capi_ctr *card)
931 if (!card->blocked) {
932 printk(KERN_DEBUG "kcapi: card %d suspend\n", CARDNR(card));
937 static void controllercb_resume_output(struct capi_ctr *card)
940 printk(KERN_DEBUG "kcapi: card %d resume\n", CARDNR(card));
945 /* ------------------------------------------------------------- */
949 drivercb_attach_ctr(struct capi_driver *driver, char *name, void *driverdata)
951 struct capi_ctr *card, **pp;
954 for (i=0; i < CAPI_MAXCONTR && cards[i].cardstate != CARD_FREE; i++) ;
956 if (i == CAPI_MAXCONTR) {
957 printk(KERN_ERR "kcapi: out of controller slots\n");
961 memset(card, 0, sizeof(struct capi_ctr));
962 card->driver = driver;
963 card->cnr = CARDNR(card);
964 strncpy(card->name, name, sizeof(card->name));
965 card->cardstate = CARD_DETECTED;
967 card->driverdata = driverdata;
968 card->traceflag = showcapimsgs;
970 card->ready = controllercb_ready;
971 card->reseted = controllercb_reseted;
972 card->suspend_output = controllercb_suspend_output;
973 card->resume_output = controllercb_resume_output;
974 card->handle_capimsg = controllercb_handle_capimsg;
975 card->appl_registered = controllercb_appl_registered;
976 card->appl_released = controllercb_appl_released;
977 card->new_ncci = controllercb_new_ncci;
978 card->free_ncci = controllercb_free_ncci;
980 for (pp = &driver->controller; *pp; pp = &(*pp)->next) ;
983 driver->ncontroller++;
984 sprintf(card->procfn, "capi/controllers/%d", card->cnr);
985 card->procent = create_proc_entry(card->procfn, 0, 0);
987 card->procent->read_proc =
988 (int (*)(char *,char **,off_t,int,int *,void *))
989 driver->ctr_read_proc;
990 card->procent->data = card;
994 printk(KERN_NOTICE "kcapi: Controller %d: %s attached\n",
995 card->cnr, card->name);
999 static int drivercb_detach_ctr(struct capi_ctr *card)
1001 struct capi_driver *driver = card->driver;
1002 struct capi_ctr **pp;
1004 if (card->cardstate == CARD_FREE)
1006 if (card->cardstate != CARD_DETECTED)
1007 controllercb_reseted(card);
1008 for (pp = &driver->controller; *pp ; pp = &(*pp)->next) {
1011 driver->ncontroller--;
1016 if (card->procent) {
1017 remove_proc_entry(card->procfn, 0);
1020 card->cardstate = CARD_FREE;
1021 printk(KERN_NOTICE "kcapi: Controller %d: %s unregistered\n",
1022 card->cnr, card->name);
1026 /* ------------------------------------------------------------- */
1028 /* fallback if no driver read_proc function defined by driver */
1030 static int driver_read_proc(char *page, char **start, off_t off,
1031 int count, int *eof, void *data)
1033 struct capi_driver *driver = (struct capi_driver *)data;
1036 len += sprintf(page+len, "%-16s %s\n", "name", driver->name);
1037 len += sprintf(page+len, "%-16s %s\n", "revision", driver->revision);
1042 *start = page + off;
1043 return ((count < len-off) ? count : len-off);
1046 /* ------------------------------------------------------------- */
1048 static struct capi_driver_interface di = {
1049 drivercb_attach_ctr,
1050 drivercb_detach_ctr,
1053 struct capi_driver_interface *attach_capi_driver(struct capi_driver *driver)
1055 struct capi_driver **pp;
1058 spin_lock(&drivers_lock);
1059 for (pp = &drivers; *pp; pp = &(*pp)->next) ;
1062 spin_unlock(&drivers_lock);
1063 printk(KERN_NOTICE "kcapi: driver %s attached\n", driver->name);
1064 sprintf(driver->procfn, "capi/drivers/%s", driver->name);
1065 driver->procent = create_proc_entry(driver->procfn, 0, 0);
1066 if (driver->procent) {
1067 if (driver->driver_read_proc) {
1068 driver->procent->read_proc =
1069 (int (*)(char *,char **,off_t,int,int *,void *))
1070 driver->driver_read_proc;
1072 driver->procent->read_proc = driver_read_proc;
1074 driver->procent->data = driver;
1079 void detach_capi_driver(struct capi_driver *driver)
1081 struct capi_driver **pp;
1082 spin_lock(&drivers_lock);
1083 for (pp = &drivers; *pp && *pp != driver; pp = &(*pp)->next) ;
1086 printk(KERN_NOTICE "kcapi: driver %s detached\n", driver->name);
1088 printk(KERN_ERR "kcapi: driver %s double detach ?\n", driver->name);
1090 spin_unlock(&drivers_lock);
1091 if (driver->procent) {
1092 remove_proc_entry(driver->procfn, 0);
1093 driver->procent = 0;
1098 /* ------------------------------------------------------------- */
1099 /* -------- CAPI2.0 Interface ---------------------------------- */
1100 /* ------------------------------------------------------------- */
1102 static __u16 capi_isinstalled(void)
1105 for (i = 0; i < CAPI_MAXCONTR; i++) {
1106 if (cards[i].cardstate == CARD_RUNNING)
1107 return CAPI_NOERROR;
1109 return CAPI_REGNOTINSTALLED;
1112 static __u16 capi_register(capi_register_params * rparam, __u16 * applidp)
1117 if (rparam->datablklen < 128)
1118 return CAPI_LOGBLKSIZETOSMALL;
1120 for (appl = 1; appl <= CAPI_MAXAPPL; appl++) {
1121 if (APPL_IS_FREE(appl))
1124 if (appl > CAPI_MAXAPPL)
1125 return CAPI_TOOMANYAPPLS;
1127 APPL_MARK_USED(appl);
1128 skb_queue_head_init(&APPL(appl)->recv_queue);
1129 APPL(appl)->nncci = 0;
1131 memcpy(&APPL(appl)->rparam, rparam, sizeof(capi_register_params));
1133 for (i = 0; i < CAPI_MAXCONTR; i++) {
1134 if (cards[i].cardstate != CARD_RUNNING)
1136 cards[i].driver->register_appl(&cards[i], appl,
1137 &APPL(appl)->rparam);
1140 printk(KERN_INFO "kcapi: appl %d up\n", appl);
1142 return CAPI_NOERROR;
1145 static __u16 capi_release(__u16 applid)
1149 if (!VALID_APPLID(applid) || APPL(applid)->releasing)
1150 return CAPI_ILLAPPNR;
1151 APPL(applid)->releasing++;
1152 skb_queue_purge(&APPL(applid)->recv_queue);
1153 for (i = 0; i < CAPI_MAXCONTR; i++) {
1154 if (cards[i].cardstate != CARD_RUNNING)
1156 APPL(applid)->releasing++;
1157 cards[i].driver->release_appl(&cards[i], applid);
1159 APPL(applid)->releasing--;
1160 if (APPL(applid)->releasing <= 0) {
1161 APPL(applid)->signal = 0;
1162 APPL_MARK_FREE(applid);
1163 printk(KERN_INFO "kcapi: appl %d down\n", applid);
1165 return CAPI_NOERROR;
1168 static __u16 capi_put_message(__u16 applid, struct sk_buff *skb)
1170 struct capi_ncci *np;
1176 return CAPI_REGNOTINSTALLED;
1177 if (!VALID_APPLID(applid))
1178 return CAPI_ILLAPPNR;
1180 || !capi_cmd_valid(CAPIMSG_COMMAND(skb->data))
1181 || !capi_subcmd_valid(CAPIMSG_SUBCOMMAND(skb->data)))
1182 return CAPI_ILLCMDORSUBCMDORMSGTOSMALL;
1183 contr = CAPIMSG_CONTROLLER(skb->data);
1184 if (!VALID_CARD(contr) || CARD(contr)->cardstate != CARD_RUNNING) {
1186 if (CARD(contr)->cardstate != CARD_RUNNING)
1187 return CAPI_REGNOTINSTALLED;
1189 if (CARD(contr)->blocked)
1190 return CAPI_SENDQUEUEFULL;
1192 cmd = CAPIMSG_COMMAND(skb->data);
1193 subcmd = CAPIMSG_SUBCOMMAND(skb->data);
1195 if (cmd == CAPI_DATA_B3 && subcmd== CAPI_REQ) {
1196 if ((np = find_ncci(APPL(applid), CAPIMSG_NCCI(skb->data))) != 0
1197 && mq_enqueue(np, CAPIMSG_MSGID(skb->data)) == 0)
1198 return CAPI_SENDQUEUEFULL;
1199 CARD(contr)->nsentdatapkt++;
1200 APPL(applid)->nsentdatapkt++;
1201 if (CARD(contr)->traceflag > 2) showctl |= 2;
1203 CARD(contr)->nsentctlpkt++;
1204 APPL(applid)->nsentctlpkt++;
1205 if (CARD(contr)->traceflag) showctl |= 2;
1207 showctl |= (CARD(contr)->traceflag & 1);
1210 printk(KERN_DEBUG "kcapi: put [0x%lx] id#%d %s len=%u\n",
1211 (unsigned long) contr,
1212 CAPIMSG_APPID(skb->data),
1213 capi_cmd2str(cmd, subcmd),
1214 CAPIMSG_LEN(skb->data));
1216 printk(KERN_DEBUG "kcapi: put [0x%lx] %s\n",
1217 (unsigned long) contr,
1218 capi_message2str(skb->data));
1222 CARD(contr)->driver->send_message(CARD(contr), skb);
1223 return CAPI_NOERROR;
1226 static __u16 capi_get_message(__u16 applid, struct sk_buff **msgp)
1228 struct sk_buff *skb;
1230 if (!VALID_APPLID(applid))
1231 return CAPI_ILLAPPNR;
1232 if ((skb = skb_dequeue(&APPL(applid)->recv_queue)) == 0)
1233 return CAPI_RECEIVEQUEUEEMPTY;
1235 return CAPI_NOERROR;
1238 static __u16 capi_set_signal(__u16 applid,
1239 void (*signal) (__u16 applid, void *param),
1242 if (!VALID_APPLID(applid))
1243 return CAPI_ILLAPPNR;
1244 APPL(applid)->signal = signal;
1245 APPL(applid)->param = param;
1246 return CAPI_NOERROR;
1249 static __u16 capi_get_manufacturer(__u32 contr, __u8 buf[CAPI_MANUFACTURER_LEN])
1252 strncpy(buf, capi_manufakturer, CAPI_MANUFACTURER_LEN);
1253 return CAPI_NOERROR;
1255 if (!VALID_CARD(contr) || CARD(contr)->cardstate != CARD_RUNNING)
1256 return CAPI_REGNOTINSTALLED;
1258 strncpy(buf, CARD(contr)->manu, CAPI_MANUFACTURER_LEN);
1259 return CAPI_NOERROR;
1262 static __u16 capi_get_version(__u32 contr, struct capi_version *verp)
1265 *verp = driver_version;
1266 return CAPI_NOERROR;
1268 if (!VALID_CARD(contr) || CARD(contr)->cardstate != CARD_RUNNING)
1269 return CAPI_REGNOTINSTALLED;
1271 memcpy((void *) verp, &CARD(contr)->version, sizeof(capi_version));
1272 return CAPI_NOERROR;
1275 static __u16 capi_get_serial(__u32 contr, __u8 serial[CAPI_SERIAL_LEN])
1278 strncpy(serial, driver_serial, CAPI_SERIAL_LEN);
1279 return CAPI_NOERROR;
1281 if (!VALID_CARD(contr) || CARD(contr)->cardstate != CARD_RUNNING)
1282 return CAPI_REGNOTINSTALLED;
1284 strncpy((void *) serial, CARD(contr)->serial, CAPI_SERIAL_LEN);
1285 return CAPI_NOERROR;
1288 static __u16 capi_get_profile(__u32 contr, struct capi_profile *profp)
1291 profp->ncontroller = ncards;
1292 return CAPI_NOERROR;
1294 if (!VALID_CARD(contr) || CARD(contr)->cardstate != CARD_RUNNING)
1295 return CAPI_REGNOTINSTALLED;
1297 memcpy((void *) profp, &CARD(contr)->profile,
1298 sizeof(struct capi_profile));
1299 return CAPI_NOERROR;
1302 static struct capi_driver *find_driver(char *name)
1304 struct capi_driver *dp;
1305 spin_lock(&drivers_lock);
1306 for (dp = drivers; dp; dp = dp->next)
1307 if (strcmp(dp->name, name) == 0)
1309 spin_unlock(&drivers_lock);
1313 #ifdef CONFIG_AVMB1_COMPAT
1314 static int old_capi_manufacturer(unsigned int cmd, void *data)
1316 avmb1_loadandconfigdef ldef;
1317 avmb1_extcarddef cdef;
1318 avmb1_resetdef rdef;
1320 struct capi_driver *driver;
1321 struct capi_ctr *card;
1322 capicardparams cparams;
1328 case AVMB1_ADDCARD_WITH_TYPE:
1329 if (cmd == AVMB1_ADDCARD) {
1330 if ((retval = copy_from_user((void *) &cdef, data,
1331 sizeof(avmb1_carddef))))
1333 cdef.cardtype = AVM_CARDTYPE_B1;
1335 if ((retval = copy_from_user((void *) &cdef, data,
1336 sizeof(avmb1_extcarddef))))
1339 cparams.port = cdef.port;
1340 cparams.irq = cdef.irq;
1341 cparams.cardnr = cdef.cardnr;
1343 switch (cdef.cardtype) {
1344 case AVM_CARDTYPE_B1:
1345 driver = find_driver("b1isa");
1347 case AVM_CARDTYPE_T1:
1348 driver = find_driver("t1isa");
1355 printk(KERN_ERR "kcapi: driver not loaded.\n");
1358 if (!driver->add_card) {
1359 printk(KERN_ERR "kcapi: driver has no add card function.\n");
1363 return driver->add_card(driver, &cparams);
1366 case AVMB1_LOAD_AND_CONFIG:
1368 if (cmd == AVMB1_LOAD) {
1369 if ((retval = copy_from_user((void *) &ldef, data,
1370 sizeof(avmb1_loaddef))))
1372 ldef.t4config.len = 0;
1373 ldef.t4config.data = 0;
1375 if ((retval = copy_from_user((void *) &ldef, data,
1376 sizeof(avmb1_loadandconfigdef))))
1379 if (!VALID_CARD(ldef.contr))
1382 card = CARD(ldef.contr);
1383 if (card->cardstate == CARD_FREE)
1385 if (card->driver->load_firmware == 0) {
1386 printk(KERN_DEBUG "kcapi: load: driver \%s\" has no load function\n", card->driver->name);
1390 if (ldef.t4file.len <= 0) {
1391 printk(KERN_DEBUG "kcapi: load: invalid parameter: length of t4file is %d ?\n", ldef.t4file.len);
1394 if (ldef.t4file.data == 0) {
1395 printk(KERN_DEBUG "kcapi: load: invalid parameter: dataptr is 0\n");
1399 ldata.firmware.user = 1;
1400 ldata.firmware.data = ldef.t4file.data;
1401 ldata.firmware.len = ldef.t4file.len;
1402 ldata.configuration.user = 1;
1403 ldata.configuration.data = ldef.t4config.data;
1404 ldata.configuration.len = ldef.t4config.len;
1406 if (card->cardstate != CARD_DETECTED) {
1407 printk(KERN_INFO "kcapi: load: contr=%d not in detect state\n", ldef.contr);
1410 card->cardstate = CARD_LOADING;
1412 retval = card->driver->load_firmware(card, &ldata);
1415 card->cardstate = CARD_DETECTED;
1419 while (card->cardstate != CARD_RUNNING) {
1421 set_current_state(TASK_INTERRUPTIBLE);
1422 schedule_timeout(HZ/10); /* 0.1 sec */
1424 if (signal_pending(current))
1429 case AVMB1_RESETCARD:
1430 if ((retval = copy_from_user((void *) &rdef, data,
1431 sizeof(avmb1_resetdef))))
1433 if (!VALID_CARD(rdef.contr))
1435 card = CARD(rdef.contr);
1437 if (card->cardstate == CARD_FREE)
1439 if (card->cardstate == CARD_DETECTED)
1442 card->driver->reset_ctr(card);
1444 while (card->cardstate > CARD_DETECTED) {
1446 set_current_state(TASK_INTERRUPTIBLE);
1447 schedule_timeout(HZ/10); /* 0.1 sec */
1449 if (signal_pending(current))
1454 case AVMB1_GET_CARDINFO:
1455 if ((retval = copy_from_user((void *) &gdef, data,
1456 sizeof(avmb1_getdef))))
1459 if (!VALID_CARD(gdef.contr))
1462 card = CARD(gdef.contr);
1464 if (card->cardstate == CARD_FREE)
1467 gdef.cardstate = card->cardstate;
1468 if (card->driver == find_driver("t1isa"))
1469 gdef.cardtype = AVM_CARDTYPE_T1;
1470 else gdef.cardtype = AVM_CARDTYPE_B1;
1472 if ((retval = copy_to_user(data, (void *) &gdef,
1473 sizeof(avmb1_getdef))))
1478 case AVMB1_REMOVECARD:
1479 if ((retval = copy_from_user((void *) &rdef, data,
1480 sizeof(avmb1_resetdef))))
1483 if (!VALID_CARD(rdef.contr))
1485 card = CARD(rdef.contr);
1487 if (card->cardstate == CARD_FREE)
1490 if (card->cardstate != CARD_DETECTED)
1493 card->driver->remove_ctr(card);
1495 while (card->cardstate != CARD_FREE) {
1497 set_current_state(TASK_INTERRUPTIBLE);
1498 schedule_timeout(HZ/10); /* 0.1 sec */
1500 if (signal_pending(current))
1509 static int capi_manufacturer(unsigned int cmd, void *data)
1511 struct capi_ctr *card;
1515 #ifdef CONFIG_AVMB1_COMPAT
1517 case AVMB1_ADDCARD_WITH_TYPE:
1519 case AVMB1_LOAD_AND_CONFIG:
1520 case AVMB1_RESETCARD:
1521 case AVMB1_GET_CARDINFO:
1522 case AVMB1_REMOVECARD:
1523 return old_capi_manufacturer(cmd, data);
1525 case KCAPI_CMD_TRACE:
1529 if ((retval = copy_from_user((void *) &fdef, data,
1530 sizeof(kcapi_flagdef))))
1533 if (!VALID_CARD(fdef.contr))
1535 card = CARD(fdef.contr);
1536 if (card->cardstate == CARD_FREE)
1538 card->traceflag = fdef.flag;
1539 printk(KERN_INFO "kcapi: contr %d set trace=%d\n",
1540 card->cnr, card->traceflag);
1544 case KCAPI_CMD_ADDCARD:
1546 struct capi_driver *driver;
1547 capicardparams cparams;
1550 if ((retval = copy_from_user((void *) &cdef, data,
1554 cparams.port = cdef.port;
1555 cparams.irq = cdef.irq;
1556 cparams.membase = cdef.membase;
1557 cparams.cardnr = cdef.cardnr;
1558 cparams.cardtype = 0;
1559 cdef.driver[sizeof(cdef.driver)-1] = 0;
1561 if ((driver = find_driver(cdef.driver)) == 0) {
1562 printk(KERN_ERR "kcapi: driver \"%s\" not loaded.\n",
1567 if (!driver->add_card) {
1568 printk(KERN_ERR "kcapi: driver \"%s\" has no add card function.\n", cdef.driver);
1572 return driver->add_card(driver, &cparams);
1576 printk(KERN_ERR "kcapi: manufacturer command %d unknown.\n",
1584 struct capi_interface avmb1_interface =
1592 capi_get_manufacturer,
1599 /* ------------------------------------------------------------- */
1600 /* -------- Exported Functions --------------------------------- */
1601 /* ------------------------------------------------------------- */
1603 struct capi_interface *attach_capi_interface(struct capi_interface_user *userp)
1605 struct capi_interface_user *p;
1608 spin_lock(&capi_users_lock);
1609 for (p = capi_users; p; p = p->next) {
1611 spin_unlock(&capi_users_lock);
1612 printk(KERN_ERR "kcapi: double attach from %s\n",
1618 userp->next = capi_users;
1620 spin_unlock(&capi_users_lock);
1621 printk(KERN_NOTICE "kcapi: %s attached\n", userp->name);
1623 return &avmb1_interface;
1626 int detach_capi_interface(struct capi_interface_user *userp)
1628 struct capi_interface_user **pp;
1630 spin_lock(&capi_users_lock);
1631 for (pp = &capi_users; *pp; pp = &(*pp)->next) {
1634 spin_unlock(&capi_users_lock);
1636 printk(KERN_NOTICE "kcapi: %s detached\n", userp->name);
1641 spin_unlock(&capi_users_lock);
1642 printk(KERN_ERR "kcapi: double detach from %s\n", userp->name);
1646 /* ------------------------------------------------------------- */
1647 /* -------- Init & Cleanup ------------------------------------- */
1648 /* ------------------------------------------------------------- */
1650 EXPORT_SYMBOL(attach_capi_interface);
1651 EXPORT_SYMBOL(detach_capi_interface);
1652 EXPORT_SYMBOL(attach_capi_driver);
1653 EXPORT_SYMBOL(detach_capi_driver);
1656 * init / exit functions
1659 static int __init kcapi_init(void)
1666 skb_queue_head_init(&recv_queue);
1668 tq_state_notify.routine = notify_handler;
1669 tq_state_notify.data = 0;
1671 tq_recv_notify.routine = recv_handler;
1672 tq_recv_notify.data = 0;
1676 if ((p = strchr(revision, ':')) != 0 && p[1]) {
1677 strncpy(rev, p + 2, sizeof(rev));
1678 rev[sizeof(rev)-1] = 0;
1679 if ((p = strchr(rev, '$')) != 0 && p > rev)
1685 printk(KERN_NOTICE "CAPI-driver Rev %s: loaded\n", rev);
1687 printk(KERN_NOTICE "CAPI-driver Rev %s: started\n", rev);
1693 static void __exit kcapi_exit(void)
1698 if ((p = strchr(revision, ':'))) {
1700 p = strchr(rev, '$');
1707 printk(KERN_NOTICE "CAPI-driver Rev%s: unloaded\n", rev);
1710 module_init(kcapi_init);
1711 module_exit(kcapi_exit);