Path: blob/master/drivers/isdn/divert/isdn_divert.h
17705 views
/* $Id: isdn_divert.h,v 1.5.6.1 2001/09/23 22:24:36 kai Exp $1*2* Header for the diversion supplementary ioctl interface.3*4* Copyright 1998 by Werner Cornelius ([email protected])5*6* This software may be used and distributed according to the terms7* of the GNU General Public License, incorporated herein by reference.8*9*/1011#include <linux/ioctl.h>12#include <linux/types.h>1314/******************************************/15/* IOCTL codes for interface to user prog */16/******************************************/17#define DIVERT_IIOC_VERSION 0x01 /* actual version */18#define IIOCGETVER _IO('I', 1) /* get version of interface */19#define IIOCGETDRV _IO('I', 2) /* get driver number */20#define IIOCGETNAM _IO('I', 3) /* get driver name */21#define IIOCGETRULE _IO('I', 4) /* read one rule */22#define IIOCMODRULE _IO('I', 5) /* modify/replace a rule */23#define IIOCINSRULE _IO('I', 6) /* insert/append one rule */24#define IIOCDELRULE _IO('I', 7) /* delete a rule */25#define IIOCDODFACT _IO('I', 8) /* hangup/reject/alert/immediately deflect a call */26#define IIOCDOCFACT _IO('I', 9) /* activate control forwarding in PBX */27#define IIOCDOCFDIS _IO('I',10) /* deactivate control forwarding in PBX */28#define IIOCDOCFINT _IO('I',11) /* interrogate control forwarding in PBX */2930/*************************************/31/* states reported through interface */32/*************************************/33#define DEFLECT_IGNORE 0 /* ignore incoming call */34#define DEFLECT_REPORT 1 /* only report */35#define DEFLECT_PROCEED 2 /* deflect when externally triggered */36#define DEFLECT_ALERT 3 /* alert and deflect after delay */37#define DEFLECT_REJECT 4 /* reject immediately */38#define DIVERT_ACTIVATE 5 /* diversion activate */39#define DIVERT_DEACTIVATE 6 /* diversion deactivate */40#define DIVERT_REPORT 7 /* interrogation result */41#define DEFLECT_AUTODEL 255 /* only for internal use */4243#define DEFLECT_ALL_IDS 0xFFFFFFFF /* all drivers selected */4445typedef struct46{ ulong drvid; /* driver ids, bit mapped */47char my_msn[35]; /* desired msn, subaddr allowed */48char caller[35]; /* caller id, partial string with * + subaddr allowed */49char to_nr[35]; /* deflected to number incl. subaddress */50u_char si1,si2; /* service indicators, si1=bitmask, si1+2 0 = all */51u_char screen; /* screening: 0 = no info, 1 = info, 2 = nfo with nr */52u_char callopt; /* option for call handling:530 = all calls541 = only non waiting calls552 = only waiting calls */56u_char action; /* desired action:570 = don't report call -> ignore581 = report call, do not allow/proceed for deflection592 = report call, send proceed, wait max waittime secs603 = report call, alert and deflect after waittime614 = report call, reject immediately62actions 1-2 only take place if interface is opened63*/64u_char waittime; /* maximum wait time for proceeding */65} divert_rule;6667typedef union68{ int drv_version; /* return of driver version */69struct70{ int drvid; /* id of driver */71char drvnam[30]; /* name of driver */72} getid;73struct74{ int ruleidx; /* index of rule */75divert_rule rule; /* rule parms */76} getsetrule;77struct78{ u_char subcmd; /* 0 = hangup/reject,791 = alert,802 = deflect */81ulong callid; /* id of call delivered by ascii output */82char to_nr[35]; /* destination when deflect,83else uus1 string (maxlen 31),84data from rule used if empty */85} fwd_ctrl;86struct87{ int drvid; /* id of driver */88u_char cfproc; /* cfu = 0, cfb = 1, cfnr = 2 */89ulong procid; /* process id returned when no error */90u_char service; /* basically coded service, 0 = all */91char msn[25]; /* desired msn, empty = all */92char fwd_nr[35];/* forwarded to number + subaddress */93} cf_ctrl;94} divert_ioctl;9596#ifdef __KERNEL__9798#include <linux/isdnif.h>99#include <linux/isdn_divertif.h>100101#define AUTODEL_TIME 30 /* timeout in s to delete internal entries */102103/**************************************************/104/* structure keeping ascii info for device output */105/**************************************************/106struct divert_info107{ struct divert_info *next;108ulong usage_cnt; /* number of files still to work */109char info_start[2]; /* info string start */110};111112113/**************/114/* Prototypes */115/**************/116extern spinlock_t divert_lock;117118extern ulong if_used; /* number of interface users */119extern int divert_dev_deinit(void);120extern int divert_dev_init(void);121extern void put_info_buffer(char *);122extern int ll_callback(isdn_ctrl *);123extern isdn_divert_if divert_if;124extern divert_rule *getruleptr(int);125extern int insertrule(int, divert_rule *);126extern int deleterule(int);127extern void deleteprocs(void);128extern int deflect_extern_action(u_char, ulong, char *);129extern int cf_command(int, int, u_char, char *, u_char, char *, ulong *);130131#endif /* __KERNEL__ */132133134