yf2825_sm.c 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. #include "plt.h"
  2. #include "yf2825_comm.h"
  3. #include "yf2825.h"
  4. #include "yf2825_sm.h"
  5. static struct state_t yf2825_states[] = {
  6. { SMST_LAUNCH, "launch" },
  7. { SMST_READY, "ready" },
  8. { SMST_ERR, "err" },
  9. };
  10. static struct err_t yf2825_errs[] = {
  11. { YF2825_NONE, "none" },
  12. // launch
  13. { YF2825_LAUNCH_COMMERR, "launch, comm err" },
  14. // err
  15. { YF2825_ERR_COMMERR, "err comm err" },
  16. // ready
  17. { YF2825_READY_COMMERR, "ready comm err" },
  18. };
  19. int yf2825_sm_init(int idx)
  20. {
  21. struct statemachine_t* sm = &yf2825[idx].sm;
  22. sm_reset_timing(sm, 1, 1);
  23. sm->states = yf2825_states;
  24. sm->state_nbr = sizeof(yf2825_states)/sizeof(struct state_t);
  25. sm->errs = yf2825_errs;
  26. sm->err_nbr = sizeof(yf2825_errs)/sizeof(struct err_t);
  27. sm_set_state( sm, SMST_LAUNCH, YF2825_NONE );
  28. return 0;
  29. }
  30. static void yf2825_sm_launch( int idx )
  31. {
  32. struct yf2825_t* dev = &yf2825[idx];
  33. struct comm_t* comm = &dev->comm;
  34. struct statemachine_t* sm = &dev->sm;
  35. if( sm_get_step(sm) == 0 ){ // entry
  36. log_dbg("%s, idx:%d, state:%s, step:%d, entry", __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  37. yf2825_reset_cmd(idx);
  38. yf2825_comm_reset(idx);
  39. sm_set_step(sm, 20);
  40. }
  41. /*
  42. if( sm_get_step(sm) == 0 ){ // entry
  43. log_dbg("%s, idx:%d, state:%s, step:%d, entry", __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  44. yf2825_reset_cmd(idx);
  45. sm_set_step(sm, 10);
  46. }else if( sm_get_step(sm) == 10){ // wait cmd
  47. if( yf2825_get_cmd(idx) == CMD_SM_READY){
  48. log_dbg("%s, idx:%d, state:%s, step:%d, get ready cmd, try to comm",
  49. __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  50. yf2825_reset_cmd(idx);
  51. yf2825_comm_reset(idx);
  52. sm_set_step(sm, 20);
  53. }
  54. }*/else if( sm_get_step(sm) == 20){ // chk comm state
  55. if( comm_get_state(comm) == COMMST_NORMAL){
  56. log_dbg("%s, idx:%d, state:%s, step:%d, comm ok, goto ready",
  57. __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  58. sm_set_state(sm, SMST_READY, YF2825_NONE);
  59. }else{
  60. log_dbg("%s, idx:%d, state:%s, step:%d, comm err, goto err",
  61. __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  62. sm_set_state(sm, SMST_ERR, YF2825_LAUNCH_COMMERR);
  63. }
  64. }
  65. }
  66. static void yf2825_sm_err( int idx )
  67. {
  68. struct yf2825_t* dev = &yf2825[idx];
  69. struct comm_t* comm = &dev->comm;
  70. struct statemachine_t* sm = &dev->sm;
  71. static double ts_last_try;
  72. double ts;
  73. if( sm_get_step(sm) == 0 ){ // entry
  74. yf2825_reset_cmd(idx);
  75. sm_set_step(sm, 10);
  76. ts_last_try = sm_get_timeofday();
  77. }else if( sm_get_step(sm) == 10){ // wait cmd
  78. ts = sm_get_timeofday();
  79. if( yf2825_get_cmd(idx) == CMD_SM_READY){
  80. log_dbg("%s, idx:%d, state:%s, step:%d, get ready cmd, try to comm",
  81. __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  82. yf2825_reset_cmd(idx);
  83. yf2825_comm_reset(idx);
  84. sm_set_step(sm, 20);
  85. }else if( ts - ts_last_try > 60000 ){ // 60s
  86. ts_last_try = ts;
  87. yf2825_comm_reset(idx);
  88. sm_set_step(sm, 20);
  89. }
  90. }else if( sm_get_step(sm) == 20){ // chk comm state
  91. if( comm_get_state(comm) == COMMST_NORMAL){
  92. log_dbg("%s, idx:%d, state:%s, step:%d, comm ok, goto ready", __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  93. sm_set_state(sm, SMST_READY, YF2825_NONE);
  94. }else{
  95. log_dbg("%s, idx:%d, state:%s, step:%d, comm err, stay err", __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  96. sm_set_state(sm, SMST_ERR, YF2825_ERR_COMMERR);
  97. }
  98. }
  99. }
  100. static void yf2825_sm_ready( int idx )
  101. {
  102. struct yf2825_t* dev = &yf2825[idx];
  103. struct comm_t* comm = &dev->comm;
  104. struct statemachine_t* sm = &dev->sm;
  105. /* chk comm state */
  106. if( comm_get_state(comm) != COMMST_NORMAL){
  107. log_dbg("%s, idx:%d, state:%s, step:%d, comm err detected, goto err",
  108. __func__, idx, sm_get_szstate(sm), sm_get_step(sm));
  109. sm_set_state(sm, SMST_ERR, YF2825_READY_COMMERR);
  110. return;
  111. }
  112. }
  113. void* yf2825_sm( int idx )
  114. {
  115. struct yf2825_t* dev = &yf2825[idx];
  116. struct statemachine_t* sm = &dev->sm;
  117. sm_cal_timing(sm);
  118. switch( sm_get_state(sm) ){
  119. case SMST_LAUNCH:
  120. yf2825_sm_launch( idx );
  121. break;
  122. case SMST_READY:
  123. yf2825_sm_ready( idx );
  124. break;
  125. case SMST_ERR:
  126. yf2825_sm_err( idx );
  127. break;
  128. default:
  129. log_dbg("%s unknown state : %d",__func__, sm_get_state(sm));
  130. break;
  131. }
  132. }