measurement_and_switch.c 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. #include <stdio.h>
  2. #define SCPI_ARGS_N_C 1
  3. #define SCPI_ARGS_N_Q 0
  4. #include "app/scpi/scpi_handler.h"
  5. const uint8_t fsqvbl_CommandHandlerMeasurementInternalTemperature = 1; // MEASurement:TEMPerature:INTernal
  6. const uint8_t fsqvbl_CommandHandlerMeasurementExternalTemperature = 2; // MEASurement:TEMPerature:EXTernal
  7. const uint8_t fsqvbl_CommandHandlerMeasurementTempCoefficient = 3; // MEASurement:TEMPerature:TCOEfficient
  8. const uint8_t fsqvbl_CommandHandlerAmpSwitchCount = 4; // GAIN:COUNt
  9. const uint8_t fsqvbl_CommandHandlerAmpSwitchList = 5; // GAIN:LIST
  10. const uint8_t fsqvbl_CommandHandlerFiltSwitchCount = 6; // FILT:COUNT
  11. const uint8_t fsqvbl_CommandHandlerFiltSwitchList = 7; // FILT:LIST
  12. // -----
  13. // @argTypesCommand
  14. // Declare argument parser entities for command form
  15. // Supported arguments: 1=NUMERIC
  16. DECLARE_SCPI_ARGS_C( eScpiArg_Numeric );
  17. // -----
  18. // @argTypesQuery
  19. // Declare argument parser entities for query form
  20. // Supported arguments: 0
  21. DECLARE_SCPI_ARGS_Q();
  22. DECLARE_ARGUMENT_NUMERIC_VALUES_I32(AllowedValues_BCoefficient, 0, 9999);
  23. #include "app/scpi/commandHandlers/measurement_and_switch.h"
  24. #include "app/nfm/nfm_base.h"
  25. // Refer to:
  26. // [1] SCPI Specification, revision 1999.0
  27. // "Standard Commands for Programmable Instruments (SCPI), VERSION 1999.0, May 1999"
  28. // [2] Gpib Programming Tutorial, (http://g2pc1.bu.edu/~qzpeng/gpib/manual/GpibProgTut.pdf)
  29. // Electronics Group (http://www.few.vu.nl/~elec), 11 January 2000 Electronics Group
  30. // [3] IEEE 488.2 Standard, revision IEEE Std 488.2-1987 (1992)
  31. // "IEEE Standard Codes, Formats, Protocols, and Common Commands for Use With IEEE Std 488.1-1987, IEEE
  32. // =================================================================================
  33. // @fsqvbl_CommandHandlerMEASnSWITCH_group
  34. // State's virtual table
  35. static void fsqe_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this, tFSeqCtx_t ctx );
  36. static void fsql_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this, tFSeqCtx_t ctx );
  37. static const struct fFSeqEntry_t * fsqf_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this, tFSeqCtx_t ctx, const struct fFSeqEntry_t * * pDeferredNext );
  38. const fFSeqVTable_t fsqvbl_CommandHandlerMEASnSWITCH_group =
  39. {
  40. .f = fsqf_CommandHandlerMeasurement_Switch_Group,
  41. .enter = fsqe_CommandHandlerMeasurement_Switch_Group,
  42. .leave = fsql_CommandHandlerMeasurement_Switch_Group
  43. };
  44. static void fsqe_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this, tFSeqCtx_t ctx )
  45. {
  46. sProcessProgramDataCommonContext_t * common_ctx = ctx;
  47. common_ctx->MeasAndSwitch.idx = 0;
  48. SCPI_PARSE_ARGUMENTS( common_ctx ); (void)common_ctx->argsParserStatus; // status is modified
  49. }
  50. static void fsql_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this, tFSeqCtx_t ctx )
  51. {
  52. }
  53. static const struct fFSeqEntry_t * fsqf_CommandHandlerMeasurement_Switch_Group( const struct fFSeqEntry_t * this,
  54. tFSeqCtx_t ctx,
  55. const struct fFSeqEntry_t * * pDeferredNext )
  56. {
  57. const fFSeqEntry_t * nextstate = NULL;
  58. sProcessProgramDataCommonContext_t * common_ctx = ctx;
  59. sScpiParserContext_t * global_ctx = common_ctx->global_ctx;
  60. switch( common_ctx->event )
  61. {
  62. case eProgramData_Event_Write:
  63. {
  64. if( eScpiStatus_success != common_ctx->argsParserStatus ) // check argument parser status
  65. {
  66. common_ctx->status = eProgramDataArgumentSyntax; // parameter syntax error, caller should generate error message
  67. }
  68. else if( ! common_ctx->isQuery )
  69. {
  70. common_ctx->status = eProgramDataIllegalArgument; // forward set, illegal parameter value, caller should generate error message
  71. if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerMeasurementTempCoefficient )
  72. {
  73. const sNumericEntry_t * ne = SCPI_PROCESS_ARGUMENT_NUMERIC(common_ctx, &AllowedValues_BCoefficient, 0);
  74. if( NULL != ne )
  75. switch( ne->error )
  76. {
  77. case ScpiNumericSuccess:
  78. {
  79. NFMClass->methods.tempCoefficient.setTempCoeff(ne->Value.demicalInteger);
  80. common_ctx->status = eProgramDataDone;
  81. }
  82. break;
  83. // -------- processed by SCPI_PROCESS_ARGUMENT_NUMERIC ----
  84. // "11.5.1.1.5", [3]
  85. // "10.10.6 Error Handling", [3]
  86. // "<...> An out-of-range integer shall cause an Execution Error, see 11.5.1.1.5. <...>"
  87. case ScpiNumericError_DEVICE_RANGE: // the value is out of range supported by device
  88. case ScpiNumericError_USER_RANGE: // the value is out of user specified range: // the value is out of range supported by device
  89. case ScpiNumericError_USER_TYPE: // the value does not match to the user expectation
  90. case ScpiNumericInvalidArg: // forbidden case: design bug
  91. case ScpiNumericError: // generic numeric conversion error
  92. break;
  93. // --------------------------------------------------------
  94. }
  95. }
  96. }
  97. else
  98. {
  99. common_ctx->status = eProgramDataNeedRead; // request processed, wait for reading...
  100. (void)nextstate; // stay in this state
  101. }
  102. }
  103. break;
  104. case eProgramData_Event_Read:
  105. {
  106. // @idx - current position of the source data to be outputed
  107. if( common_ctx->MeasAndSwitch.idx == 0 ) // first reading
  108. {
  109. size_t length = 0;
  110. if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerMeasurementInternalTemperature )
  111. {
  112. float temp = NFMClass->methods.getAverageTemperature();
  113. length = _snprintf( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer), "%.3f", temp);
  114. }
  115. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerMeasurementExternalTemperature )
  116. {
  117. float temp = NFMClass->methods.getAverageExtTemperature();
  118. length = _snprintf( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer), "%.3f", temp);
  119. }
  120. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerMeasurementTempCoefficient )
  121. {
  122. uint16_t temp_coeff = 0;
  123. NFMClass->methods.tempCoefficient.getTempCoeff(&temp_coeff);
  124. length = _snprintf( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer), "%d", temp_coeff );
  125. }
  126. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerAmpSwitchCount )
  127. {
  128. length = 0;//_snprintf( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer), "%d", NFMClass->properties.allowedAmpStatesCount );
  129. }
  130. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerAmpSwitchList )
  131. {
  132. length = NFMClass->methods.getAmpStateList( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer) );
  133. }
  134. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerFiltSwitchCount )
  135. {
  136. length = 0; //_snprintf( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer), "%d", NFMClass->properties.allowedFiltStatesCount );
  137. }
  138. else if( common_ctx->handler_ctx == &fsqvbl_CommandHandlerFiltSwitchList )
  139. {
  140. length = NFMClass->methods.getFilterStateList( common_ctx->tempBuffer, sizeof(common_ctx->tempBuffer) );
  141. }
  142. if( length > 0 )
  143. {
  144. // place null-terminator in the end of line
  145. common_ctx->tempBuffer[length] = '\0';
  146. }
  147. else
  148. {
  149. fsq_RaiseError( SCPI_ERROR_INTERNAL_DEVICE,
  150. SCPI_ERROR_INTERNAL_DEVICE_MSG,
  151. global_ctx->sParser.xHandlerToken.shead,
  152. global_ctx->sParser.xHandlerToken.stail );
  153. common_ctx->status = eProgramData_SpecificError; // specific error already generated
  154. break;
  155. }
  156. }
  157. // Since @done flag is set, this dispatcher shall not be called anymore.
  158. // Since this handler is implemented as a single-state automat, there no
  159. // ... other states to go to:
  160. (void)nextstate;
  161. // modify current postion index:
  162. SCPI_RESPONSE_HELPER( common_ctx, common_ctx->MeasAndSwitch.idx );
  163. }
  164. break;
  165. }
  166. return nextstate;
  167. }