/* * 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