123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- /*
- *
- Copyright (c) Eicon Networks, 2002.
- *
- This source file is supplied for the use with
- Eicon Networks range of DIVA Server Adapters.
- *
- Eicon File Revision : 2.1
- *
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2, or (at your option)
- any later version.
- *
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY OF ANY KIND WHATSOEVER INCLUDING ANY
- implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- See the GNU General Public License for more details.
- *
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- *
- */
- #ifndef _DI_DEFS_
- #define _DI_DEFS_
- /* typedefs for our data structures */
- typedef struct get_name_s GET_NAME;
- /* The entity_s structure is used to pass all
- parameters between application and IDI */
- typedef struct entity_s ENTITY;
- typedef struct buffers_s BUFFERS;
- typedef struct postcall_s POSTCALL;
- typedef struct get_para_s GET_PARA;
- #define BOARD_NAME_LENGTH 9
- #define IDI_CALL_LINK_T
- #define IDI_CALL_ENTITY_T
- /* typedef void ( * IDI_CALL)(ENTITY *); */
- /* --------------------------------------------------------
- IDI_CALL
- -------------------------------------------------------- */
- typedef void (IDI_CALL_LINK_T *IDI_CALL)(ENTITY IDI_CALL_ENTITY_T *);
- typedef struct {
- word length; /* length of data/parameter field */
- byte P[270]; /* data/parameter field */
- } DBUFFER;
- struct get_name_s {
- word command; /* command = 0x0100 */
- byte name[BOARD_NAME_LENGTH];
- };
- struct postcall_s {
- word command; /* command = 0x0300 */
- word dummy; /* not used */
- void (*callback)(void *); /* call back */
- void *context; /* context pointer */
- };
- #define REQ_PARA 0x0600 /* request command line parameters */
- #define REQ_PARA_LEN 1 /* number of data bytes */
- #define L1_STARTUP_DOWN_POS 0 /* '-y' command line parameter in......*/
- #define L1_STARTUP_DOWN_MSK 0x01 /* first byte position (index 0) with value 0x01 */
- struct get_para_s {
- word command; /* command = 0x0600 */
- byte len; /* max length of para field in bytes */
- byte para[REQ_PARA_LEN]; /* parameter field */
- };
- struct buffers_s {
- word PLength;
- byte *P;
- };
- struct entity_s {
- byte Req; /* pending request */
- byte Rc; /* return code received */
- byte Ind; /* indication received */
- byte ReqCh; /* channel of current Req */
- byte RcCh; /* channel of current Rc */
- byte IndCh; /* channel of current Ind */
- byte Id; /* ID used by this entity */
- byte GlobalId; /* reserved field */
- byte XNum; /* number of X-buffers */
- byte RNum; /* number of R-buffers */
- BUFFERS *X; /* pointer to X-buffer list */
- BUFFERS *R; /* pointer to R-buffer list */
- word RLength; /* length of current R-data */
- DBUFFER *RBuffer; /* buffer of current R-data */
- byte RNR; /* receive not ready flag */
- byte complete; /* receive complete status */
- IDI_CALL callback;
- word user[2];
- /* fields used by the driver internally */
- byte No; /* entity number */
- byte reserved2; /* reserved field */
- byte More; /* R/X More flags */
- byte MInd; /* MDATA coding for this ID */
- byte XCurrent; /* current transmit buffer */
- byte RCurrent; /* current receive buffer */
- word XOffset; /* offset in x-buffer */
- word ROffset; /* offset in r-buffer */
- };
- typedef struct {
- byte type;
- byte channels;
- word features;
- IDI_CALL request;
- } DESCRIPTOR;
- /* descriptor type field coding */
- #define IDI_ADAPTER_S 1
- #define IDI_ADAPTER_PR 2
- #define IDI_ADAPTER_DIVA 3
- #define IDI_ADAPTER_MAESTRA 4
- #define IDI_VADAPTER 0x40
- #define IDI_DRIVER 0x80
- #define IDI_DADAPTER 0xfd
- #define IDI_DIDDPNP 0xfe
- #define IDI_DIMAINT 0xff
- /* Hardware IDs ISA PNP */
- #define HW_ID_DIVA_PRO 3 /* same as IDI_ADAPTER_DIVA */
- #define HW_ID_MAESTRA 4 /* same as IDI_ADAPTER_MAESTRA */
- #define HW_ID_PICCOLA 5
- #define HW_ID_DIVA_PRO20 6
- #define HW_ID_DIVA20 7
- #define HW_ID_DIVA_PRO20_U 8
- #define HW_ID_DIVA20_U 9
- #define HW_ID_DIVA30 10
- #define HW_ID_DIVA30_U 11
- /* Hardware IDs PCI */
- #define HW_ID_EICON_PCI 0x1133
- #define HW_ID_SIEMENS_PCI 0x8001 /* unused SubVendor ID for Siemens Cornet-N cards */
- #define HW_ID_PROTTYPE_CORNETN 0x0014 /* SubDevice ID for Siemens Cornet-N cards */
- #define HW_ID_FUJITSU_SIEMENS_PCI 0x110A /* SubVendor ID for Fujitsu Siemens */
- #define HW_ID_GS03_PCI 0x0021 /* SubDevice ID for Fujitsu Siemens ISDN S0 card */
- #define HW_ID_DIVA_PRO20_PCI 0xe001
- #define HW_ID_DIVA20_PCI 0xe002
- #define HW_ID_DIVA_PRO20_PCI_U 0xe003
- #define HW_ID_DIVA20_PCI_U 0xe004
- #define HW_ID_DIVA201_PCI 0xe005
- #define HW_ID_DIVA_CT_ST 0xe006
- #define HW_ID_DIVA_CT_U 0xe007
- #define HW_ID_DIVA_CTL_ST 0xe008
- #define HW_ID_DIVA_CTL_U 0xe009
- #define HW_ID_DIVA_ISDN_V90_PCI 0xe00a
- #define HW_ID_DIVA202_PCI_ST 0xe00b
- #define HW_ID_DIVA202_PCI_U 0xe00c
- #define HW_ID_DIVA_PRO30_PCI 0xe00d
- #define HW_ID_MAESTRA_PCI 0xe010
- #define HW_ID_MAESTRAQ_PCI 0xe012
- #define HW_ID_DSRV_Q8M_V2_PCI 0xe013
- #define HW_ID_MAESTRAP_PCI 0xe014
- #define HW_ID_DSRV_P30M_V2_PCI 0xe015
- #define HW_ID_DSRV_VOICE_Q8M_PCI 0xe016
- #define HW_ID_DSRV_VOICE_Q8M_V2_PCI 0xe017
- #define HW_ID_DSRV_B2M_V2_PCI 0xe018
- #define HW_ID_DSRV_VOICE_P30M_V2_PCI 0xe019
- #define HW_ID_DSRV_B2F_PCI 0xe01a
- #define HW_ID_DSRV_VOICE_B2M_V2_PCI 0xe01b
- /* Hardware IDs USB */
- #define EICON_USB_VENDOR_ID 0x071D
- #define HW_ID_DIVA_USB_REV1 0x1000
- #define HW_ID_DIVA_USB_REV2 0x1003
- #define HW_ID_TELEDAT_SURF_USB_REV2 0x1004
- #define HW_ID_TELEDAT_SURF_USB_REV1 0x2000
- /* --------------------------------------------------------------------------
- Adapter array change notification framework
- -------------------------------------------------------------------------- */
- typedef void (IDI_CALL_LINK_T *didd_adapter_change_callback_t)(void IDI_CALL_ENTITY_T *context, DESCRIPTOR *adapter, int removal);
- /* -------------------------------------------------------------------------- */
- #define DI_VOICE 0x0 /* obsolete define */
- #define DI_FAX3 0x1
- #define DI_MODEM 0x2
- #define DI_POST 0x4
- #define DI_V110 0x8
- #define DI_V120 0x10
- #define DI_POTS 0x20
- #define DI_CODEC 0x40
- #define DI_MANAGE 0x80
- #define DI_V_42 0x0100
- #define DI_EXTD_FAX 0x0200 /* Extended FAX (ECM, 2D, T.6, Polling) */
- #define DI_AT_PARSER 0x0400 /* Build-in AT Parser in the L2 */
- #define DI_VOICE_OVER_IP 0x0800 /* Voice over IP support */
- typedef void (IDI_CALL_LINK_T *_IDI_CALL)(void *, ENTITY *);
- #endif
|