forked from luck/tmp_suning_uos_patched
3879b6b6a8
drivers/isdn/sc/event.c: In function 'indicate_status': drivers/isdn/sc/event.c:49: error: 'events' undeclared (first use in this function) drivers/isdn/sc/event.c:49: error: (Each undeclared identifier is reported only once drivers/isdn/sc/event.c:49: error: for each function it appears in.) drivers/isdn/sc/event.c:49: warning: format '%d' expects type 'int', but argument 4 has type 'ulong' drivers/isdn/sc/interrupt.c: In function 'interrupt_handler': drivers/isdn/sc/interrupt.c:97: warning: format '%x' expects type 'unsigned int', but argument 4 has type 'long unsigned int' drivers/isdn/sc/timer.c: In function 'check_reset': drivers/isdn/sc/timer.c:80: warning: format '%d' expects type 'int', but argument 3 has type 'long unsigned int' Acked-by: Karsten Keil <kkeil@suse.de> Cc: Zach Brown <zach.brown@oracle.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
72 lines
1.7 KiB
C
72 lines
1.7 KiB
C
/* $Id: event.c,v 1.4.8.1 2001/09/23 22:24:59 kai Exp $
|
|
*
|
|
* Copyright (C) 1996 SpellCaster Telecommunications Inc.
|
|
*
|
|
* This software may be used and distributed according to the terms
|
|
* of the GNU General Public License, incorporated herein by reference.
|
|
*
|
|
* For more information, please contact gpl-info@spellcast.com or write:
|
|
*
|
|
* SpellCaster Telecommunications Inc.
|
|
* 5621 Finch Avenue East, Unit #3
|
|
* Scarborough, Ontario Canada
|
|
* M1B 2T9
|
|
* +1 (416) 297-8565
|
|
* +1 (416) 297-6433 Facsimile
|
|
*/
|
|
|
|
#include "includes.h"
|
|
#include "hardware.h"
|
|
#include "message.h"
|
|
#include "card.h"
|
|
|
|
extern int cinst;
|
|
extern board *sc_adapter[];
|
|
|
|
#ifdef DEBUG
|
|
static char *events[] = { "ISDN_STAT_STAVAIL",
|
|
"ISDN_STAT_ICALL",
|
|
"ISDN_STAT_RUN",
|
|
"ISDN_STAT_STOP",
|
|
"ISDN_STAT_DCONN",
|
|
"ISDN_STAT_BCONN",
|
|
"ISDN_STAT_DHUP",
|
|
"ISDN_STAT_BHUP",
|
|
"ISDN_STAT_CINF",
|
|
"ISDN_STAT_LOAD",
|
|
"ISDN_STAT_UNLOAD",
|
|
"ISDN_STAT_BSENT",
|
|
"ISDN_STAT_NODCH",
|
|
"ISDN_STAT_ADDCH",
|
|
"ISDN_STAT_CAUSE" };
|
|
#endif
|
|
|
|
int indicate_status(int card, int event,ulong Channel,char *Data)
|
|
{
|
|
isdn_ctrl cmd;
|
|
|
|
#ifdef DEBUG
|
|
pr_debug("%s: Indicating event %s on Channel %d\n",
|
|
sc_adapter[card]->devicename, events[event-256], Channel);
|
|
#endif
|
|
if (Data != NULL){
|
|
pr_debug("%s: Event data: %s\n", sc_adapter[card]->devicename,
|
|
Data);
|
|
switch (event) {
|
|
case ISDN_STAT_BSENT:
|
|
memcpy(&cmd.parm.length, Data, sizeof(cmd.parm.length));
|
|
break;
|
|
case ISDN_STAT_ICALL:
|
|
memcpy(&cmd.parm.setup, Data, sizeof(cmd.parm.setup));
|
|
break;
|
|
default:
|
|
strcpy(cmd.parm.num, Data);
|
|
}
|
|
}
|
|
|
|
cmd.command = event;
|
|
cmd.driver = sc_adapter[card]->driverId;
|
|
cmd.arg = Channel;
|
|
return sc_adapter[card]->card->statcallb(&cmd);
|
|
}
|