factory.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. #include "factory.h"
  2. #include "bsp/bsp_driver.h"
  3. #include "prot/can_message.h"
  4. #include "prot/can_foc_msg.h"
  5. #include "foc/samples.h"
  6. #include "foc/motor/current.h"
  7. #include "foc/motor/motor.h"
  8. #include "libs/utils.h"
  9. #include "libs/logger.h"
  10. #include "os/os_task.h"
  11. static u8 factory_mode = 0;
  12. static void stop_pwm_adc(void);
  13. static bool start_pwm_adc(void) {
  14. pwm_turn_on_low_side();
  15. delay_ms(10);
  16. phase_current_offset_calibrate();
  17. pwm_start();
  18. delay_us(10);
  19. get_motor()->b_start = true;
  20. adc_start_convert();
  21. phase_current_calibrate_wait();
  22. if (phase_curr_offset_check()) {
  23. stop_pwm_adc();
  24. return false;
  25. }
  26. return true;
  27. }
  28. static void stop_pwm_adc(void) {
  29. u32 mask = cpu_enter_critical();
  30. adc_stop_convert();
  31. pwm_stop();
  32. pwm_up_enable(true);
  33. get_motor()->b_start = false;
  34. cpu_exit_critical(mask);
  35. }
  36. void can_process_factory_message(can_message_t *can_message){
  37. uint8_t response[32];
  38. uint8_t rsplen;
  39. encoder_can_key(response, can_message->key);
  40. response[2] = 0;
  41. rsplen = 3;
  42. switch(can_message->key) {
  43. case BUILD_CMD_KEY(0xE0):
  44. factory_mode = decode_u8(can_message->data);
  45. break;
  46. case BUILD_CMD_KEY(0xE1):
  47. {
  48. if (!factory_is_running()) {
  49. response[2] = 1;
  50. break;
  51. }
  52. u8 item = decode_u8(can_message->data);
  53. if (item == 1) { //3相驱动测试
  54. u8 duty = decode_u8((u8 *)can_message->data + 1);
  55. pwm_3phase_sides(true, 0);
  56. u16 duty_time = (u16)((float)duty * FOC_PWM_Half_Period / 100.0f);
  57. pwm_update_duty(duty_time, duty_time, duty_time);
  58. }else if (item == 2) {//获取所有电压的采集值
  59. can_response_vols(can_message->src, can_message->key);
  60. return;
  61. }else if (item == 3) { //读取gpio状态
  62. encode_u16(response + 3, gpio_get_pin_values());
  63. rsplen += 4;
  64. }else if (item == 4) { // u phase detect
  65. int count = 20;
  66. float uvw[3] = {0, 0, 0};
  67. s16 uvw_total[3] = {0, 0, 0};
  68. if (can_message->len < 2) {
  69. response[2] = 2; //长度错误
  70. break;
  71. }
  72. u8 detect = decode_u8((u8 *)can_message->data + 1);
  73. gpio_phase_u_detect(detect?true:false);
  74. while(count-- > 0) {
  75. delay_us(100);
  76. get_uvw_phases_raw(uvw);
  77. uvw_total[0] += (s16)(uvw[0] * 100);
  78. uvw_total[1] += (s16)(uvw[1] * 100);
  79. uvw_total[2] += (s16)(uvw[2] * 100);
  80. }
  81. encode_u16(response + 3, uvw_total[0]/20);
  82. encode_u16(response + 5, uvw_total[1]/20);
  83. encode_u16(response + 7, uvw_total[2]/20);
  84. gpio_phase_u_detect(false);
  85. rsplen += 6;
  86. }else if (item == 5) { //phase current test
  87. u8 start = decode_u8((u8 *)can_message->data + 1);
  88. if (start == 1) {
  89. pwm_3phase_sides(true, 0); //use pwm output, disable timer break in
  90. if (!start_pwm_adc()) {
  91. response[2] = 1;
  92. break;
  93. }
  94. }else if (start == 0){
  95. stop_pwm_adc();
  96. pwm_3phase_init();
  97. }else {
  98. s16 ui = (s16)mot_contrl()->foc.in.curr_abc[0];
  99. s16 vi = (s16)mot_contrl()->foc.in.curr_abc[1];
  100. s16 wi = (s16)mot_contrl()->foc.in.curr_abc[2];
  101. encode_s16(response + 3, ui);
  102. encode_s16(response + 5, ui);
  103. encode_s16(response + 7, ui);
  104. rsplen += 6;
  105. }
  106. }
  107. break;
  108. }
  109. default:
  110. rsplen = 0;
  111. break;
  112. }
  113. if (rsplen > 0) {
  114. can_send_response(can_message->src, response, rsplen);
  115. }
  116. }
  117. bool factory_is_running(void) {
  118. return (factory_mode == 0x5A);
  119. }