You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
365 lines
10 KiB
365 lines
10 KiB
/* $Id: capi.h,v 1.6.6.2 2001/09/23 22:24:32 kai Exp $
|
|
*
|
|
* ISDN lowlevel-module for the IBM ISDN-S0 Active 2000.
|
|
*
|
|
* Author Fritz Elfert
|
|
* Copyright by Fritz Elfert <fritz@isdn4linux.de>
|
|
*
|
|
* This software may be used and distributed according to the terms
|
|
* of the GNU General Public License, incorporated herein by reference.
|
|
*
|
|
* Thanks to Friedemann Baitinger and IBM Germany
|
|
*
|
|
*/
|
|
|
|
#ifndef CAPI_H
|
|
#define CAPI_H
|
|
|
|
/* Command-part of a CAPI message */
|
|
typedef struct actcapi_msgcmd {
|
|
__u8 cmd;
|
|
__u8 subcmd;
|
|
} actcapi_msgcmd;
|
|
|
|
/* CAPI message header */
|
|
typedef struct actcapi_msghdr {
|
|
__u16 len;
|
|
__u16 applicationID;
|
|
actcapi_msgcmd cmd;
|
|
__u16 msgnum;
|
|
} actcapi_msghdr;
|
|
|
|
/* CAPI message description (for debugging) */
|
|
typedef struct actcapi_msgdsc {
|
|
actcapi_msgcmd cmd;
|
|
char *description;
|
|
} actcapi_msgdsc;
|
|
|
|
/* CAPI Address */
|
|
typedef struct actcapi_addr {
|
|
__u8 len; /* Length of element */
|
|
__u8 tnp; /* Type/Numbering Plan */
|
|
__u8 num[20]; /* Caller ID */
|
|
} actcapi_addr;
|
|
|
|
/* CAPI INFO element mask */
|
|
typedef union actcapi_infonr { /* info number */
|
|
__u16 mask; /* info-mask field */
|
|
struct bmask { /* bit definitions */
|
|
unsigned codes : 3; /* code set */
|
|
unsigned rsvd : 5; /* reserved */
|
|
unsigned svind : 1; /* single, variable length ind. */
|
|
unsigned wtype : 7; /* W-element type */
|
|
} bmask;
|
|
} actcapi_infonr;
|
|
|
|
/* CAPI INFO element */
|
|
typedef union actcapi_infoel { /* info element */
|
|
__u8 len; /* length of info element */
|
|
__u8 display[40]; /* display contents */
|
|
__u8 uuinfo[40]; /* User-user info field */
|
|
struct cause { /* Cause information */
|
|
unsigned ext2 : 1; /* extension */
|
|
unsigned cod : 2; /* coding standard */
|
|
unsigned spare : 1; /* spare */
|
|
unsigned loc : 4; /* location */
|
|
unsigned ext1 : 1; /* extension */
|
|
unsigned cval : 7; /* Cause value */
|
|
} cause;
|
|
struct charge { /* Charging information */
|
|
__u8 toc; /* type of charging info */
|
|
__u8 unit[10]; /* charging units */
|
|
} charge;
|
|
__u8 date[20]; /* date fields */
|
|
__u8 stat; /* state of remote party */
|
|
} actcapi_infoel;
|
|
|
|
/* Message for EAZ<->MSN Mapping */
|
|
typedef struct actcapi_msn {
|
|
__u8 eaz;
|
|
__u8 len; /* Length of MSN */
|
|
__u8 msn[15];
|
|
} __attribute__((packed)) actcapi_msn;
|
|
|
|
typedef struct actcapi_dlpd {
|
|
__u8 len; /* Length of structure */
|
|
__u16 dlen; /* Data Length */
|
|
__u8 laa; /* Link Address A */
|
|
__u8 lab; /* Link Address B */
|
|
__u8 modulo; /* Modulo Mode */
|
|
__u8 win; /* Window size */
|
|
__u8 xid[100]; /* XID Information */
|
|
} __attribute__((packed)) actcapi_dlpd;
|
|
|
|
typedef struct actcapi_ncpd {
|
|
__u8 len; /* Length of structure */
|
|
__u16 lic;
|
|
__u16 hic;
|
|
__u16 ltc;
|
|
__u16 htc;
|
|
__u16 loc;
|
|
__u16 hoc;
|
|
__u8 modulo;
|
|
} __attribute__((packed)) actcapi_ncpd;
|
|
#define actcapi_ncpi actcapi_ncpd
|
|
|
|
/*
|
|
* Layout of NCCI field in a B3 DATA CAPI message is different from
|
|
* standard at act2000:
|
|
*
|
|
* Bit 0-4 = PLCI
|
|
* Bit 5-7 = Controller
|
|
* Bit 8-15 = NCCI
|
|
*/
|
|
#define MAKE_NCCI(plci,contr,ncci) \
|
|
((plci & 0x1f) | ((contr & 0x7) << 5) | ((ncci & 0xff) << 8))
|
|
|
|
#define EVAL_NCCI(fakencci,plci,contr,ncci) { \
|
|
plci = fakencci & 0x1f; \
|
|
contr = (fakencci >> 5) & 0x7; \
|
|
ncci = (fakencci >> 8) & 0xff; \
|
|
}
|
|
|
|
/*
|
|
* Layout of PLCI field in a B3 DATA CAPI message is different from
|
|
* standard at act2000:
|
|
*
|
|
* Bit 0-4 = PLCI
|
|
* Bit 5-7 = Controller
|
|
* Bit 8-15 = reserved (must be 0)
|
|
*/
|
|
#define MAKE_PLCI(plci,contr) \
|
|
((plci & 0x1f) | ((contr & 0x7) << 5))
|
|
|
|
#define EVAL_PLCI(fakeplci,plci,contr) { \
|
|
plci = fakeplci & 0x1f; \
|
|
contr = (fakeplci >> 5) & 0x7; \
|
|
}
|
|
|
|
typedef struct actcapi_msg {
|
|
actcapi_msghdr hdr;
|
|
union {
|
|
__u16 manuf_msg;
|
|
struct manufacturer_req_net {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
__u8 nettype;
|
|
} manufacturer_req_net;
|
|
struct manufacturer_req_v42 {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
__u32 v42control;
|
|
} manufacturer_req_v42;
|
|
struct manufacturer_conf_v42 {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
} manufacturer_conf_v42;
|
|
struct manufacturer_req_err {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
} manufacturer_req_err;
|
|
struct manufacturer_ind_err {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
__u32 errcode;
|
|
__u8 errstring; /* actually up to 160 */
|
|
} manufacturer_ind_err;
|
|
struct manufacturer_req_msn {
|
|
__u16 manuf_msg;
|
|
__u16 controller;
|
|
actcapi_msn msnmap;
|
|
} __attribute ((packed)) manufacturer_req_msn;
|
|
/* TODO: TraceInit-req/conf/ind/resp and
|
|
* TraceDump-req/conf/ind/resp
|
|
*/
|
|
struct connect_req {
|
|
__u8 controller;
|
|
__u8 bchan;
|
|
__u32 infomask;
|
|
__u8 si1;
|
|
__u8 si2;
|
|
__u8 eaz;
|
|
actcapi_addr addr;
|
|
} __attribute__ ((packed)) connect_req;
|
|
struct connect_conf {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} connect_conf;
|
|
struct connect_ind {
|
|
__u16 plci;
|
|
__u8 controller;
|
|
__u8 si1;
|
|
__u8 si2;
|
|
__u8 eaz;
|
|
actcapi_addr addr;
|
|
} __attribute__ ((packed)) connect_ind;
|
|
struct connect_resp {
|
|
__u16 plci;
|
|
__u8 rejectcause;
|
|
} connect_resp;
|
|
struct connect_active_ind {
|
|
__u16 plci;
|
|
actcapi_addr addr;
|
|
} __attribute__ ((packed)) connect_active_ind;
|
|
struct connect_active_resp {
|
|
__u16 plci;
|
|
} connect_active_resp;
|
|
struct connect_b3_req {
|
|
__u16 plci;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) connect_b3_req;
|
|
struct connect_b3_conf {
|
|
__u16 plci;
|
|
__u16 ncci;
|
|
__u16 info;
|
|
} connect_b3_conf;
|
|
struct connect_b3_ind {
|
|
__u16 ncci;
|
|
__u16 plci;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) connect_b3_ind;
|
|
struct connect_b3_resp {
|
|
__u16 ncci;
|
|
__u8 rejectcause;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) connect_b3_resp;
|
|
struct disconnect_req {
|
|
__u16 plci;
|
|
__u8 cause;
|
|
} disconnect_req;
|
|
struct disconnect_conf {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} disconnect_conf;
|
|
struct disconnect_ind {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} disconnect_ind;
|
|
struct disconnect_resp {
|
|
__u16 plci;
|
|
} disconnect_resp;
|
|
struct connect_b3_active_ind {
|
|
__u16 ncci;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) connect_b3_active_ind;
|
|
struct connect_b3_active_resp {
|
|
__u16 ncci;
|
|
} connect_b3_active_resp;
|
|
struct disconnect_b3_req {
|
|
__u16 ncci;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) disconnect_b3_req;
|
|
struct disconnect_b3_conf {
|
|
__u16 ncci;
|
|
__u16 info;
|
|
} disconnect_b3_conf;
|
|
struct disconnect_b3_ind {
|
|
__u16 ncci;
|
|
__u16 info;
|
|
actcapi_ncpi ncpi;
|
|
} __attribute__ ((packed)) disconnect_b3_ind;
|
|
struct disconnect_b3_resp {
|
|
__u16 ncci;
|
|
} disconnect_b3_resp;
|
|
struct info_ind {
|
|
__u16 plci;
|
|
actcapi_infonr nr;
|
|
actcapi_infoel el;
|
|
} __attribute__ ((packed)) info_ind;
|
|
struct info_resp {
|
|
__u16 plci;
|
|
} info_resp;
|
|
struct listen_b3_req {
|
|
__u16 plci;
|
|
} listen_b3_req;
|
|
struct listen_b3_conf {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} listen_b3_conf;
|
|
struct select_b2_protocol_req {
|
|
__u16 plci;
|
|
__u8 protocol;
|
|
actcapi_dlpd dlpd;
|
|
} __attribute__ ((packed)) select_b2_protocol_req;
|
|
struct select_b2_protocol_conf {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} select_b2_protocol_conf;
|
|
struct select_b3_protocol_req {
|
|
__u16 plci;
|
|
__u8 protocol;
|
|
actcapi_ncpd ncpd;
|
|
} __attribute__ ((packed)) select_b3_protocol_req;
|
|
struct select_b3_protocol_conf {
|
|
__u16 plci;
|
|
__u16 info;
|
|
} select_b3_protocol_conf;
|
|
struct listen_req {
|
|
__u8 controller;
|
|
__u32 infomask;
|
|
__u16 eazmask;
|
|
__u16 simask;
|
|
} __attribute__ ((packed)) listen_req;
|
|
struct listen_conf {
|
|
__u8 controller;
|
|
__u16 info;
|
|
} __attribute__ ((packed)) listen_conf;
|
|
struct data_b3_req {
|
|
__u16 fakencci;
|
|
__u16 datalen;
|
|
__u32 unused;
|
|
__u8 blocknr;
|
|
__u16 flags;
|
|
} __attribute ((packed)) data_b3_req;
|
|
struct data_b3_ind {
|
|
__u16 fakencci;
|
|
__u16 datalen;
|
|
__u32 unused;
|
|
__u8 blocknr;
|
|
__u16 flags;
|
|
} __attribute__ ((packed)) data_b3_ind;
|
|
struct data_b3_resp {
|
|
__u16 ncci;
|
|
__u8 blocknr;
|
|
} __attribute__ ((packed)) data_b3_resp;
|
|
struct data_b3_conf {
|
|
__u16 ncci;
|
|
__u8 blocknr;
|
|
__u16 info;
|
|
} __attribute__ ((packed)) data_b3_conf;
|
|
} msg;
|
|
} __attribute__ ((packed)) actcapi_msg;
|
|
|
|
static inline unsigned short
|
|
actcapi_nextsmsg(act2000_card *card)
|
|
{
|
|
unsigned long flags;
|
|
unsigned short n;
|
|
|
|
spin_lock_irqsave(&card->mnlock, flags);
|
|
n = card->msgnum;
|
|
card->msgnum++;
|
|
card->msgnum &= 0x7fff;
|
|
spin_unlock_irqrestore(&card->mnlock, flags);
|
|
return n;
|
|
}
|
|
#define DEBUG_MSG
|
|
#undef DEBUG_DATA_MSG
|
|
#undef DEBUG_DUMP_SKB
|
|
|
|
extern int actcapi_chkhdr(act2000_card *, actcapi_msghdr *);
|
|
extern int actcapi_listen_req(act2000_card *);
|
|
extern int actcapi_manufacturer_req_net(act2000_card *);
|
|
extern int actcapi_manufacturer_req_errh(act2000_card *);
|
|
extern int actcapi_manufacturer_req_msn(act2000_card *);
|
|
extern int actcapi_connect_req(act2000_card *, act2000_chan *, char *, char, int, int);
|
|
extern void actcapi_select_b2_protocol_req(act2000_card *, act2000_chan *);
|
|
extern void actcapi_disconnect_b3_req(act2000_card *, act2000_chan *);
|
|
extern void actcapi_connect_resp(act2000_card *, act2000_chan *, __u8);
|
|
extern void actcapi_dispatch(struct work_struct *);
|
|
#ifdef DEBUG_MSG
|
|
extern void actcapi_debug_msg(struct sk_buff *skb, int);
|
|
#else
|
|
#define actcapi_debug_msg(skb, len)
|
|
#endif
|
|
#endif
|
|
|