divasfunc.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. /* $Id: divasfunc.c,v 1.23.4.2 2004/08/28 20:03:53 armin Exp $
  2. *
  3. * Low level driver for Eicon DIVA Server ISDN cards.
  4. *
  5. * Copyright 2000-2003 by Armin Schindler (mac@melware.de)
  6. * Copyright 2000-2003 Cytronics & Melware (info@melware.de)
  7. *
  8. * This software may be used and distributed according to the terms
  9. * of the GNU General Public License, incorporated herein by reference.
  10. */
  11. #include "platform.h"
  12. #include "di_defs.h"
  13. #include "pc.h"
  14. #include "di.h"
  15. #include "io.h"
  16. #include "divasync.h"
  17. #include "diva.h"
  18. #include "xdi_vers.h"
  19. #define DBG_MINIMUM (DL_LOG + DL_FTL + DL_ERR)
  20. #define DBG_DEFAULT (DBG_MINIMUM + DL_XLOG + DL_REG)
  21. static int debugmask;
  22. extern void DIVA_DIDD_Read(void *, int);
  23. extern PISDN_ADAPTER IoAdapters[MAX_ADAPTER];
  24. extern char *DRIVERRELEASE_DIVAS;
  25. static dword notify_handle;
  26. static DESCRIPTOR DAdapter;
  27. static DESCRIPTOR MAdapter;
  28. /* --------------------------------------------------------------------------
  29. MAINT driver connector section
  30. -------------------------------------------------------------------------- */
  31. static void no_printf(unsigned char *x, ...)
  32. {
  33. /* dummy debug function */
  34. }
  35. #include "debuglib.c"
  36. /*
  37. * get the adapters serial number
  38. */
  39. void diva_get_vserial_number(PISDN_ADAPTER IoAdapter, char *buf)
  40. {
  41. int contr = 0;
  42. if ((contr = ((IoAdapter->serialNo & 0xff000000) >> 24))) {
  43. sprintf(buf, "%d-%d",
  44. IoAdapter->serialNo & 0x00ffffff, contr + 1);
  45. } else {
  46. sprintf(buf, "%d", IoAdapter->serialNo);
  47. }
  48. }
  49. /*
  50. * register a new adapter
  51. */
  52. void diva_xdi_didd_register_adapter(int card)
  53. {
  54. DESCRIPTOR d;
  55. IDI_SYNC_REQ req;
  56. if (card && ((card - 1) < MAX_ADAPTER) &&
  57. IoAdapters[card - 1] && Requests[card - 1]) {
  58. d.type = IoAdapters[card - 1]->Properties.DescType;
  59. d.request = Requests[card - 1];
  60. d.channels = IoAdapters[card - 1]->Properties.Channels;
  61. d.features = IoAdapters[card - 1]->Properties.Features;
  62. DBG_TRC(("DIDD register A(%d) channels=%d", card,
  63. d.channels))
  64. /* workaround for different Name in structure */
  65. strlcpy(IoAdapters[card - 1]->Name,
  66. IoAdapters[card - 1]->Properties.Name,
  67. sizeof(IoAdapters[card - 1]->Name));
  68. req.didd_remove_adapter.e.Req = 0;
  69. req.didd_add_adapter.e.Rc = IDI_SYNC_REQ_DIDD_ADD_ADAPTER;
  70. req.didd_add_adapter.info.descriptor = (void *) &d;
  71. DAdapter.request((ENTITY *) & req);
  72. if (req.didd_add_adapter.e.Rc != 0xff) {
  73. DBG_ERR(("DIDD register A(%d) failed !", card))
  74. }
  75. IoAdapters[card - 1]->os_trap_nfy_Fnc = NULL;
  76. }
  77. }
  78. /*
  79. * remove an adapter
  80. */
  81. void diva_xdi_didd_remove_adapter(int card)
  82. {
  83. IDI_SYNC_REQ req;
  84. ADAPTER *a = &IoAdapters[card - 1]->a;
  85. IoAdapters[card - 1]->os_trap_nfy_Fnc = NULL;
  86. DBG_TRC(("DIDD de-register A(%d)", card))
  87. req.didd_remove_adapter.e.Req = 0;
  88. req.didd_remove_adapter.e.Rc = IDI_SYNC_REQ_DIDD_REMOVE_ADAPTER;
  89. req.didd_remove_adapter.info.p_request =
  90. (IDI_CALL) Requests[card - 1];
  91. DAdapter.request((ENTITY *) & req);
  92. memset(&(a->IdTable), 0x00, 256);
  93. }
  94. /*
  95. * start debug
  96. */
  97. static void start_dbg(void)
  98. {
  99. DbgRegister("DIVAS", DRIVERRELEASE_DIVAS, (debugmask) ? debugmask : DBG_DEFAULT);
  100. DBG_LOG(("DIVA ISDNXDI BUILD (%s[%s]-%s-%s)",
  101. DIVA_BUILD, diva_xdi_common_code_build, __DATE__,
  102. __TIME__))
  103. }
  104. /*
  105. * stop debug
  106. */
  107. static void stop_dbg(void)
  108. {
  109. DbgDeregister();
  110. memset(&MAdapter, 0, sizeof(MAdapter));
  111. dprintf = no_printf;
  112. }
  113. /*
  114. * didd callback function
  115. */
  116. static void *didd_callback(void *context, DESCRIPTOR * adapter,
  117. int removal)
  118. {
  119. if (adapter->type == IDI_DADAPTER) {
  120. DBG_ERR(("Notification about IDI_DADAPTER change ! Oops."));
  121. return (NULL);
  122. }
  123. if (adapter->type == IDI_DIMAINT) {
  124. if (removal) {
  125. stop_dbg();
  126. } else {
  127. memcpy(&MAdapter, adapter, sizeof(MAdapter));
  128. dprintf = (DIVA_DI_PRINTF) MAdapter.request;
  129. start_dbg();
  130. }
  131. }
  132. return (NULL);
  133. }
  134. /*
  135. * connect to didd
  136. */
  137. static int DIVA_INIT_FUNCTION connect_didd(void)
  138. {
  139. int x = 0;
  140. int dadapter = 0;
  141. IDI_SYNC_REQ req;
  142. DESCRIPTOR DIDD_Table[MAX_DESCRIPTORS];
  143. DIVA_DIDD_Read(DIDD_Table, sizeof(DIDD_Table));
  144. for (x = 0; x < MAX_DESCRIPTORS; x++) {
  145. if (DIDD_Table[x].type == IDI_DADAPTER) { /* DADAPTER found */
  146. dadapter = 1;
  147. memcpy(&DAdapter, &DIDD_Table[x], sizeof(DAdapter));
  148. req.didd_notify.e.Req = 0;
  149. req.didd_notify.e.Rc =
  150. IDI_SYNC_REQ_DIDD_REGISTER_ADAPTER_NOTIFY;
  151. req.didd_notify.info.callback = (void *)didd_callback;
  152. req.didd_notify.info.context = NULL;
  153. DAdapter.request((ENTITY *) & req);
  154. if (req.didd_notify.e.Rc != 0xff) {
  155. stop_dbg();
  156. return (0);
  157. }
  158. notify_handle = req.didd_notify.info.handle;
  159. } else if (DIDD_Table[x].type == IDI_DIMAINT) { /* MAINT found */
  160. memcpy(&MAdapter, &DIDD_Table[x], sizeof(DAdapter));
  161. dprintf = (DIVA_DI_PRINTF) MAdapter.request;
  162. start_dbg();
  163. }
  164. }
  165. if (!dadapter) {
  166. stop_dbg();
  167. }
  168. return (dadapter);
  169. }
  170. /*
  171. * disconnect from didd
  172. */
  173. static void disconnect_didd(void)
  174. {
  175. IDI_SYNC_REQ req;
  176. stop_dbg();
  177. req.didd_notify.e.Req = 0;
  178. req.didd_notify.e.Rc = IDI_SYNC_REQ_DIDD_REMOVE_ADAPTER_NOTIFY;
  179. req.didd_notify.info.handle = notify_handle;
  180. DAdapter.request((ENTITY *) & req);
  181. }
  182. /*
  183. * init
  184. */
  185. int DIVA_INIT_FUNCTION divasfunc_init(int dbgmask)
  186. {
  187. char *version;
  188. debugmask = dbgmask;
  189. if (!connect_didd()) {
  190. DBG_ERR(("divasfunc: failed to connect to DIDD."))
  191. return (0);
  192. }
  193. version = diva_xdi_common_code_build;
  194. divasa_xdi_driver_entry();
  195. return (1);
  196. }
  197. /*
  198. * exit
  199. */
  200. void divasfunc_exit(void)
  201. {
  202. divasa_xdi_driver_unload();
  203. disconnect_didd();
  204. }