ibRsp.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. /***************************************************************************
  2. lib/ibRsp.c
  3. -------------------
  4. copyright : (C) 2001,2002,2003 by Frank Mori Hess
  5. email : fmhess@users.sourceforge.net
  6. ***************************************************************************/
  7. /***************************************************************************
  8. * *
  9. * This program is free software; you can redistribute it and/or modify *
  10. * it under the terms of the GNU General Public License as published by *
  11. * the Free Software Foundation; either version 2 of the License, or *
  12. * (at your option) any later version. *
  13. * *
  14. ***************************************************************************/
  15. #include "ib_internal.h"
  16. static int serial_poll( ibBoard_t *board, unsigned int pad, int sad,
  17. unsigned int usec_timeout, char *result )
  18. {
  19. serial_poll_ioctl_t poll_cmd;
  20. int retval;
  21. poll_cmd.pad = pad;
  22. poll_cmd.sad = sad;
  23. set_timeout( board, usec_timeout );
  24. retval = ioctl( board->fileno, IBRSP, &poll_cmd );
  25. if(retval < 0)
  26. {
  27. switch( errno )
  28. {
  29. case ETIMEDOUT:
  30. setIberr( EABO );
  31. break;
  32. case EPIPE:
  33. setIberr( ESTB );
  34. break;
  35. default:
  36. setIberr( EDVR );
  37. setIbcnt( errno );
  38. break;
  39. }
  40. return -1;
  41. }
  42. *result = poll_cmd.status_byte;
  43. return 0;
  44. }
  45. int ibrsp(int ud, char *spr)
  46. {
  47. ibConf_t *conf;
  48. ibBoard_t *board;
  49. int retval;
  50. conf = enter_library( ud );
  51. if( conf == NULL )
  52. return exit_library( ud, 1 );
  53. if( conf->is_interface )
  54. {
  55. setIberr( EARG );
  56. return exit_library( ud, 1 );
  57. }
  58. board = interfaceBoard( conf );
  59. retval = serial_poll( board, conf->settings.pad, conf->settings.sad,
  60. conf->settings.spoll_usec_timeout, spr );
  61. if(retval < 0)
  62. {
  63. if( errno == ETIMEDOUT )
  64. conf->timed_out = 1;
  65. return exit_library( ud, 1 );
  66. }
  67. return exit_library( ud, 0 );
  68. }
  69. void AllSPoll( int boardID, const Addr4882_t addressList[], short resultList[] )
  70. {
  71. int i;
  72. ibConf_t *conf;
  73. ibBoard_t *board;
  74. int retval;
  75. conf = enter_library( boardID );
  76. if( conf == NULL )
  77. {
  78. exit_library( boardID, 1 );
  79. return;
  80. }
  81. if( addressListIsValid( addressList ) == 0 )
  82. {
  83. exit_library( boardID, 1 );
  84. return;
  85. }
  86. if( conf->is_interface == 0 )
  87. {
  88. setIberr( EDVR );
  89. exit_library( boardID, 1 );
  90. return;
  91. }
  92. board = interfaceBoard( conf );
  93. if( is_cic( board ) == 0 )
  94. {
  95. setIberr( ECIC );
  96. exit_library( boardID, 1 );
  97. return;
  98. }
  99. // XXX could use slightly more efficient ALLSPOLL protocol
  100. retval = 0;
  101. for( i = 0; i < numAddresses( addressList ); i++ )
  102. {
  103. char result;
  104. retval = serial_poll( board, extractPAD( addressList[ i ] ),
  105. extractSAD( addressList[ i ] ), conf->settings.spoll_usec_timeout, &result );
  106. if( retval < 0 )
  107. {
  108. if( errno == ETIMEDOUT )
  109. conf->timed_out = 1;
  110. break;
  111. }
  112. resultList[ i ] = result & 0xff;
  113. }
  114. setIbcnt( i );
  115. if( retval < 0 ) exit_library( boardID, 1 );
  116. else exit_library( boardID, 0 );
  117. }
  118. void AllSpoll( int boardID, const Addr4882_t addressList[], short resultList[] )
  119. {
  120. AllSPoll( boardID, addressList, resultList );
  121. }
  122. void FindRQS( int boardID, const Addr4882_t addressList[], short *result )
  123. {
  124. int i;
  125. ibConf_t *conf;
  126. ibBoard_t *board;
  127. int retval;
  128. conf = enter_library( boardID );
  129. if( conf == NULL )
  130. {
  131. exit_library( boardID, 1 );
  132. return;
  133. }
  134. if( addressListIsValid( addressList ) == 0 )
  135. {
  136. exit_library( boardID, 1 );
  137. return;
  138. }
  139. if( conf->is_interface == 0 )
  140. {
  141. setIberr( EDVR );
  142. exit_library( boardID, 1 );
  143. return;
  144. }
  145. board = interfaceBoard( conf );
  146. if( is_cic( board ) == 0 )
  147. {
  148. setIberr( ECIC );
  149. exit_library( boardID, 1 );
  150. return;
  151. }
  152. retval = 0;
  153. for( i = 0; i < numAddresses( addressList ); i++ )
  154. {
  155. char spoll_byte;
  156. retval = serial_poll( board, extractPAD( addressList[ i ] ),
  157. extractSAD( addressList[ i ] ), conf->settings.usec_timeout, &spoll_byte );
  158. if( retval < 0 )
  159. {
  160. if( errno == ETIMEDOUT )
  161. conf->timed_out = 1;
  162. break;
  163. }
  164. if( spoll_byte & request_service_bit )
  165. {
  166. *result = spoll_byte & 0xff;
  167. break;
  168. }
  169. }
  170. setIbcnt( i );
  171. if( i == numAddresses( addressList ) )
  172. {
  173. setIberr( ETAB );
  174. retval = -1;
  175. }
  176. if( retval < 0 ) exit_library( boardID, 1 );
  177. else exit_library( boardID, 0 );
  178. }
  179. void ReadStatusByte( int boardID, Addr4882_t address, short *result )
  180. {
  181. ibConf_t *conf;
  182. ibBoard_t *board;
  183. char byte_result;
  184. int retval;
  185. conf = enter_library( boardID );
  186. if( conf == NULL )
  187. {
  188. exit_library( boardID, 1 );
  189. return;
  190. }
  191. if( addressIsValid( address ) == 0 )
  192. {
  193. exit_library( boardID, 1 );
  194. return;
  195. }
  196. if( conf->is_interface == 0 )
  197. {
  198. setIberr( EDVR );
  199. exit_library( boardID, 1 );
  200. return;
  201. }
  202. board = interfaceBoard( conf );
  203. if( is_cic( board ) == 0 )
  204. {
  205. setIberr( ECIC );
  206. exit_library( boardID, 1 );
  207. return;
  208. }
  209. retval = serial_poll( board, extractPAD( address ),
  210. extractSAD( address ), conf->settings.spoll_usec_timeout, &byte_result );
  211. if( retval < 0 )
  212. {
  213. if( errno == ETIMEDOUT )
  214. conf->timed_out = 1;
  215. exit_library( boardID, 1 );
  216. return;
  217. }
  218. *result = byte_result & 0xff;
  219. exit_library( boardID, 0 );
  220. }