ecat_master.c 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476
  1. /**
  2. * RT-Thread RuiChing
  3. *
  4. * COPYRIGHT (C) 2024-2025 Shanghai Real-Thread Electronic Technology Co., Ltd.
  5. * All rights reserved.
  6. *
  7. * The license and distribution terms for this file may be
  8. * found in the file LICENSE in this distribution.
  9. */
  10. #include <rtthread.h>
  11. #include "ecat_master.h"
  12. #include "ecat_service.h"
  13. #include <service.h>
  14. #include <stdint.h>
  15. #include <stdlib.h>
  16. static struct service_core *service = RT_NULL;
  17. rt_err_t ecat_master_init(ec_master_t *master)
  18. {
  19. if (!master)
  20. {
  21. return (-RT_EINVAL);
  22. }
  23. if (service != RT_NULL)
  24. {
  25. return service_control(service, ECAT_SERVICE_MASTER_INIT, master);
  26. }
  27. return (-RT_ERROR);
  28. }
  29. rt_err_t ecat_master_deinit(ec_master_t *master)
  30. {
  31. if (!master)
  32. {
  33. return (-RT_EINVAL);
  34. }
  35. if (service != RT_NULL)
  36. {
  37. return service_control(service, ECAT_SERVICE_MASTER_DEINIT, master);
  38. }
  39. return (-RT_ERROR);
  40. }
  41. rt_err_t ecat_master_start(ec_master_t *master)
  42. {
  43. if (!master)
  44. {
  45. return (-RT_EINVAL);
  46. }
  47. if (service != RT_NULL)
  48. {
  49. return service_control(service, ECAT_SERVICE_MASTER_START, master);
  50. }
  51. return (-RT_ERROR);
  52. }
  53. rt_err_t ecat_simple_start(ec_master_t *master)
  54. {
  55. if (!master)
  56. {
  57. return (-RT_EINVAL);
  58. }
  59. if (service != RT_NULL)
  60. {
  61. return service_control(service, ECAT_SERVICE_MASTER_START, master);
  62. }
  63. return (-RT_ERROR);
  64. }
  65. rt_err_t ecat_simple_stop(ec_master_t *master)
  66. {
  67. if (!master)
  68. {
  69. return (-RT_EINVAL);
  70. }
  71. if (service != RT_NULL)
  72. {
  73. return service_control(service, ECAT_SERVICE_MASTER_STOP, master);
  74. }
  75. return (-RT_ERROR);
  76. }
  77. rt_err_t ecat_master_state(ec_master_t *master, ec_master_state_t *state)
  78. {
  79. if ((!master) || (!state))
  80. {
  81. return (-RT_EINVAL);
  82. }
  83. if (service != RT_NULL)
  84. {
  85. struct ecat_master_state_arg state_arg;
  86. state_arg.master = master;
  87. state_arg.state = state;
  88. return service_control(service, ECAT_SERVICE_MASTER_STATE, &state_arg);
  89. }
  90. return (-RT_ERROR);
  91. }
  92. rt_err_t ecat_slave_state(
  93. ec_master_t *master, uint16_t slave, ec_slave_state_t *state)
  94. {
  95. if ((!master) || (!state))
  96. {
  97. return (-RT_EINVAL);
  98. }
  99. if (service != RT_NULL)
  100. {
  101. struct ecat_slave_state_arg state_arg;
  102. state_arg.master = master;
  103. state_arg.state = state;
  104. state_arg.slave = slave;
  105. return service_control(service, ECAT_SERVICE_SLAVE_STATE, &state_arg);
  106. }
  107. return (-RT_ERROR);
  108. }
  109. rt_err_t ecat_slave_info(
  110. ec_master_t *master, uint16_t slave, ec_slave_info_t *info)
  111. {
  112. if ((!master) || (!info))
  113. {
  114. return (-RT_EINVAL);
  115. }
  116. if (service != RT_NULL)
  117. {
  118. struct ecat_slave_info_arg info_arg;
  119. info_arg.master = master;
  120. info_arg.info = info;
  121. info_arg.slave = slave;
  122. return service_control(service, ECAT_SERVICE_SLAVE_INFO, &info_arg);
  123. }
  124. return (-RT_ERROR);
  125. }
  126. rt_err_t ecat_slave_config(
  127. ec_master_t *master, uint16_t slave, ec_slave_config_t *config)
  128. {
  129. if ((!master) || (!config))
  130. {
  131. return (-RT_EINVAL);
  132. }
  133. if (service != RT_NULL)
  134. {
  135. struct ecat_slave_config_arg config_arg;
  136. config_arg.master = master;
  137. config_arg.config = config;
  138. config_arg.slave = slave;
  139. return service_control(service, ECAT_SERVICE_SLAVE_CONFIG, &config_arg);
  140. }
  141. return (-RT_ERROR);
  142. }
  143. int ecat_sdo_write(ec_master_t *master,
  144. uint16_t slave,
  145. uint16_t index,
  146. uint8_t subindex,
  147. uint8_t complete_access,
  148. void *data,
  149. int size,
  150. int timeout)
  151. {
  152. if (!master)
  153. {
  154. return (-RT_EINVAL);
  155. }
  156. if (service != RT_NULL)
  157. {
  158. struct ecat_pdo_arg pdo_arg;
  159. pdo_arg.master = master;
  160. pdo_arg.slave = slave;
  161. pdo_arg.index = index;
  162. pdo_arg.subindex = subindex;
  163. pdo_arg.complete_access = complete_access;
  164. pdo_arg.data = data;
  165. pdo_arg.size = size;
  166. pdo_arg.timeout = timeout;
  167. return service_control(service, ECAT_SERVICE_SDO_WRITE, &pdo_arg);
  168. }
  169. return 0;
  170. }
  171. int ecat_sdo_read(ec_master_t *master,
  172. uint16_t slave,
  173. uint16_t index,
  174. uint8_t subindex,
  175. uint8_t complete_access,
  176. void *data,
  177. int size,
  178. int timeout)
  179. {
  180. if (!master)
  181. {
  182. return (-RT_EINVAL);
  183. }
  184. if (service != RT_NULL)
  185. {
  186. struct ecat_pdo_arg pdo_arg;
  187. pdo_arg.master = master;
  188. pdo_arg.slave = slave;
  189. pdo_arg.index = index;
  190. pdo_arg.subindex = subindex;
  191. pdo_arg.complete_access = complete_access;
  192. pdo_arg.data = data;
  193. pdo_arg.size = size;
  194. pdo_arg.timeout = timeout;
  195. return service_control(service, ECAT_SERVICE_SDO_READ, &pdo_arg);
  196. }
  197. return 0;
  198. }
  199. void ecat_dc_config(ec_master_t *master,
  200. uint16_t slave,
  201. uint8_t act,
  202. uint32_t cycle_time,
  203. int32_t cycle_shift)
  204. {
  205. if (!master)
  206. {
  207. return;
  208. }
  209. if (service != RT_NULL)
  210. {
  211. struct ecat_dc_config_arg dc_cfg;
  212. dc_cfg.master = master;
  213. dc_cfg.slave = slave;
  214. dc_cfg.act = act;
  215. dc_cfg.cycle_time = cycle_time;
  216. dc_cfg.cycle_shift = cycle_shift;
  217. service_control(service, ECAT_SERVICE_DC_CONFIG, &dc_cfg);
  218. }
  219. }
  220. void ecat_dc_config_ex(ec_master_t *master,
  221. uint16_t slave,
  222. uint8_t act,
  223. uint32_t cycle_time0,
  224. uint32_t cycle_time1,
  225. int32_t cycle_shift)
  226. {
  227. if (!master)
  228. {
  229. return;
  230. }
  231. if (service != RT_NULL)
  232. {
  233. struct ecat_dc_config_ex_arg dc_cfg;
  234. dc_cfg.master = master;
  235. dc_cfg.slave = slave;
  236. dc_cfg.act = act;
  237. dc_cfg.cycle_time0 = cycle_time0;
  238. dc_cfg.cycle_time1 = cycle_time1;
  239. dc_cfg.cycle_shift = cycle_shift;
  240. service_control(service, ECAT_SERVICE_DC_CONFIG_EX, &dc_cfg);
  241. }
  242. }
  243. int ecat_slavecount(ec_master_t *master)
  244. {
  245. if (!master || !service)
  246. {
  247. return -1;
  248. }
  249. int tmp;
  250. void *arg[] = { (void *)master, (void *)&tmp };
  251. service_control(service, ECAT_SERVICE_SLAVE_COUNT, arg);
  252. return tmp;
  253. }
  254. rt_err_t ecat_write_state(ec_master_t *master, uint16_t slave, uint16_t state)
  255. {
  256. if (!master)
  257. {
  258. return (-RT_EINVAL);
  259. }
  260. if (!service)
  261. {
  262. return (-RT_ERROR);
  263. }
  264. struct ecat_state_arg state_arg;
  265. state_arg.master = master;
  266. state_arg.state = &state;
  267. state_arg.slave = slave;
  268. return service_control(service, ECAT_SERVICE_SET_STATE, &state_arg);
  269. }
  270. rt_err_t ecat_check_state(
  271. ec_master_t *master, uint16_t slave, uint16_t *state, int timeout)
  272. {
  273. if (!master)
  274. {
  275. return (-RT_EINVAL);
  276. }
  277. if (!service)
  278. {
  279. return (-RT_ERROR);
  280. }
  281. struct ecat_state_arg state_arg;
  282. state_arg.master = master;
  283. state_arg.state = state;
  284. state_arg.slave = slave;
  285. state_arg.timeout = timeout;
  286. return service_control(service, ECAT_SERVICE_CHECT_STATE, &state_arg);
  287. }
  288. rt_err_t ecat_config_init(ec_master_t *master, uint8_t usetable)
  289. {
  290. if (!master)
  291. {
  292. return (-RT_EINVAL);
  293. }
  294. if (!service)
  295. {
  296. return (-RT_ERROR);
  297. }
  298. void *arg[] = { (void *)master, (void *)(uintptr_t)usetable };
  299. return service_control(service, ECAT_SERVICE_INIT_CONFIG, arg);
  300. }
  301. rt_err_t ecat_config_dc(ec_master_t *master)
  302. {
  303. if (!master)
  304. {
  305. return (-RT_EINVAL);
  306. }
  307. if (!service)
  308. {
  309. return (-RT_ERROR);
  310. }
  311. return service_control(service, ECAT_SERVICE_CONFIG_DC, master);
  312. }
  313. rt_err_t ecat_config_map_group(ec_master_t *master, void *map, uint8_t group)
  314. {
  315. if (!master)
  316. {
  317. return (-RT_EINVAL);
  318. }
  319. if (!service)
  320. {
  321. return (-RT_ERROR);
  322. }
  323. void *arg[] = { (void *)master, (void *)(uintptr_t)group };
  324. master->process_data = map;
  325. return service_control(service, ECAT_SERVICE_CONFIG_MAP_GROUP, arg);
  326. }
  327. rt_err_t ecat_send_processdata_group(ec_master_t *master, uint8_t group)
  328. {
  329. if (!master)
  330. {
  331. return (-RT_EINVAL);
  332. }
  333. void *arg[] = { (void *)master, (void *)(uintptr_t)group };
  334. return service_control(service, ECAT_SERVICE_SEND_PROCESS_DATA_GROUP, arg);
  335. }
  336. rt_err_t ecat_receive_processdata_group(
  337. ec_master_t *master, uint8_t group, int timeout)
  338. {
  339. if (!master)
  340. {
  341. return (-RT_EINVAL);
  342. }
  343. void *arg[] = {
  344. (void *)master,
  345. (void *)(uintptr_t)group,
  346. (void *)(uintptr_t)timeout,
  347. };
  348. return service_control(service, ECAT_SERVICE_RECV_PROCESS_DATA_GROUP, arg);
  349. }
  350. rt_err_t ecat_timer_start(struct ecat_timer *t, uint32_t timeout_us)
  351. {
  352. if (!t)
  353. {
  354. return (-RT_EINVAL);
  355. }
  356. void *arg[] = {
  357. (void *)t,
  358. (void *)(uintptr_t)timeout_us,
  359. };
  360. return service_control(service, ECAT_SERVICE_TIMERSTART, arg);
  361. }
  362. rt_bool_t ecat_timer_is_expired(struct ecat_timer *t)
  363. {
  364. void *arg[] = {
  365. (void *)t,
  366. };
  367. return service_control(service, ECAT_SERVICE_TIMER_ISEXPIRED, arg);
  368. }
  369. rt_err_t ecat_sync_dc(ec_master_t *master)
  370. {
  371. if (!master)
  372. {
  373. return (-RT_EINVAL);
  374. }
  375. void *arg[] = {
  376. (void *)master,
  377. };
  378. return service_control(service, ECAT_SERVICE_SYNC_DC, arg);
  379. }
  380. rt_err_t ecat_hwtimer_start(ec_master_t *master)
  381. {
  382. if (!master)
  383. {
  384. return (-RT_EINVAL);
  385. }
  386. void *arg[] = {
  387. (void *)master,
  388. };
  389. return service_control(service, ECAT_SERVICE_HWTIMER_START, arg);
  390. }
  391. int ecat_service_init(void)
  392. {
  393. service = service_find("ecat_service");
  394. if (!service)
  395. {
  396. rt_kprintf("not find ethercat service\n");
  397. return (-RT_ERROR);
  398. }
  399. return RT_EOK;
  400. }