ZYHeLian.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796
  1. #include "global.h"
  2. #if ZHEN_YU_MACHINE
  3. void HL_InitAction(void);
  4. void HL_Action(void);
  5. void HL_SetAlarmCode(unsigned alarm_code);
  6. void HL_StartStopAction(void);
  7. void HL_AutoRunStep(void);
  8. void HL_Motor(void);
  9. void HL_Step(void);
  10. unsigned char cDWflg=0,cZCXflg=0,cHLflg=0,HL_StopFlg;
  11. short *offset_length_buff;
  12. unsigned char HL_X02_IN_FLAG,HL_X02_IN_FLAG_OLD;
  13. unsigned short HL_X02_FILTER;
  14. void HL_SetAlarmCode(unsigned alarm_code)
  15. {
  16. SetAlarmCode(HL_ALARM_ADDR,alarm_code);
  17. HL_bAlarmStop = 1;
  18. }
  19. void HL_InitAction(void)
  20. {
  21. CalFreqTab_X_Free(14);
  22. XGearRatio = 1;
  23. HL_X02_IN_FLAG = HL_GUO_LIAN_IN;
  24. HL_X02_IN_FLAG_OLD = HL_X02_IN_FLAG;
  25. }
  26. //手动动作
  27. void HL_ManualAction(void)
  28. {
  29. if(!HL_bRunning)
  30. {
  31. //警告跳出
  32. if(bClearTotal)
  33. {
  34. bClearTotal = 0;
  35. ClrcToTal(HL_TOTAL_ADDR);
  36. HL_bSetWorkData = 1;
  37. }
  38. if(HL_bAdd)
  39. {
  40. HL_bAdd = 0;
  41. HL_PARAM_DELAY_STOP += 10;
  42. }
  43. if(HL_bDec)
  44. {
  45. HL_bDec = 0;
  46. if(HL_PARAM_DELAY_STOP >= 10)HL_PARAM_DELAY_STOP -= 10;
  47. }
  48. if(HL_bHM)
  49. {
  50. HL_bHM = 0;
  51. HL_HM_VAVLE = ~HL_HM_VAVLE;
  52. }
  53. if(HL_bTFK)
  54. {
  55. HL_bTFK = 0;
  56. HL_TFK_VAVLE = ~HL_TFK_VAVLE;
  57. }
  58. if(HL_bBB)
  59. {
  60. HL_bBB = 0;
  61. HL_BB_VAVLE = ~HL_BB_VAVLE;
  62. }
  63. if(HL_bJD)
  64. {
  65. HL_bJD = 0;
  66. HL_JD_VAVLE = ~HL_JD_VAVLE;
  67. }
  68. if(HL_bCCX)
  69. {
  70. HL_bCCX = 0;
  71. HL_CCX_VAVLE = ~HL_CCX_VAVLE;
  72. }
  73. if(HL_bSL)
  74. {
  75. HL_bSL = 0;
  76. HL_SL_MOTOR = ~HL_SL_MOTOR;
  77. }
  78. if(HL_bDK)
  79. {
  80. HL_bDK = 0;
  81. HL_DK_VAVLE = ~HL_DK_VAVLE;
  82. }
  83. if(HL_bMotor)
  84. {
  85. SetEn(X_AXIS,HL_MOTOR_EN);
  86. if(!X_DRV)AxisContinueMove(X_AXIS,10,HL_DIR_P);
  87. }
  88. else
  89. {
  90. if(X_DRV)AxisDecStop(X_AXIS);
  91. }
  92. }
  93. }
  94. //合链动作
  95. void HL_Action(void)
  96. {
  97. HL_ManualAction();
  98. HL_StartStopAction();
  99. HL_Motor();
  100. HL_Step();
  101. HL_AutoRunStep();
  102. }
  103. //启动停止故障停止动作
  104. void HL_StartStopAction(void)
  105. {
  106. static unsigned long dwstop_cnt = 0;
  107. if((START_IN_UP || HL_bStart || HL_bSingStart || HL_bDW || HL_bZCX || HL_bHL) && !HL_bRunning && (HL_AutoStep ==0))
  108. {
  109. if(!HL_CCX_LIMIT_IN)HL_SetAlarmCode(HL_CCX_LIMIT_ALARM);
  110. else if(!HL_CCX_ORIGIN_IN)HL_SetAlarmCode(HL_CCX_ORIGIN_ALARM);
  111. else
  112. {
  113. SetAlarmCode(HL_ALARM_ADDR,HL_NO_ALARM);
  114. HL_bRunning = 1;
  115. HL_StopFlg = 0;
  116. dwZipCnt = 0;
  117. if(HL_bSingStart)
  118. {
  119. HL_bSingStart = 0;
  120. SingOneFlg = 1;
  121. }
  122. if(HL_bDW)
  123. {
  124. cDWflg = 1;
  125. dwZipCnt = 1;
  126. }
  127. if(HL_bZCX)cZCXflg = 1;
  128. if(HL_bHL)cHLflg = 1;
  129. if(HL_bZCX)HL_AutoStep = 4;
  130. else if(HL_bHL)HL_AutoStep = 1;
  131. else HL_AutoStep = 1;
  132. }
  133. HL_bDW = 0;
  134. HL_bZCX = 0;
  135. HL_bHL = 0;
  136. HL_bSingStart = 0;
  137. HL_bStart = 0;
  138. }
  139. if(!HL_bMotor && !X_DRV && !HL_bRunning && (HL_MotorStep==0))SetEn(X_AXIS,HL_MOTOR_DISEN);
  140. if(HL_bStop)
  141. {
  142. HL_bStop = 0;
  143. if(HL_bRunning)
  144. SingOneFlg = 1;
  145. else
  146. {
  147. HL_HM_VAVLE = 0;
  148. HL_JD_VAVLE = 0;
  149. HL_CCX_VAVLE = 0;
  150. HL_DK_VAVLE = 0;
  151. HL_SL_MOTOR = 0;
  152. HL_bRunning = 0;
  153. HL_AutoStep = 0;
  154. HL_MotorStep = 0;
  155. HL_JDStep = 0;
  156. SingOneFlg = 0;
  157. HL_bMotor = 0;
  158. cDWflg = 0;
  159. cZCXflg = 0;
  160. cHLflg = 0;
  161. AxisEgmStop(X_AXIS);
  162. SetAlarmCode(HL_ALARM_ADDR,HL_NO_ALARM);
  163. HL_StopFlg = 1;
  164. }
  165. }
  166. if(STOP_IN_UP)
  167. {
  168. if(HL_bRunning)
  169. {
  170. HL_bStop = 0;
  171. HL_DK_VAVLE = 0;
  172. HL_JD_VAVLE = 0;
  173. HL_CCX_VAVLE = 0;
  174. HL_SL_MOTOR = 0;
  175. HL_bRunning = 0;
  176. HL_AutoStep = 0;
  177. HL_MotorStep = 0;
  178. HL_HLStep = 0;
  179. HL_JDStep = 0;
  180. SingOneFlg = 0;
  181. HL_bMotor = 0;
  182. cDWflg = 0;
  183. cZCXflg = 0;
  184. cHLflg = 0;
  185. SetAlarmCode(HL_ALARM_ADDR,HL_NO_ALARM);
  186. AxisEgmStop(X_AXIS);
  187. }
  188. else
  189. {
  190. HL_bStop = 0;
  191. HL_DK_VAVLE = 0;
  192. HL_JD_VAVLE = 0;
  193. HL_CCX_VAVLE = 0;
  194. HL_SL_MOTOR = 0;
  195. HL_bRunning = 0;
  196. HL_AutoStep = 0;
  197. HL_MotorStep = 0;
  198. HL_HLStep = 0;
  199. HL_JDStep = 0;
  200. SingOneFlg = 0;
  201. HL_bMotor = 0;
  202. cDWflg = 0;
  203. cZCXflg = 0;
  204. cHLflg = 0;
  205. SetAlarmCode(HL_ALARM_ADDR,HL_NO_ALARM);
  206. AxisEgmStop(X_AXIS);
  207. HL_HM_VAVLE = 0;
  208. HL_StopFlg = 1;
  209. }
  210. }
  211. if(HL_StopFlg)
  212. {
  213. if(!HL_SM_LIMIT_IN && !HL_XM_LIMIT_IN)
  214. {
  215. HL_BB_VAVLE = 0;
  216. HL_TFK_VAVLE = 0;
  217. HL_StopFlg = 0;
  218. }
  219. }
  220. if(HL_bAlarmStop)
  221. {
  222. HL_bAlarmStop = 0;
  223. AxisEgmStop(X_AXIS);
  224. HL_AutoStep = 0;
  225. HL_ManDKStep = 0;
  226. HL_MotorStep = 0;
  227. HL_HLStep = 0;
  228. HL_bRunning = 0;
  229. SingOneFlg = 0;
  230. cDWflg = 0;
  231. cZCXflg = 0;
  232. cHLflg = 0;
  233. }
  234. if(HL_KA_DAI_IN)
  235. {
  236. HL_SetAlarmCode(HL_KD_ALARM);
  237. }
  238. else
  239. {
  240. // if(GetAlarmCode(HL_ALARM_ADDR) == HL_KD_ALARM)SetAlarmCode(HL_ALARM_ADDR,HL_NO_ALARM);
  241. }
  242. }
  243. void HL_Step(void)
  244. {
  245. static long hm_save_buff;
  246. switch(HL_HLStep)
  247. {
  248. case 1:
  249. if(HL_GUO_LIAN_IN_UP)
  250. {
  251. hm_save_buff = dwRealPos;
  252. HL_HLStep = 2;
  253. }
  254. break;
  255. case 2:
  256. if((dwRealPos + HL_PARAM_DELAY_HM_BACK) <= hm_save_buff)
  257. {
  258. HL_HM_VAVLE = 0;
  259. HL_HLDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  260. HL_HLStep = 3;
  261. }
  262. else if(!X_DRV)HL_SetAlarmCode(HL_HM_BACK_ALARM);
  263. break;
  264. case 3:
  265. if(!HL_SM_LIMIT_IN && !HL_XM_LIMIT_IN)
  266. {
  267. HL_HLStep = 4;
  268. HL_HLDelay = dwTickCount + HL_PARAM_DELAY_BB_BACK;
  269. }
  270. else if(dwTickCount >= HL_HLDelay)
  271. {
  272. if(HL_SM_LIMIT_IN)HL_SetAlarmCode(HL_SM_LIMIT_ALARM);
  273. else HL_SetAlarmCode(HL_XM_LIMIT_ALARM);
  274. }
  275. break;
  276. case 4:
  277. if(dwTickCount >= HL_HLDelay)
  278. {
  279. HL_HLStep = 5;
  280. HL_BB_VAVLE = 0;
  281. HL_HLDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  282. }
  283. break;
  284. case 5:
  285. if(!HL_BB_LIMIT_IN)
  286. {
  287. HL_HLStep = 0;
  288. if(SingOneFlg)
  289. {
  290. SingOneFlg = 0;
  291. HL_AutoStep = 0;
  292. HL_bRunning = 0;
  293. HL_MotorStep = 0;
  294. }
  295. HL_HLDelay = dwTickCount;
  296. }
  297. else if(dwTickCount >= HL_HLDelay)
  298. {
  299. HL_SetAlarmCode(HL_BB_LIMIT_ALARM);
  300. }
  301. break;
  302. }
  303. }
  304. //电机动作
  305. void HL_Motor(void) //
  306. {
  307. static long save_buff,hm_save_buff;
  308. static unsigned char cCheckFangKuaiEn = 0,FangKuaiOk= 0;
  309. DISPLAY_DATA0 = dwRealPos;
  310. DISPLAY_DATA1 = HL_AutoStep;
  311. DISPLAY_DATA2 = HL_MotorStep;
  312. DISPLAY_DATA3 = HL_HLStep;
  313. DISPLAY_DATA4 = HL_JDStep;
  314. HL_X02_IN_FLAG_OLD = HL_X02_IN_FLAG;
  315. if(HL_GUO_LIAN_IN)
  316. {
  317. if(HL_X02_FILTER < HL_PARAM_FILTER_TIMES)
  318. {
  319. HL_X02_FILTER++;
  320. }
  321. else
  322. HL_X02_IN_FLAG = 1;
  323. }
  324. else if(HL_X02_FILTER > (HL_PARAM_FILTER_TIMES/2))
  325. {
  326. HL_X02_FILTER--;
  327. }
  328. else
  329. HL_X02_IN_FLAG = 0;
  330. dwRealPos = GetPos(X_AXIS);
  331. if(cCheckFangKuaiEn)
  332. {
  333. if(HL_FANGKUAI_IN)
  334. {
  335. FangKuaiOk = 1;
  336. cCheckFangKuaiEn = 0;
  337. }
  338. }
  339. switch(HL_MotorStep)
  340. {
  341. case 0:break;
  342. case 1:
  343. if(GetEn(X_AXIS) == 0)
  344. {
  345. SetEn(X_AXIS,HL_MOTOR_EN);
  346. HL_MotorDelay = dwTickCount + 100;
  347. }
  348. HL_MotorStep = 2;
  349. break;
  350. case 2:
  351. if((dwTickCount >= HL_MotorDelay) && (HL_JDStep == 0))
  352. {
  353. HL_MotorDelay = dwTickCount + HL_PARAM_MOTOR_ALARM_TIME;
  354. if(HL_PARAM_MACHINE_MODE == 2)
  355. {
  356. cCheckFangKuaiEn = 1;
  357. FangKuaiOk = 0;
  358. }
  359. if(!HL_GUO_LIAN_IN)
  360. {
  361. MoveAction_Const_AccDec(X_AXIS,HL_DIR_P,HL_PARAM_LOW_SPEED,HL_PARAM_START_SPEED,HL_PARAM_ACC_SPEED,HL_PARAM_DEC_SPEED);
  362. HL_MotorStep = 4;
  363. }
  364. else
  365. {
  366. MoveAction_Const_AccDec(X_AXIS,HL_DIR_P,HL_PARAM_HIGH_SPEED,HL_PARAM_START_SPEED,HL_PARAM_ACC_SPEED,HL_PARAM_DEC_SPEED);
  367. HL_MotorStep = 3;
  368. }
  369. if(HL_HM_VAVLE)
  370. {
  371. *offset_length_buff = 0;
  372. if(HL_HLStep == 0)HL_HLStep = 1;
  373. }
  374. else
  375. {
  376. *offset_length_buff = 0;
  377. // offset_length_buff = &user_datas[22];
  378. }
  379. }
  380. break;
  381. case 3:
  382. if(HL_GUO_LIAN_IN_DW)
  383. {
  384. AxisChangeSpeed(X_AXIS,HL_PARAM_LOW_SPEED);
  385. HL_MotorDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  386. HL_MotorStep = 5;
  387. }
  388. else if((dwTickCount >= HL_MotorDelay) || HL_GUO_LIAN_IN_UP)
  389. HL_SetAlarmCode(HL_GUOLIAN_ALARM);
  390. break;
  391. case 4:
  392. if(HL_FANGKUAI_IN)
  393. {
  394. HL_MotorStep = 5;
  395. HL_MotorDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  396. }
  397. else if(dwTickCount >= HL_MotorDelay)
  398. HL_SetAlarmCode(HL_FK_IN_ALARM);
  399. break;
  400. case 5:
  401. if((HL_X02_IN_FLAG && !HL_X02_IN_FLAG_OLD))
  402. {
  403. save_buff = dwRealPos;
  404. if(HL_PARAM_MACHINE_MODE == 2)HL_JDStep = 1;
  405. HL_MotorStep = 6;
  406. }
  407. else if(dwTickCount >= HL_MotorDelay)
  408. HL_SetAlarmCode(HL_GUOLIAN_ALARM);
  409. break;
  410. case 6:
  411. if((dwRealPos + HL_PARAM_DELAY_STOP) <= save_buff)
  412. {
  413. AxisEgmStop(X_AXIS);
  414. HL_MotorStep = 7;
  415. }
  416. break;
  417. case 7:
  418. if(!X_DRV && (HL_HLStep == 0))
  419. {
  420. if(HL_PARAM_MACHINE_MODE == 2)
  421. {
  422. if(FangKuaiOk)
  423. {
  424. HL_MotorStep = 0;
  425. FangKuaiOk = 0;
  426. HL_MotorDelay = dwTickCount;
  427. }
  428. else
  429. HL_SetAlarmCode(HL_FK_IN_ALARM);
  430. }
  431. else
  432. {
  433. HL_MotorStep = 0;
  434. HL_MotorDelay = dwTickCount;
  435. }
  436. }
  437. break;
  438. }
  439. }
  440. //自动运行动作
  441. void HL_AutoRunStep(void)
  442. {
  443. if(HL_bRunning)
  444. {
  445. if(HL_JDStep == 1)
  446. {
  447. HL_CCX_VAVLE = 0;
  448. HL_JD_VAVLE = 0;
  449. HL_JDDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  450. HL_JDStep = 2;
  451. }
  452. else if(HL_JDStep == 2)
  453. {
  454. if(!HL_JD_LIMIT_IN && HL_CCX_ORIGIN_IN)
  455. {
  456. HL_JDDelay = dwTickCount + HL_PARAM_DELAY_JD;
  457. HL_JDStep = 3;
  458. }
  459. else if(dwTickCount >= HL_JDDelay)
  460. {
  461. if(HL_JD_LIMIT_IN)HL_SetAlarmCode(HL_JD_LIMIT_ALARM);
  462. else HL_SetAlarmCode(HL_CCX_ORIGIN_ALARM);
  463. }
  464. }
  465. else if((HL_JDStep == 3) && (dwTickCount >= HL_JDDelay))
  466. {
  467. HL_JD_VAVLE = 1;
  468. HL_JDDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  469. HL_JDStep = 4;
  470. }
  471. else if(HL_JDStep == 4)
  472. {
  473. if(HL_JD_LIMIT_IN && HL_DK_LIMIT_IN && HL_DK_VAVLE)
  474. {
  475. HL_CCX_VAVLE = 1;
  476. HL_JDDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  477. HL_JDStep = 5;
  478. }
  479. else if(dwTickCount >= HL_JDDelay)
  480. HL_SetAlarmCode(HL_JD_LIMIT_ALARM);
  481. }
  482. else if(HL_JDStep == 5)
  483. {
  484. if(!HL_CCX_ORIGIN_IN)
  485. {
  486. HL_JDDelay = dwTickCount + HL_PARAM_DELAY_CCX;
  487. HL_JDStep = 6;
  488. }
  489. else if(dwTickCount >= HL_JDDelay)
  490. HL_SetAlarmCode(HL_CCX_ORIGIN_IN);
  491. }
  492. else if((HL_JDStep == 6) && (dwTickCount >= HL_JDDelay) && HL_CCX_LIMIT_IN)
  493. {
  494. HL_CCX_VAVLE = 0;
  495. HL_JDDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  496. HL_JDStep = 7;
  497. }
  498. else if(HL_JDStep == 7)
  499. {
  500. if(HL_CCX_ORIGIN_IN)
  501. {
  502. HL_JDDelay = dwTickCount + HL_PARAM_DELAY_JD_BACK;
  503. HL_JDStep = 8;
  504. }
  505. else if(dwTickCount >= HL_JDDelay)
  506. HL_SetAlarmCode(HL_CCX_ORIGIN_ALARM);
  507. }
  508. else if((HL_JDStep == 8) && (dwTickCount >= HL_JDDelay) )
  509. {
  510. HL_JD_VAVLE = 0;
  511. HL_JDDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  512. HL_JDStep = 9;
  513. }
  514. else if(HL_JDStep == 9)
  515. {
  516. if(!HL_JD_LIMIT_IN)
  517. {
  518. HL_JDDelay = dwTickCount;
  519. HL_JDStep = 0;
  520. }
  521. else if(dwTickCount >= HL_JDDelay)
  522. HL_SetAlarmCode(HL_JD_LIMIT_ALARM);
  523. }
  524. if(HL_AutoStep == 1)
  525. {
  526. HL_AutoStep = 2;
  527. }
  528. else if((HL_AutoStep == 2) && (dwTickCount >= HL_JDDelay))
  529. {
  530. if(HL_MotorStep == 0)
  531. {
  532. HL_AutoStep = 3;
  533. HL_MotorStep = 1;
  534. }
  535. }
  536. else if(HL_AutoStep == 3)
  537. {
  538. if(HL_MotorStep == 0)
  539. {
  540. if(cDWflg | cHLflg)
  541. {
  542. cDWflg = 0;
  543. cHLflg = 0;
  544. HL_AutoStep = 0;
  545. HL_bRunning = 0;
  546. }
  547. else
  548. {
  549. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_TFK;
  550. HL_AutoStep = 4;
  551. }
  552. }
  553. }
  554. else if((HL_AutoStep == 4) && (dwTickCount >= HL_AutoDelay))
  555. {
  556. HL_TFK_VAVLE = 0;
  557. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  558. HL_AutoStep = 5;
  559. }
  560. else if(HL_AutoStep == 5)
  561. {
  562. if(HL_TFK_LIMIT_IN)
  563. {
  564. HL_AutoStep = 6;
  565. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_HM;
  566. }
  567. else if(dwTickCount >= HL_AutoDelay)
  568. {
  569. HL_SetAlarmCode(HL_TFK_LIMIT_ALARM);
  570. }
  571. }
  572. else if((HL_AutoStep == 6) && (dwTickCount >= HL_AutoDelay))
  573. {
  574. HL_HM_VAVLE = 1;
  575. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  576. HL_AutoStep = 7;
  577. }
  578. else if(HL_AutoStep == 7)
  579. {
  580. if(HL_SM_LIMIT_IN && HL_XM_LIMIT_IN)
  581. {
  582. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_DK;
  583. HL_AutoStep = 10;
  584. }
  585. else if(dwTickCount >= HL_AutoDelay)
  586. {
  587. if(!HL_SM_LIMIT_IN)
  588. HL_SetAlarmCode(HL_SM_LIMIT_ALARM);
  589. else
  590. HL_SetAlarmCode(HL_XM_LIMIT_ALARM);
  591. }
  592. }
  593. else if((HL_AutoStep == 8) && (dwTickCount >= HL_AutoDelay))
  594. {
  595. HL_AutoStep = 9;
  596. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  597. HL_TFK_VAVLE = 1;
  598. }
  599. else if(HL_AutoStep == 9)
  600. {
  601. if(HL_TFK_ORIGIN_IN)
  602. {
  603. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_BB;
  604. HL_AutoStep = 13;
  605. }
  606. else if(dwTickCount >= HL_AutoDelay)
  607. HL_SetAlarmCode(HL_TFK_ORIGIN_ALARM);
  608. }
  609. else if((HL_AutoStep == 10) && (dwTickCount >= HL_AutoDelay))
  610. {
  611. HL_AutoStep = 11;
  612. }
  613. else if(HL_AutoStep == 11)
  614. {
  615. HL_DK_VAVLE = 1;
  616. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  617. HL_AutoStep = 12;
  618. }
  619. else if(HL_AutoStep == 12)
  620. {
  621. if(HL_DK_LIMIT_IN)
  622. {
  623. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_TFK_BACK;
  624. HL_AutoStep = 8;
  625. }
  626. else if(dwTickCount >= HL_AutoDelay)
  627. HL_SetAlarmCode(HL_DK_LIMIT_ALARM);
  628. }
  629. else if((HL_AutoStep == 13) && (dwTickCount >= HL_AutoDelay))
  630. {
  631. HL_BB_VAVLE = 1;
  632. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  633. HL_AutoStep = 14;
  634. }
  635. else if(HL_AutoStep == 14)
  636. {
  637. if(HL_BB_LIMIT_IN)
  638. {
  639. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_JD;
  640. HL_AutoStep = 15;
  641. }
  642. else if(dwTickCount >= HL_AutoDelay)
  643. HL_SetAlarmCode(HL_BB_LIMIT_ALARM);
  644. }
  645. else if((HL_AutoStep == 15) && (dwTickCount >= HL_AutoDelay))
  646. {
  647. if(HL_PARAM_MACHINE_MODE != 2)HL_JD_VAVLE = 1;
  648. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  649. HL_AutoStep = 16;
  650. }
  651. else if(HL_AutoStep == 16)
  652. {
  653. if(HL_JD_LIMIT_IN || (HL_PARAM_MACHINE_MODE == 2))
  654. {
  655. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_CCX;
  656. HL_AutoStep = 17;
  657. }
  658. else if(dwTickCount >= HL_AutoDelay)
  659. HL_SetAlarmCode(HL_JD_LIMIT_ALARM);
  660. }
  661. else if((HL_AutoStep == 17) && (dwTickCount >= HL_AutoDelay))
  662. {
  663. if(HL_PARAM_MACHINE_MODE != 2)HL_CCX_VAVLE = 1;
  664. if(HL_PARAM_MACHINE_MODE)
  665. {
  666. if(!X_DRV)AxisMovePosAccDec(X_AXIS,HL_PARAM_LOW_SPEED,HL_PARAM_CCX_LENGTH,HL_PARAM_START_SPEED,HL_PARAM_ACC_SPEED,HL_PARAM_DEC_SPEED);
  667. }
  668. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  669. HL_CheckDelay = dwTickCount + HL_PARAM_DELAY_CHECK_CCX;
  670. HL_AutoStep = 18;
  671. }
  672. else if((HL_AutoStep == 18) && (dwTickCount >= HL_CheckDelay))
  673. {
  674. if(HL_CCX_LIMIT_IN)
  675. {
  676. if(HL_PARAM_MACHINE_MODE)AxisEgmStop(X_AXIS);
  677. HL_DK_VAVLE = 0;
  678. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  679. HL_AutoStep = 19;
  680. }
  681. else if(dwTickCount >= HL_AutoDelay)
  682. HL_SetAlarmCode(HL_CCX_LIMIT_ALARM);
  683. }
  684. else if(HL_AutoStep == 19)
  685. {
  686. if(HL_DK_ORIGIN_IN && !X_DRV)
  687. {
  688. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_JD_BACK;
  689. if(HL_PARAM_MACHINE_MODE == 2)
  690. HL_AutoStep = 22;
  691. else
  692. HL_AutoStep = 20;
  693. }
  694. else if(dwTickCount >= HL_AutoDelay)
  695. {
  696. HL_SetAlarmCode(HL_DK_ORIGIN_ALARM);
  697. }
  698. }
  699. else if((HL_AutoStep == 20) && (dwTickCount >= HL_AutoDelay))
  700. {
  701. HL_JD_VAVLE = 0;
  702. HL_AutoDelay = dwTickCount + HL_VAVLE_ALARM_TIME;
  703. HL_AutoStep = 21;
  704. }
  705. else if(HL_AutoStep == 21)
  706. {
  707. if(!HL_JD_LIMIT_IN)
  708. {
  709. HL_CCX_VAVLE = 0;
  710. HL_AutoDelay = dwTickCount + HL_PARAM_DELAY_MOTOR;
  711. HL_AutoStep = 22;
  712. }
  713. else if(dwTickCount >= HL_AutoDelay)
  714. {
  715. HL_SetAlarmCode(HL_JD_LIMIT_ALARM);
  716. }
  717. }
  718. else if((HL_AutoStep == 22) && (dwTickCount >= HL_AutoDelay))
  719. {
  720. if(!HL_PARAM_MACHINE_MODE)
  721. {
  722. if(!X_DRV)AxisMovePosAccDec(X_AXIS,HL_PARAM_LOW_SPEED,HL_PARAM_CCX_LENGTH,1,5,5);
  723. }
  724. HL_AutoStep = 23;
  725. }
  726. else if((HL_AutoStep == 23) && !X_DRV)
  727. {
  728. HL_AutoStep = 24;
  729. }
  730. else if(HL_AutoStep == 24)
  731. {
  732. if(cZCXflg)
  733. {
  734. cZCXflg = 0;
  735. HL_AutoStep = 0;
  736. HL_bRunning = 0;
  737. }
  738. else
  739. {
  740. HL_AutoStep = 25;
  741. }
  742. }
  743. else if((HL_AutoStep == 25) && (HL_JDStep == 0))
  744. {
  745. AddToTal(HL_TOTAL_ADDR);
  746. dwZipCnt++;
  747. HL_AutoStep = 2;
  748. HL_AutoDelay = HL_PARAM_CYCLE_DELAY + dwTickCount;
  749. CalProSP(HL_PROSPEED_ADDR);
  750. }
  751. }
  752. }
  753. #endif