| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  Copyright (c) Eicon Networks, 2002. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  This source file is supplied for the use with | 
					
						
							|  |  |  |  Eicon Networks range of DIVA Server Adapters. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  Eicon File Revision :    2.1 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  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. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  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. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |  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. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | #ifndef __DIVA_SYNC__H
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define __DIVA_SYNC__H
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_REMOVE             0x00
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_NAME           0x01
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_SERIAL         0x02
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_SET_POSTCALL       0x03
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_XLOG           0x04
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_FEATURES       0x05
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_REGISTER       0x06
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_RELEASE        0x07
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_ADD_DEVICE     0x08
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_START_DEVICE   0x09
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_STOP_DEVICE    0x0A
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_REMOVE_DEVICE  0x0B
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_CARDTYPE       0x0C
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_DBG_XLOG       0x0D
 | 
					
						
							|  |  |  | #define DIVA_USB
 | 
					
						
							|  |  |  | #define DIVA_USB_REQ                    0xAC
 | 
					
						
							|  |  |  | #define DIVA_USB_TEST                   0xAB
 | 
					
						
							|  |  |  | #define DIVA_USB_ADD_ADAPTER            0xAC
 | 
					
						
							|  |  |  | #define DIVA_USB_REMOVE_ADAPTER         0xAD
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_SERIAL_HOOK        0x80
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XCHANGE_STATUS     0x81
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_USB_HOOK           0x82
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_PORTDRV_HOOK       0x83
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_SLI                0x84   /*  SLI request from 3signal modem drivers */
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_RECONFIGURE        0x85
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_RESET              0x86
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_85X_DEVICE_DATA     0x87
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_LOCK_85X                   0x88
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIVA_85X_USB_DATA_EXCHANGE 0x99
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIPORT_EXCHANGE_REQ   0x98
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_GET_85X_EXT_PORT_TYPE      0xA0
 | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XDI_GET_EXTENDED_FEATURES  0x92
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |   To receive XDI features: | 
					
						
							|  |  |  |   1. set 'buffer_length_in_bytes' to length of you buffer | 
					
						
							|  |  |  |   2. set 'features' to pointer to your buffer | 
					
						
							|  |  |  |   3. issue synchronous request to XDI | 
					
						
							|  |  |  |   4. Check that feature 'DIVA_XDI_EXTENDED_FEATURES_VALID' is present | 
					
						
							|  |  |  |   after call. This feature does indicate that your request | 
					
						
							|  |  |  |   was processed and XDI does support this synchronous request | 
					
						
							|  |  |  |   5. if on return bit 31 (0x80000000) in 'buffer_length_in_bytes' is | 
					
						
							|  |  |  |   set then provided buffer was too small, and bits 30-0 does | 
					
						
							|  |  |  |   contain necessary length of buffer. | 
					
						
							|  |  |  |   in this case only features that do find place in the buffer | 
					
						
							|  |  |  |   are indicated to caller | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | */ | 
					
						
							|  |  |  | typedef struct _diva_xdi_get_extended_xdi_features { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	dword buffer_length_in_bytes; | 
					
						
							|  |  |  | 	byte  *features; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_get_extended_xdi_features_t; | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  |   features[0] | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define DIVA_XDI_EXTENDED_FEATURES_VALID          0x01
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_CMA             0x02
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_SDRAM_BAR       0x04
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_CAPI_PRMS       0x08
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_NO_CANCEL_RC    0x10
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_RX_DMA          0x20
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_MANAGEMENT_DMA  0x40
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURE_WIDE_ID         0x80
 | 
					
						
							|  |  |  | #define DIVA_XDI_EXTENDED_FEATURES_MAX_SZ    1
 | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XDI_GET_ADAPTER_SDRAM_BAR   0x93
 | 
					
						
							|  |  |  | typedef struct _diva_xdi_get_adapter_sdram_bar { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	dword bar; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_get_adapter_sdram_bar_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XDI_GET_CAPI_PARAMS   0x94
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   CAPI Parameters will be written in the caller's buffer | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | typedef struct _diva_xdi_get_capi_parameters { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	dword structure_length; | 
					
						
							|  |  |  | 	byte flag_dynamic_l1_down; | 
					
						
							|  |  |  | 	byte group_optimization_enabled; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_get_capi_parameters_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XDI_GET_LOGICAL_ADAPTER_NUMBER   0x95
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Get logical adapter number, as assigned by XDI | 
					
						
							|  |  |  |   'controller' is starting with zero 'sub' controller number | 
					
						
							|  |  |  |   in case of one adapter that supports multiple interfaces | 
					
						
							|  |  |  |   'controller' is zero for Master adapter (and adapter that supports | 
					
						
							|  |  |  |   only one interface) | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | typedef struct _diva_xdi_get_logical_adapter_number { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	dword logical_adapter_number; | 
					
						
							|  |  |  | 	dword controller; | 
					
						
							|  |  |  | 	dword total_controllers; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_get_logical_adapter_number_s_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_UP1DM_OPERATION   0x96
 | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DMA_DESCRIPTOR_OPERATION 0x97
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DMA_DESCRIPTOR_ALLOC     0x01
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DMA_DESCRIPTOR_FREE      0x02
 | 
					
						
							|  |  |  | typedef struct _diva_xdi_dma_descriptor_operation { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	int operation; | 
					
						
							|  |  |  | 	int descriptor_number; | 
					
						
							|  |  |  | 	void *descriptor_address; | 
					
						
							|  |  |  | 	dword descriptor_magic; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_dma_descriptor_operation_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_REGISTER_ADAPTER_NOTIFY   0x01
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_REMOVE_ADAPTER_NOTIFY     0x02
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_ADD_ADAPTER               0x03
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_REMOVE_ADAPTER            0x04
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_READ_ADAPTER_ARRAY        0x05
 | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_DIDD_GET_CFG_LIB_IFC           0x10
 | 
					
						
							|  |  |  | typedef struct _diva_didd_adapter_notify { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	dword handle; /* Notification handle */ | 
					
						
							|  |  |  | 	void *callback; | 
					
						
							|  |  |  | 	void *context; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_didd_adapter_notify_t; | 
					
						
							|  |  |  | typedef struct _diva_didd_add_adapter { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	void *descriptor; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_didd_add_adapter_t; | 
					
						
							|  |  |  | typedef struct _diva_didd_remove_adapter { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	IDI_CALL p_request; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_didd_remove_adapter_t; | 
					
						
							|  |  |  | typedef struct _diva_didd_read_adapter_array { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	void *buffer; | 
					
						
							|  |  |  | 	dword length; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_didd_read_adapter_array_t; | 
					
						
							|  |  |  | typedef struct _diva_didd_get_cfg_lib_ifc { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	void *ifc; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_didd_get_cfg_lib_ifc_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | #define IDI_SYNC_REQ_XDI_GET_STREAM    0x91
 | 
					
						
							|  |  |  | #define DIVA_XDI_SYNCHRONOUS_SERVICE   0x01
 | 
					
						
							|  |  |  | #define DIVA_XDI_DMA_SERVICE           0x02
 | 
					
						
							|  |  |  | #define DIVA_XDI_AUTO_SERVICE          0x03
 | 
					
						
							|  |  |  | #define DIVA_ISTREAM_COMPLETE_NOTIFY   0
 | 
					
						
							|  |  |  | #define DIVA_ISTREAM_COMPLETE_READ     1
 | 
					
						
							|  |  |  | #define DIVA_ISTREAM_COMPLETE_WRITE    2
 | 
					
						
							|  |  |  | typedef struct _diva_xdi_stream_interface { | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char  Id;                 /* filled by XDI client */ | 
					
						
							|  |  |  | 	unsigned char provided_service;    /* filled by XDI        */ | 
					
						
							|  |  |  | 	unsigned char requested_service;   /* filled by XDI Client */ | 
					
						
							|  |  |  | 	void *xdi_context;    /* filled by XDI */ | 
					
						
							|  |  |  | 	void *client_context;   /* filled by XDI client */ | 
					
						
							|  |  |  | 	int (*write)(void *context, | 
					
						
							|  |  |  | 		     int Id, | 
					
						
							|  |  |  | 		     void *data, | 
					
						
							|  |  |  | 		     int length, | 
					
						
							|  |  |  | 		     int final, | 
					
						
							|  |  |  | 		     byte usr1, | 
					
						
							|  |  |  | 		     byte usr2); | 
					
						
							|  |  |  | 	int (*read)(void *context, | 
					
						
							|  |  |  | 		    int Id, | 
					
						
							|  |  |  | 		    void *data, | 
					
						
							|  |  |  | 		    int max_length, | 
					
						
							|  |  |  | 		    int *final, | 
					
						
							|  |  |  | 		    byte *usr1, | 
					
						
							|  |  |  | 		    byte *usr2); | 
					
						
							|  |  |  | 	int (*complete)(void *client_context, | 
					
						
							|  |  |  | 			int Id, | 
					
						
							|  |  |  | 			int what, | 
					
						
							|  |  |  | 			void *data, | 
					
						
							|  |  |  | 			int length, | 
					
						
							|  |  |  | 			int *final); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } diva_xdi_stream_interface_t; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * IDI_SYNC_REQ_SERIAL_HOOK - special interface for the DIVA Mobile card | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct | 
					
						
							|  |  |  | { unsigned char LineState;         /* Modem line state (STATUS_R) */ | 
					
						
							|  |  |  | #define SERIAL_GSM_CELL 0x01   /* GSM or CELL cable attached  */
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char CardState;          /* PCMCIA card state (0 = down) */ | 
					
						
							|  |  |  | 	unsigned char IsdnState;          /* ISDN layer 1 state (0 = down)*/ | 
					
						
							|  |  |  | 	unsigned char HookState;          /* current logical hook state */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define SERIAL_ON_HOOK 0x02   /* set in DIVA CTRL_R register */
 | 
					
						
							|  |  |  | } SERIAL_STATE; | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | typedef int (*SERIAL_INT_CB)(void *Context); | 
					
						
							|  |  |  | typedef int (*SERIAL_DPC_CB)(void *Context); | 
					
						
							|  |  |  | typedef unsigned char (*SERIAL_I_SYNC)(void *Context); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | typedef struct | 
					
						
							|  |  |  | { /* 'Req' and 'Rc' must be at the same place as in the ENTITY struct */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char Req;             /* request (must be always 0) */ | 
					
						
							|  |  |  | 	unsigned char Rc;              /* return code (is the request) */ | 
					
						
							|  |  |  | 	unsigned char Function;           /* private function code  */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define SERIAL_HOOK_ATTACH 0x81
 | 
					
						
							|  |  |  | #define SERIAL_HOOK_STATUS 0x82
 | 
					
						
							|  |  |  | #define SERIAL_HOOK_I_SYNC 0x83
 | 
					
						
							|  |  |  | #define SERIAL_HOOK_NOECHO 0x84
 | 
					
						
							|  |  |  | #define SERIAL_HOOK_RING 0x85
 | 
					
						
							|  |  |  | #define SERIAL_HOOK_DETACH 0x8f
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char Flags;           /* function refinements   */ | 
					
						
							|  |  |  | 	/* parameters passed by the ATTACH request      */ | 
					
						
							|  |  |  | 	SERIAL_INT_CB InterruptHandler; /* called on each interrupt  */ | 
					
						
							|  |  |  | 	SERIAL_DPC_CB DeferredHandler; /* called on hook state changes */ | 
					
						
							|  |  |  | 	void   *HandlerContext; /* context for both handlers */ | 
					
						
							|  |  |  | 	/* return values for both the ATTACH and the STATUS request   */ | 
					
						
							|  |  |  | 	unsigned long IoBase;    /* IO port assigned to UART  */ | 
					
						
							|  |  |  | 	SERIAL_STATE State; | 
					
						
							|  |  |  | 	/* parameters and return values for the I_SYNC function    */ | 
					
						
							|  |  |  | 	SERIAL_I_SYNC SyncFunction;  /* to be called synchronized */ | 
					
						
							|  |  |  | 	void   *SyncContext;  /* context for this function */ | 
					
						
							|  |  |  | 	unsigned char SyncResult;   /* return value of function  */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } SERIAL_HOOK; | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * IDI_SYNC_REQ_XCHANGE_STATUS - exchange the status between IDI and WMP | 
					
						
							|  |  |  |  * IDI_SYNC_REQ_RECONFIGURE - reconfiguration of IDI from WMP | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct | 
					
						
							|  |  |  | { /* 'Req' and 'Rc' must be at the same place as in the ENTITY struct */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char Req;             /* request (must be always 0) */ | 
					
						
							|  |  |  | 	unsigned char Rc;              /* return code (is the request) */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define DRIVER_STATUS_BOOT  0xA1
 | 
					
						
							|  |  |  | #define DRIVER_STATUS_INIT_DEV 0xA2
 | 
					
						
							|  |  |  | #define DRIVER_STATUS_RUNNING 0xA3
 | 
					
						
							|  |  |  | #define DRIVER_STATUS_SHUTDOWN 0xAF
 | 
					
						
							|  |  |  | #define DRIVER_STATUS_TRAPPED 0xAE
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char wmpStatus;          /* exported by WMP              */ | 
					
						
							|  |  |  | 	unsigned char idiStatus;   /* exported by IDI              */ | 
					
						
							|  |  |  | 	unsigned long wizProto;   /* from WMP registry to IDI     */ | 
					
						
							|  |  |  | 	/* the cardtype value is defined by cardtype.h */ | 
					
						
							|  |  |  | 	unsigned long cardType;   /* from IDI registry to WMP     */ | 
					
						
							|  |  |  | 	unsigned long nt2;    /* from IDI registry to WMP     */ | 
					
						
							|  |  |  | 	unsigned long permanent;   /* from IDI registry to WMP     */ | 
					
						
							|  |  |  | 	unsigned long stableL2;   /* from IDI registry to WMP     */ | 
					
						
							|  |  |  | 	unsigned long tei;    /* from IDI registry to WMP     */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define CRC4_MASK   0x00000003
 | 
					
						
							|  |  |  | #define L1_TRISTATE_MASK 0x00000004
 | 
					
						
							|  |  |  | #define WATCHDOG_MASK  0x00000008
 | 
					
						
							|  |  |  | #define NO_ORDER_CHECK_MASK 0x00000010
 | 
					
						
							|  |  |  | #define LOW_CHANNEL_MASK 0x00000020
 | 
					
						
							|  |  |  | #define NO_HSCX30_MASK  0x00000040
 | 
					
						
							|  |  |  | #define SET_BOARD   0x00001000
 | 
					
						
							|  |  |  | #define SET_CRC4   0x00030000
 | 
					
						
							|  |  |  | #define SET_L1_TRISTATE  0x00040000
 | 
					
						
							|  |  |  | #define SET_WATCHDOG  0x00080000
 | 
					
						
							|  |  |  | #define SET_NO_ORDER_CHECK 0x00100000
 | 
					
						
							|  |  |  | #define SET_LOW_CHANNEL  0x00200000
 | 
					
						
							|  |  |  | #define SET_NO_HSCX30  0x00400000
 | 
					
						
							|  |  |  | #define SET_MODE   0x00800000
 | 
					
						
							|  |  |  | #define SET_PROTO   0x02000000
 | 
					
						
							|  |  |  | #define SET_CARDTYPE  0x04000000
 | 
					
						
							|  |  |  | #define SET_NT2    0x08000000
 | 
					
						
							|  |  |  | #define SET_PERMANENT  0x10000000
 | 
					
						
							|  |  |  | #define SET_STABLEL2  0x20000000
 | 
					
						
							|  |  |  | #define SET_TEI    0x40000000
 | 
					
						
							|  |  |  | #define SET_NUMBERLEN  0x80000000
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned long Flag;  /* |31-Type-16|15-Mask-0| */ | 
					
						
							|  |  |  | 	unsigned long NumberLen; /* reconfiguration: union is empty */ | 
					
						
							|  |  |  | 	union { | 
					
						
							|  |  |  | 		struct {    /* possible reconfiguration, but ... ; SET_BOARD */ | 
					
						
							|  |  |  | 			unsigned long SerialNumber; | 
					
						
							|  |  |  | 			char     *pCardname; /* di_defs.h: BOARD_NAME_LENGTH */ | 
					
						
							|  |  |  | 		} board; | 
					
						
							|  |  |  | 		struct {      /* reset: need resources */ | 
					
						
							|  |  |  | 			void *pRawResources; | 
					
						
							|  |  |  | 			void *pXlatResources; | 
					
						
							|  |  |  | 		} res; | 
					
						
							|  |  |  | 		struct { /* reconfiguration: wizProto == PROTTYPE_RBSCAS */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define GLARE_RESOLVE_MASK 0x00000001
 | 
					
						
							|  |  |  | #define DID_MASK   0x00000002
 | 
					
						
							|  |  |  | #define BEARER_CAP_MASK  0x0000000c
 | 
					
						
							|  |  |  | #define SET_GLARE_RESOLVE 0x00010000
 | 
					
						
							|  |  |  | #define SET_DID    0x00020000
 | 
					
						
							|  |  |  | #define SET_BEARER_CAP  0x000c0000
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 			unsigned long Flag;  /* |31-Type-16|15-VALUE-0| */ | 
					
						
							|  |  |  | 			unsigned short DigitTimeout; | 
					
						
							|  |  |  | 			unsigned short AnswerDelay; | 
					
						
							|  |  |  | 		} rbs; | 
					
						
							|  |  |  | 		struct { /* reconfiguration: wizProto == PROTTYPE_QSIG */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define CALL_REF_LENGTH1_MASK 0x00000001
 | 
					
						
							|  |  |  | #define BRI_CHANNEL_ID_MASK  0x00000002
 | 
					
						
							|  |  |  | #define SET_CALL_REF_LENGTH  0x00010000
 | 
					
						
							|  |  |  | #define SET_BRI_CHANNEL_ID  0x00020000
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 			unsigned long Flag;  /* |31-Type-16|15-VALUE-0| */ | 
					
						
							|  |  |  | 		} qsig; | 
					
						
							|  |  |  | 		struct { /* reconfiguration: NumberLen != 0 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #define SET_SPID1   0x00010000
 | 
					
						
							|  |  |  | #define SET_NUMBER1   0x00020000
 | 
					
						
							|  |  |  | #define SET_SUBADDRESS1  0x00040000
 | 
					
						
							|  |  |  | #define SET_SPID2   0x00100000
 | 
					
						
							|  |  |  | #define SET_NUMBER2   0x00200000
 | 
					
						
							|  |  |  | #define SET_SUBADDRESS2  0x00400000
 | 
					
						
							|  |  |  | #define MASK_SET   0xffff0000
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 			unsigned long Flag;   /* |31-Type-16|15-Channel-0| */ | 
					
						
							|  |  |  | 			unsigned char *pBuffer; /* number value */ | 
					
						
							|  |  |  | 		} isdnNo; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 		parms | 
					
						
							|  |  |  | 		; | 
					
						
							|  |  |  | } isdnProps; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * IDI_SYNC_REQ_PORTDRV_HOOK - signal plug/unplug (Award Cardware only) | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | typedef void (*PORTDRV_HOOK_CB)(void *Context, int Plug); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | typedef struct | 
					
						
							|  |  |  | { /* 'Req' and 'Rc' must be at the same place as in the ENTITY struct */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char Req;             /* request (must be always 0) */ | 
					
						
							|  |  |  | 	unsigned char Rc;              /* return code (is the request) */ | 
					
						
							|  |  |  | 	unsigned char Function;           /* private function code  */ | 
					
						
							|  |  |  | 	unsigned char Flags;           /* function refinements   */ | 
					
						
							|  |  |  | 	PORTDRV_HOOK_CB Callback;   /* to be called on plug/unplug */ | 
					
						
							|  |  |  | 	void   *Context;   /* context for callback   */ | 
					
						
							|  |  |  | 	unsigned long Info;    /* more info if needed   */ | 
					
						
							|  |  |  | } PORTDRV_HOOK; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*  Codes for the 'Rc' element in structure below. */ | 
					
						
							|  |  |  | #define SLI_INSTALL     (0xA1)
 | 
					
						
							|  |  |  | #define SLI_UNINSTALL   (0xA2)
 | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | typedef int (*SLIENTRYPOINT)(void *p3SignalAPI, void *pContext); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | typedef struct | 
					
						
							|  |  |  | {   /* 'Req' and 'Rc' must be at the same place as in the ENTITY struct */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	unsigned char   Req;                /* request (must be always 0)   */ | 
					
						
							|  |  |  | 	unsigned char   Rc;                 /* return code (is the request) */ | 
					
						
							|  |  |  | 	unsigned char   Function;           /* private function code        */ | 
					
						
							|  |  |  | 	unsigned char   Flags;              /* function refinements         */ | 
					
						
							|  |  |  | 	SLIENTRYPOINT   Callback;           /* to be called on plug/unplug  */ | 
					
						
							|  |  |  | 	void            *Context;           /* context for callback         */ | 
					
						
							|  |  |  | 	unsigned long   Info;               /* more info if needed          */ | 
					
						
							|  |  |  | } SLIENTRYPOINT_REQ; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  Definitions for DIVA USB | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | typedef int (*USB_SEND_REQ)(unsigned char PipeIndex, unsigned char Type, void *Data, int sizeData); | 
					
						
							|  |  |  | typedef int (*USB_START_DEV)(void *Adapter, void *Ipac); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* called from WDM */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | typedef void (*USB_RECV_NOTIFY)(void *Ipac, void *msg); | 
					
						
							|  |  |  | typedef void (*USB_XMIT_NOTIFY)(void *Ipac, unsigned char PipeIndex); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /******************************************************************************/ | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Parameter description for synchronous requests. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Sorry, must repeat some parts of di_defs.h here because | 
					
						
							|  |  |  |  * they are not defined for all operating environments | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef union | 
					
						
							|  |  |  | { ENTITY Entity; | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	struct | 
					
						
							|  |  |  | 	{ /* 'Req' and 'Rc' are at the same place as in the ENTITY struct */ | 
					
						
							|  |  |  | 		unsigned char   Req; /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char   Rc;  /* return code (is the request) */ | 
					
						
							|  |  |  | 	}   Request; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char   Req; /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char   Rc;  /* return code (0x01)   */ | 
					
						
							|  |  |  | 		unsigned char   name[BOARD_NAME_LENGTH]; | 
					
						
							|  |  |  | 	}   GetName; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char   Req; /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char   Rc;  /* return code (0x02)   */ | 
					
						
							|  |  |  | 		unsigned long   serial; /* serial number    */ | 
					
						
							|  |  |  | 	}   GetSerial; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char   Req; /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char   Rc;  /* return code (0x02)   */ | 
					
						
							|  |  |  | 		unsigned long   lineIdx;/* line, 0 if card has only one */ | 
					
						
							|  |  |  | 	}   GetLineIdx; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char  Req;     /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char  Rc;      /* return code (0x02)   */ | 
					
						
							|  |  |  | 		unsigned long  cardtype;/* card type        */ | 
					
						
							|  |  |  | 	}   GetCardType; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned short command;/* command = 0x0300 */ | 
					
						
							|  |  |  | 		unsigned short dummy; /* not used */ | 
					
						
							|  |  |  | 		IDI_CALL       callback;/* routine to call back */ | 
					
						
							|  |  |  | 		ENTITY      *contxt; /* ptr to entity to use */ | 
					
						
							|  |  |  | 	}   PostCall; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char  Req;  /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char  Rc;   /* return code (0x04)   */ | 
					
						
							|  |  |  | 		unsigned char  pcm[1]; /* buffer (a pc_maint struct) */ | 
					
						
							|  |  |  | 	}   GetXlog; | 
					
						
							|  |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char  Req;  /* request (must be always 0) */ | 
					
						
							|  |  |  | 		unsigned char  Rc;   /* return code (0x05)   */ | 
					
						
							|  |  |  | 		unsigned short features;/* feature defines see below */ | 
					
						
							|  |  |  | 	}   GetFeatures; | 
					
						
							|  |  |  | 	SERIAL_HOOK  SerialHook; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* Added for DIVA USB */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char   Req; | 
					
						
							|  |  |  | 		unsigned char   Rc; | 
					
						
							|  |  |  | 		USB_SEND_REQ    UsbSendRequest; /* function in Diva Usb WDM driver in usb_os.c, */ | 
					
						
							|  |  |  | 		/* called from usb_drv.c to send a message to our device */ | 
					
						
							|  |  |  | 		/* eg UsbSendRequest (USB_PIPE_SIGNAL, USB_IPAC_START, 0, 0); */ | 
					
						
							|  |  |  | 		USB_RECV_NOTIFY usb_recv;       /* called from usb_os.c to pass a received message and ptr to IPAC */ | 
					
						
							|  |  |  | 		/* on to usb_drv.c by a call to usb_recv(). */ | 
					
						
							|  |  |  | 		USB_XMIT_NOTIFY usb_xmit;       /* called from usb_os.c in DivaUSB.sys WDM to indicate a completed transmit */ | 
					
						
							|  |  |  | 		/* to usb_drv.c by a call to usb_xmit(). */ | 
					
						
							|  |  |  | 		USB_START_DEV   UsbStartDevice; /* Start the USB Device, in usb_os.c */ | 
					
						
							|  |  |  | 		IDI_CALL        callback;       /* routine to call back */ | 
					
						
							|  |  |  | 		ENTITY          *contxt;     /* ptr to entity to use */ | 
					
						
							|  |  |  | 		void **ipac_ptr;    /* pointer to struct IPAC in VxD */ | 
					
						
							|  |  |  | 	} Usb_Msg_old; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* message used by WDM and VXD to pass pointers of function and IPAC* */ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | 	struct | 
					
						
							|  |  |  | 	{ unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		USB_SEND_REQ    pUsbSendRequest;/* function in Diva Usb WDM driver in usb_os.c, */ | 
					
						
							|  |  |  | 		/* called from usb_drv.c to send a message to our device */ | 
					
						
							|  |  |  | 		/* eg UsbSendRequest (USB_PIPE_SIGNAL, USB_IPAC_START, 0, 0); */ | 
					
						
							|  |  |  | 		USB_RECV_NOTIFY p_usb_recv;     /* called from usb_os.c to pass a received message and ptr to IPAC */ | 
					
						
							|  |  |  | 		/* on to usb_drv.c by a call to usb_recv(). */ | 
					
						
							|  |  |  | 		USB_XMIT_NOTIFY p_usb_xmit;     /* called from usb_os.c in DivaUSB.sys WDM to indicate a completed transmit */ | 
					
						
							|  |  |  | 		/* to usb_drv.c by a call to usb_xmit().*/ | 
					
						
							|  |  |  | 		void            *ipac_ptr;      /* &Diva.ipac pointer to struct IPAC in VxD */ | 
					
						
							|  |  |  | 	} Usb_Msg; | 
					
						
							|  |  |  | 	PORTDRV_HOOK PortdrvHook; | 
					
						
							|  |  |  | 	SLIENTRYPOINT_REQ   sliEntryPointReq; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_stream_interface_t info; | 
					
						
							|  |  |  | 	} xdi_stream_info; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_get_extended_xdi_features_t info; | 
					
						
							|  |  |  | 	} xdi_extended_features; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_get_adapter_sdram_bar_t info; | 
					
						
							|  |  |  | 	} xdi_sdram_bar; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_get_capi_parameters_t info; | 
					
						
							|  |  |  | 	} xdi_capi_prms; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		ENTITY           e; | 
					
						
							|  |  |  | 		diva_didd_adapter_notify_t info; | 
					
						
							|  |  |  | 	} didd_notify; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		ENTITY           e; | 
					
						
							|  |  |  | 		diva_didd_add_adapter_t   info; | 
					
						
							|  |  |  | 	} didd_add_adapter; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		ENTITY           e; | 
					
						
							|  |  |  | 		diva_didd_remove_adapter_t info; | 
					
						
							|  |  |  | 	} didd_remove_adapter; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		ENTITY             e; | 
					
						
							|  |  |  | 		diva_didd_read_adapter_array_t info; | 
					
						
							|  |  |  | 	} didd_read_adapter_array; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		ENTITY             e; | 
					
						
							|  |  |  | 		diva_didd_get_cfg_lib_ifc_t     info; | 
					
						
							|  |  |  | 	} didd_get_cfg_lib_ifc; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_get_logical_adapter_number_s_t info; | 
					
						
							|  |  |  | 	} xdi_logical_adapter_number; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char Req; | 
					
						
							|  |  |  | 		unsigned char Rc; | 
					
						
							|  |  |  | 		diva_xdi_dma_descriptor_operation_t info; | 
					
						
							|  |  |  | 	} xdi_dma_descriptor_operation; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } IDI_SYNC_REQ; | 
					
						
							|  |  |  | /******************************************************************************/ | 
					
						
							| 
									
										
										
										
											2012-02-19 19:52:38 -08:00
										 |  |  | #endif /* __DIVA_SYNC__H */
 |