mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-02 00:24:12 +08:00
03f18285cd
Fix up some of the readibility deterioration caused by last year's ISDN whitespace coding style cleanup. Note that the checkpatch complaints all apply to the state of the source before this patch as well, and in many cases even more so. Signed-off-by: Tilman Schmidt <tilman@imap.cc> Signed-off-by: David S. Miller <davem@davemloft.net>
133 lines
4.8 KiB
C
133 lines
4.8 KiB
C
/* $Id: isdn_divert.h,v 1.5.6.1 2001/09/23 22:24:36 kai Exp $
|
|
*
|
|
* Header for the diversion supplementary ioctl interface.
|
|
*
|
|
* Copyright 1998 by Werner Cornelius (werner@ikt.de)
|
|
*
|
|
* This software may be used and distributed according to the terms
|
|
* of the GNU General Public License, incorporated herein by reference.
|
|
*
|
|
*/
|
|
|
|
#include <linux/ioctl.h>
|
|
#include <linux/types.h>
|
|
|
|
/******************************************/
|
|
/* IOCTL codes for interface to user prog */
|
|
/******************************************/
|
|
#define DIVERT_IIOC_VERSION 0x01 /* actual version */
|
|
#define IIOCGETVER _IO('I', 1) /* get version of interface */
|
|
#define IIOCGETDRV _IO('I', 2) /* get driver number */
|
|
#define IIOCGETNAM _IO('I', 3) /* get driver name */
|
|
#define IIOCGETRULE _IO('I', 4) /* read one rule */
|
|
#define IIOCMODRULE _IO('I', 5) /* modify/replace a rule */
|
|
#define IIOCINSRULE _IO('I', 6) /* insert/append one rule */
|
|
#define IIOCDELRULE _IO('I', 7) /* delete a rule */
|
|
#define IIOCDODFACT _IO('I', 8) /* hangup/reject/alert/immediately deflect a call */
|
|
#define IIOCDOCFACT _IO('I', 9) /* activate control forwarding in PBX */
|
|
#define IIOCDOCFDIS _IO('I', 10) /* deactivate control forwarding in PBX */
|
|
#define IIOCDOCFINT _IO('I', 11) /* interrogate control forwarding in PBX */
|
|
|
|
/*************************************/
|
|
/* states reported through interface */
|
|
/*************************************/
|
|
#define DEFLECT_IGNORE 0 /* ignore incoming call */
|
|
#define DEFLECT_REPORT 1 /* only report */
|
|
#define DEFLECT_PROCEED 2 /* deflect when externally triggered */
|
|
#define DEFLECT_ALERT 3 /* alert and deflect after delay */
|
|
#define DEFLECT_REJECT 4 /* reject immediately */
|
|
#define DIVERT_ACTIVATE 5 /* diversion activate */
|
|
#define DIVERT_DEACTIVATE 6 /* diversion deactivate */
|
|
#define DIVERT_REPORT 7 /* interrogation result */
|
|
#define DEFLECT_AUTODEL 255 /* only for internal use */
|
|
|
|
#define DEFLECT_ALL_IDS 0xFFFFFFFF /* all drivers selected */
|
|
|
|
typedef struct {
|
|
ulong drvid; /* driver ids, bit mapped */
|
|
char my_msn[35]; /* desired msn, subaddr allowed */
|
|
char caller[35]; /* caller id, partial string with * + subaddr allowed */
|
|
char to_nr[35]; /* deflected to number incl. subaddress */
|
|
u_char si1, si2; /* service indicators, si1=bitmask, si1+2 0 = all */
|
|
u_char screen; /* screening: 0 = no info, 1 = info, 2 = nfo with nr */
|
|
u_char callopt; /* option for call handling:
|
|
0 = all calls
|
|
1 = only non waiting calls
|
|
2 = only waiting calls */
|
|
u_char action; /* desired action:
|
|
0 = don't report call -> ignore
|
|
1 = report call, do not allow/proceed for deflection
|
|
2 = report call, send proceed, wait max waittime secs
|
|
3 = report call, alert and deflect after waittime
|
|
4 = report call, reject immediately
|
|
actions 1-2 only take place if interface is opened
|
|
*/
|
|
u_char waittime; /* maximum wait time for proceeding */
|
|
} divert_rule;
|
|
|
|
typedef union {
|
|
int drv_version; /* return of driver version */
|
|
struct {
|
|
int drvid; /* id of driver */
|
|
char drvnam[30]; /* name of driver */
|
|
} getid;
|
|
struct {
|
|
int ruleidx; /* index of rule */
|
|
divert_rule rule; /* rule parms */
|
|
} getsetrule;
|
|
struct {
|
|
u_char subcmd; /* 0 = hangup/reject,
|
|
1 = alert,
|
|
2 = deflect */
|
|
ulong callid; /* id of call delivered by ascii output */
|
|
char to_nr[35]; /* destination when deflect,
|
|
else uus1 string (maxlen 31),
|
|
data from rule used if empty */
|
|
} fwd_ctrl;
|
|
struct {
|
|
int drvid; /* id of driver */
|
|
u_char cfproc; /* cfu = 0, cfb = 1, cfnr = 2 */
|
|
ulong procid; /* process id returned when no error */
|
|
u_char service; /* basically coded service, 0 = all */
|
|
char msn[25]; /* desired msn, empty = all */
|
|
char fwd_nr[35];/* forwarded to number + subaddress */
|
|
} cf_ctrl;
|
|
} divert_ioctl;
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
#include <linux/isdnif.h>
|
|
#include <linux/isdn_divertif.h>
|
|
|
|
#define AUTODEL_TIME 30 /* timeout in s to delete internal entries */
|
|
|
|
/**************************************************/
|
|
/* structure keeping ascii info for device output */
|
|
/**************************************************/
|
|
struct divert_info {
|
|
struct divert_info *next;
|
|
ulong usage_cnt; /* number of files still to work */
|
|
char info_start[2]; /* info string start */
|
|
};
|
|
|
|
|
|
/**************/
|
|
/* Prototypes */
|
|
/**************/
|
|
extern spinlock_t divert_lock;
|
|
|
|
extern ulong if_used; /* number of interface users */
|
|
extern int divert_dev_deinit(void);
|
|
extern int divert_dev_init(void);
|
|
extern void put_info_buffer(char *);
|
|
extern int ll_callback(isdn_ctrl *);
|
|
extern isdn_divert_if divert_if;
|
|
extern divert_rule *getruleptr(int);
|
|
extern int insertrule(int, divert_rule *);
|
|
extern int deleterule(int);
|
|
extern void deleteprocs(void);
|
|
extern int deflect_extern_action(u_char, ulong, char *);
|
|
extern int cf_command(int, int, u_char, char *, u_char, char *, ulong *);
|
|
|
|
#endif /* __KERNEL__ */
|