P5_Automation_can-dev-res.ino 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609
  1. /* P5_Automation_can-dev
  2. * 2020-06 testing communications CAN for integrate further with Procesy5
  3. * A.Binder
  4. * Uses:
  5. * LCD1602 - big 2x16 character display
  6. * TFT_ILI9163C 128x128 lcd display
  7. * MCP_2515 - can port controller
  8. * //#define HAS_I2C_driver_Adafruit_PWMServoDriver
  9. * controls
  10. * Slave ports via:
  11. * I2C
  12. * PCA9685 - 16port 12bit PWM driver - can controll 16 eg. LEDs which can be 0....12V dimmed=]
  13. * todo 74HC595 - Serial to Parallel Shifting-Out - from 8 ports to many if connected in paraller
  14. * based on https://www.arduino.cc/en/tutorial/ShiftOut
  15. * or 16 servos
  16. * - can have addressed many of PCA9685 on I2C bus - so can controll over 64 ports
  17. * to be added another devices tested
  18. * todo Rottary Swich { GND, +, SW, DT, CLK } - to provide LCD menu access
  19. * TODO structure of port is in _Slave_Ports.h
  20. * _Slave_Port _Slave_Ports[] = {
  21. {"CAN", 0x102, 0x80, 0x00, 0, 0x00, 0x00 },
  22. {"CAN", - Base port origin protocol
  23. 0x102, - Base port origin protocol address
  24. 0x80, - int PortTypes; 0xFF = 1111 1111
  25. 0x01 = 0000 0001 = PWM port
  26. {
  27. bit 1 - PWM port
  28. bit 2 - not allocated
  29. bit 3 - not allocated
  30. bit 4 - not allocated
  31. bit 2 - not allocated
  32. bit 5 - not allocated
  33. bit 6 - not allocated
  34. bit 7 - not allocated
  35. bit 8 - not allocated
  36. },
  37. 0x00, int Address - local address on e.g. I2C bus - 0x40 etc
  38. 0x00, - int LocalPort - local port number when used e.g. I2C extension
  39. 0x01 - Exp_state - 0xFF = 1111 1111
  40. 0x00 = 0000 0000 = OFF = 0V
  41. 0x01 = 0000 0001 = ON = PWM max
  42. {
  43. bit 1 - OFF = 0V
  44. bit 2 - ON = PWM max
  45. bit 3 - not allocated
  46. bit 4 - not allocated
  47. bit 2 - not allocated
  48. bit 5 - not allocated
  49. bit 6 - not allocated
  50. bit 7 - not allocated
  51. bit 8 - not allocated
  52. },
  53. 0x6d - testowy ttl - 10 sekund do przedawnienia stanu portu w tablicy i koniecznosci odswiezenia tablicy
  54. }
  55. };
  56. - to be optimalized for inegration
  57. - to allow of subscribe ports
  58. - to allow of concurent routing
  59. - to allow new port detectioj
  60. - to allow creating ports dependencies e.g. IF
  61. - port has value
  62. - port AND port
  63. THEN
  64. - set port
  65. - probably should be avilable creations of virtual ports which would describe
  66. - state of port AND port etc...
  67. * TO BE INTEGRATED WITH p5
  68. * - interface and WFST
  69. * TO BE INGEGRATED WITH MARLIN 3D PRINTERS - machine and automation purpose
  70. * - controll remote ports via g-code
  71. * - allows interrupts
  72. * TO ALLOW OF NEXT PACKETS TYPES WITH DIFFERENT MEANINGS
  73. * - dimming
  74. * logic
  75. */
  76. //#define HAS_DEBUG_ACTION_TRIG
  77. //#define DEBUG_I2C //to debug _Slave_Ports_I2C_POP etc
  78. //#define HAS_TFT_ILI9163C
  79. //#define HAS_LCD1602
  80. //#define HAS_ROTTARY_SW
  81. //#define DEBUG_I2C_driver_Adafruit_PWMServoDriver
  82. //#define DEBUG_CAN
  83. //#define DEBUG_QUEUE
  84. //#define DEBUG_QUEUE_ASSERT
  85. //#define DEBUG_QUEUE_WAIT 500
  86. //#define DEBUG_STRUCT_INIT
  87. //#define DEBUG_STORAGE_QUEUE_TEST
  88. #define DEBUG_ARDUINO_ATTR_ARRAY_S__commit_added_element_QUEUE
  89. //#define DEBUG_ARDUINO_ARRAY_INDEX_NEXT_LOCK
  90. //#define HAS__PCINT_setup //to allow interrupts
  91. //#define DEBUG_TASK_TYPE_T_Slave_Ports_broadcast____
  92. //#define DEBUG_TASK_TYPE_T_DISPLAY_queue_pop________
  93. //#define DEBUG_TASK_TYPE_T_Slave_Ports_set_I2C______
  94. #define DEBUG_TASK_TYPE_T_Debug_Queue_Functions____ //to detect validate queue func - disables loop much
  95. #define HAS__jm_Scheduler //to allow planned actions blink etc
  96. #if defined(HAS__jm_Scheduler)
  97. #include "jm_Scheduler.h"
  98. #endif
  99. //Debug level
  100. //#define DEBUG 5
  101. //#define DISABLE_LOOP //To debug and disable any output
  102. #include "___main/__main_struct.h"
  103. #include "___main/__main_trigger_struct.h"
  104. #include "___main/__main_struct_funct.h"
  105. #include "___main/__main_struct_limits.h"
  106. #include "_time_struct.h"
  107. #include "_DRIVER_STATUS/_DRIVER_STATUS_struct.h"
  108. #include "___main/__main_I2C_struc.h"
  109. #include "___main/__main_static.h"
  110. #include "___main/__main_auto.h"
  111. #include "___main/__main_register.h"
  112. #include "___main/__main_extern.h"
  113. #include "___template/__STORAGE_ARRAY_func.h" //testing
  114. #define _ControllerID 0x101
  115. #define _Slave1_ID 0x103
  116. //#include "Active_ControllerID_0x103.h"
  117. //#define Active_ControllerID _ControllerID
  118. //#define Active_ControllerID _Slave1_ID
  119. #include "___CONFIG/config_Active_ControllerID.h" //there kleep id of device
  120. //#include "config_Slave_Ports_LOCAL_0x101_init.h" //there kleep config of this id device
  121. #define print_SEP_RT "]"
  122. #if defined(DEBUG)
  123. #define DPRINT(...) Serial.print(__VA_ARGS__)
  124. #define DPRINTLN(...) Serial.println(__VA_ARGS__)
  125. #define DRINTF(...) Serial.print(F(__VA_ARGS__))
  126. #define DPRINTLNF(...) Serial.println(F(__VA_ARGS__))
  127. DPRINTLN("#125 [DEBUG ENABLED]");
  128. //DPRINTLN(0xC0FFEEul,DEC);
  129. //DPRINTLN(12648430ul,HEX);
  130. #else
  131. #define DPRINT(...) //blank line
  132. #define DPRINTLN(...) //blank line
  133. #define DPRINTF(...) //blank line
  134. #define DPRINTLNF(...) //blank line
  135. #endif
  136. #if Active_ControllerID == 0x101
  137. const int Active_ControllerID_HEX = 0x11 ;
  138. #include "___CONFIG/0x101/config_Active_ControllerID_0x101.h"
  139. #endif
  140. #if Active_ControllerID == 0x103
  141. const int Active_ControllerID_HEX = 0x13 ;
  142. #include "___CONFIG/0x103/config_Active_ControllerID_0x103.h" //there kleep config of this id device
  143. #endif
  144. #if defined(HAS_TFT_ILI9163C)
  145. #include "_TFT_ILI9163C_config.h"
  146. #endif
  147. #include "_DISPLAY_struct.h"
  148. #include "_Port_ID_sruct.h"
  149. #include "_TASK_TYPES_struct.h"
  150. #include "_Slave_Ports_Status_QUEUE_struct.h"
  151. //#include "Slave_Ports_Status_QUEUE.h"
  152. #include "_I2C_driver_Adafruit_PWMServoDriver/_I2C_driver_Adafruit_PWMServoDriver_struct.h"
  153. #include "_CAN/_CAN_config.h"
  154. #if defined(HAS_ROTTARY_SW)
  155. #include "_ROTTARY_SW/_ROTTARY_SW_config.h"
  156. #endif
  157. #if defined(HAS_I2C_driver_Adafruit_PWMServoDriver)
  158. #include "_I2C_driver_Adafruit_PWMServoDriver/_I2C_driver_Adafruit_PWMServoDriver_config.h"
  159. #endif
  160. #if defined(HAS_ROTTARY_SW)
  161. #include "_ROTTARY_SW/_ROTTARY_SW_struct.h"
  162. #endif
  163. #include "Queue.h"
  164. //#include "TPQ.h"
  165. Queue<int> _Slave_Ports_queue = Queue<int>(ARDUINO_ARRAY_INDEX_LIMIT_QUEUE);
  166. Queue<int> TEST_QUEUE = Queue<int>(ARDUINO_ARRAY_INDEX_LIMIT_QUEUE);
  167. #if Active_ControllerID == _ControllerID
  168. String lcdPattern = "s" ;
  169. #endif
  170. #if Active_ControllerID == _Slave1_ID
  171. String lcdPattern = "." ;
  172. #endif
  173. //BEGIN 1602
  174. #if defined(HAS_LCD1602)
  175. #include <LiquidCrystal.h>
  176. // initialize the library with the numbers of the interface pins
  177. //LiquidCrystal lcd(4, 6, 10, 11, 12, 13);
  178. //LiquidCrystal lcd(4, 6, 53, 51, 50, 52 );
  179. #include "_LCD1602_struct.h"
  180. // #include "_LCD1602_init.h"
  181. #endif
  182. //#if defined(HAS_TFT_ILI9163C)
  183. #include "_TFT_ILI9163C_struct.h"
  184. //#endif
  185. #if defined(HAS__PCINT_setup)
  186. #include "_PCINT/_PCINT_struct.h" //pins MYPIN1 MYPIN2 MYPIN3
  187. #endif
  188. //BEGIN CAN
  189. #include "_CAN/_CAN_init.h"
  190. //EOF CAN
  191. //REMOTE PORTS DEFINITIONS
  192. #include "_PortTypes_struct.h"
  193. #include "_PortStates_struct.h"
  194. #include "_Port_Exp_state_ttl_struct.h"
  195. #include "_Port_Broadcast_state_struct.h"
  196. #include "_Port_I2C_driver_struct.h"
  197. #include "_Slave_Ports_Status_struct.h"
  198. #include "_CAN/_Slave_Ports_Protocol_CAN_struct.h"
  199. #if defined(HAS_TFT_ILI9163C)
  200. #include "_TFT_ILI9163C_func.h"
  201. #endif
  202. #if defined(HAS_I2C_driver_Adafruit_PWMServoDriver)
  203. #include "_I2C_driver_Adafruit_PWMServoDriver/_I2C_driver_Adafruit_PWMServoDriver_func.h"
  204. #endif
  205. #include "_TASK_TYPES_func.h"
  206. #include "_Slave_Ports_Status_QUEUE_add_func.h"
  207. #include "_DISPLAY_add_record_func.h"
  208. #include "_DISPLAY_func.h"
  209. #if defined(HAS_LCD1602)
  210. #include "_LCD1602_func.h"
  211. //#include "_LCD1602_init.h"
  212. #endif
  213. #if defined(HAS_ROTTARY_SW)
  214. #include "_ROTTARY_SW/_ROTTARY_SW_func.h"
  215. #endif
  216. #include "_time_func.h"
  217. #include "_Slave_Ports_ttl_decrement_func.h"
  218. #include "_Slave_Ports_broadcast_func.h"
  219. #include "_Slave_Ports_I2C_func.h"
  220. #include "_DISPLAY_queue_pop_func.h"
  221. #include "_Slave_Ports_Status_QUEUE_func.h"
  222. #include "_Slave_Ports_Protocol_CAN_func.h"
  223. #include "_Slave_Ports_Status_func.h"
  224. #include "_CAN/_CAN_func.h"
  225. #include "_Slave_Ports.h"
  226. // #include "_Slave_Ports_ttl_decrement_POP.h"
  227. // #define _CAN_P_0x102_PWM0x00_0 { _Slave1_ID , "PWM", 0x00, 0 }
  228. //#define _CAN_P_0x102_PWMServoDriver0x40
  229. // #define Adafruit_PWMServoDriver pwm1 = Adafruit_PWMServoDriver();
  230. // Adafruit_PWMServoDriver pwm1 = Adafruit_PWMServoDriver(0x40);
  231. // #define __CSpin 53 // 10 // chip select
  232. #if defined(HAS_LCD1602)
  233. #include "_LCD1602_init.h"
  234. #endif
  235. #if defined(HAS_TFT_ILI9163C)
  236. #include "_TFT_ILI9163C_init.h"
  237. #endif
  238. #include "_DISPLAY_init.h"
  239. #if defined(HAS_ROTTARY_SW)
  240. #include "_ROTTARY_SW/_ROTTARY_SW_init.h" //empty
  241. #endif
  242. #if defined(HAS__PCINT_setup)
  243. #include "_PCINT/_PCINT_init.h"
  244. #endif
  245. #include "___CONFIG/config_Slave_Ports_LOCAL_init.h"
  246. #if Active_ControllerID == 0x101
  247. #include "___CONFIG/0x101/config_Slave_Ports_LOCAL_0x101_init.h"
  248. #endif
  249. #if Active_ControllerID == 0x103
  250. #include "___CONFIG/0x103/config_Slave_Ports_LOCAL_0x103_init.h"
  251. #endif
  252. #if defined(HAS_I2C_driver_Adafruit_PWMServoDriver)
  253. #include "_I2C_driver_Adafruit_PWMServoDriver/_I2C_driver_Adafruit_PWMServoDriver_init.h"
  254. #endif
  255. #include "___main/__main_init.h"
  256. #ifdef DISABLE_LOOP
  257. #include "___DEBUG/___DEBUG_DISABLE_INIT.h"
  258. #endif
  259. void setup() { //REMEMBER NOT INITIALIZE ANY VARIABLES OR ARRAYS
  260. Serial.begin(115200);
  261. #if defined(DEBUG) || defined(DEBUG_QUEUE)
  262. Serial.println("#329 Serial.begin(115200)");
  263. #endif
  264. // Serial.begin(9600);
  265. // Serial.println("#233 setup" );
  266. // _LCD_print_queue.push(1);
  267. // _LCD_print_queue.push(2);
  268. // _LCD_print_queue.push(3);
  269. //String character = "Geas";
  270. //char b = abc.charAt(0);
  271. //int b_ascii_value = b;
  272. // LCD_print_background_add( _LCD_print_buffors, 0, 0, 0, "W", 5000, 6000);
  273. // LCD_print_background_add( _LCD_print_buffors, 1, 0, 0, "H", 5000, 6000);
  274. // LCD_print_background_add( _LCD_print_buffors, 2, 0, 0, "W", 5000, 6000);
  275. // LCD_print_background_add( _LCD_print_buffors, 3, 0, 0, "K", 5000, 6000);
  276. //todo PCINT service
  277. #if defined(DISABLE_LOOP) || defined(DEBUG)
  278. Serial.println("#375 will include ___main/__main_I2C_setup.h");
  279. #endif
  280. #include "___main/__main_I2C_setup.h"
  281. #if defined(HAS__PCINT_setup)
  282. #include "_PCINT/_PCINT_setup.h" //empty
  283. #endif
  284. #if defined(HAS_ROTTARY_SW)
  285. #include "_ROTTARY_SW/_ROTTARY_SW_setup.h" //Attach interrupts
  286. #endif
  287. /* TODO
  288. String LCDarray1="CAN_1602_LCD "; //the string to print onthe LCD
  289. String LCDarray2="Testing id "; //the string to print onthe LCD
  290. LCDarray2.concat(String(Active_ControllerID, HEX) ) ;
  291. */
  292. #if defined(HAS_I2C_driver_Adafruit_PWMServoDriver)
  293. #if defined(DISABLE_LOOP) || defined(DEBUG) || defined(DEBUG_I2C_driver_Adafruit_PWMServoDriver)
  294. Serial.println("#401 will include /_I2C_driver_Adafruit_PWMServoDriver_setup.h");
  295. #endif
  296. #include "_I2C_driver_Adafruit_PWMServoDriver/_I2C_driver_Adafruit_PWMServoDriver_setup.h"
  297. #endif
  298. // put your setup code here, to run once:
  299. #if defined(HAS_LCD1602)
  300. #include "_LCD1602_setup.h"
  301. #endif
  302. #if defined(HAS_TFT_ILI9163C)
  303. #include "_TFT_ILI9163C_setup.h"
  304. #endif
  305. //BEGIN CAN
  306. #include "_CAN/_CAN_setup.h"
  307. #if defined(HAS_LCD1602)
  308. /* todo
  309. LCDarray1 = "loop.... ";
  310. LCDarray2 = "....";
  311. LCD_print(LCDarray1, LCDarray2, LCDtim/10);
  312. */
  313. #endif
  314. #ifndef DISABLE_LOOP
  315. #include "___main/__main_setup.h"
  316. #endif
  317. #ifdef DISABLE_LOOP
  318. #include "___DEBUG/___DEBUG_DISABLE_SETUP.h"
  319. #endif
  320. }
  321. //#if Active_ControllerID == _ControllerID
  322. // byte data[8] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07};
  323. //#endif
  324. //String LCDarray1 ;
  325. //String LCDarray2 ;
  326. unsigned long time;
  327. ARDUINO_LOOP_LATENCY_T ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END( ARDUINO_LOOP_LATENCY_T
  328. ARDUINO_LOOP_LATENCY__MAIN_END_A) {
  329. static ARDUINO_LOOP_LATENCY_COUNTER_T ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A = ARDUINO_LOOP_LATENCY__MAIN_END_A;
  330. if(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A == 0 ) {
  331. ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A = ARDUINO_LOOP_LATENCY__MAIN_END_A;
  332. #if defined(DEBUG)
  333. Serial.print("] COUNTER__MAIN_END_A["); Serial.print(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A); Serial.print("] C["); Serial.print(ARDUINO_LOOP_LATENCY__MAIN_END_A); Serial.println("] ");
  334. #endif
  335. } else {
  336. return ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A-- ;
  337. }
  338. }
  339. ARDUINO_LOOP_LATENCY_T ARDUINO_LOOP_LATENCY_COUNTER__MAIN( ARDUINO_LOOP_LATENCY_T
  340. ARDUINO_LOOP_LATENCY__MAIN_A) {
  341. static ARDUINO_LOOP_LATENCY_COUNTER_T ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A = ARDUINO_LOOP_LATENCY__MAIN_A;
  342. if(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A == 0 ) {
  343. #if defined(DEBUG)
  344. Serial.print("] COUNTER__MAIN_A["); Serial.print(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A); Serial.print("] C["); Serial.print(ARDUINO_LOOP_LATENCY__MAIN_A); Serial.println("] ");
  345. #endif
  346. ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A = ARDUINO_LOOP_LATENCY__MAIN_A;
  347. } else {
  348. return ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A-- ;
  349. }
  350. }
  351. void loop() {
  352. register long time;
  353. time = millis();
  354. #include "___loop/___loop_init.h"
  355. #if defined(HAS__PCINT_setup)
  356. #include "_PCINT/_PCINT_loop.h"
  357. #endif
  358. #if defined(HAS_ROTTARY_SW)
  359. #include "_ROTTARY_SW/_ROTTARY_SW_loop.h"
  360. #endif
  361. #ifdef DISABLE_LOOP
  362. #include "___DEBUG/___DEBUG_DISABLE_LOOP.h"
  363. #endif
  364. #include "___loop/__main_loop_top.h"
  365. if(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END(ARDUINO_LOOP_LATENCY__MAIN_END_A) <= ARDUINO_LOOP_LATENCY_COUNTER_INIT ) {
  366. #if defined(DEBUG)
  367. #ifndef DISABLE_LOOP
  368. if(DEBUG_ACTION_TRIG == 1) Serial.print("] Time: " ); Serial.println(time);
  369. #endif
  370. #endif
  371. if(DEBUG_ACTION_TRIG == 1 or (time % 100000 == 0)) {
  372. Serial.print("Time: " ); Serial.println(time);
  373. }
  374. #ifndef DISABLE_LOOP
  375. if(DEBUG_ACTION_TRIG == 1) {
  376. #if defined(DEBUG)
  377. Serial.print("#331_L1 main loop top ARDUINO_FUNCT_INIT_RESULT__Slave_Ports_LOCAL_init ");
  378. Serial.println(ARDUINO_FUNCT_INIT_RESULT__Slave_Ports_LOCAL_init);
  379. Serial.print("#331_L2 main loop top ARDUINO_FUNCT_INIT_RESULT__Slave_Ports_LOCAL_init=[");
  380. Serial.println(ARDUINO_FUNCT_INIT_RESULT__Slave_Ports_LOCAL_init);
  381. Serial.print(" true["); Serial.print(true); Serial.print("] false["); Serial.print(false);
  382. Serial.println("] ");
  383. #endif
  384. }
  385. #if defined(DEBUG_DISPLAY)
  386. Serial.print("#532 Will TODO bug when too many mesgs to queue ..DISPLAY_pos_seq_T[");
  387. Serial.print(DISPLAY_pos_seq_A_NEXT , BIN); Serial.print("]+[ "); Serial.print(DISPLAY_pos_seq_A_IMMEDIATE , BIN); Serial.print("] ==[ "); Serial.print(DISPLAY_pos_seq_A_NEXT | DISPLAY_pos_seq_A_IMMEDIATE , BIN);
  388. Serial.print("] DISPLAY_TARGET_T 128["); Serial.print(DISPLAY_TARGET_DISPLAY128, BIN);Serial.print("] bin[");
  389. Serial.println("] ");
  390. #endif
  391. Slave_Ports_Status__DISPLAY_TARGET(
  392. Slave_Ports_Status_A ,
  393. Slave_Ports_Status_T_ARDUINO_ATTR_ARRAY_A,
  394. 0 ,
  395. DISPLAY_A ,
  396. DISPLAY_T_ARDUINO_ATTR_ARRAY_A ,
  397. DISPLAY_PHYSICAL_CHAR_A,
  398. DISPLAY_pos_seq_A_NEXT | DISPLAY_pos_seq_A_IMMEDIATE ,
  399. "PORTS [" ,
  400. DISPLAY_TARGET_DISPLAY128,
  401. time,
  402. time + ARDUINO_time_seq_id_A_INCREMENT
  403. //queue
  404. ,Slave_Ports_Status_QUEUE_A, Slave_Ports_Status_QUEUE_T_ARDUINO_ATTR_ARRAY_A ,
  405. TASK_TYPE_T__EMPTY__JUST_PASSED_ARG__,
  406. TASK_PORT_ASSOC_EMPTY
  407. );
  408. #else
  409. #include "___DEBUG/___DEBUG_DISABLE_LOOP_MAIN_A.h"
  410. #endif
  411. }
  412. // Serial.println(time);
  413. #include "___loop/_SlaveID_loop1.h" //todo PCINT
  414. #include "___loop/_ControllerID_loop1.h" //todo make default
  415. #include "___loop/__main_loop_end.h"
  416. // DISPLAY_DEV.setCursor(10,10);
  417. // DISPLAY_DEV.print(" Test307");
  418. /*
  419. DISPLAY__print_ANY(
  420. DISPLAY_T_ARDUINO_ATTR_ARRAY_A ,
  421. DISPLAY_PHYSICAL_CHAR_A,
  422. DISPLAY_pos_seq_A_NEXT,
  423. "123456789012345678901234567890"
  424. ); */
  425. delay(10);
  426. if(DEBUG_ACTION_TRIG != DEBUG_LAST_ACTION_TRIG) {
  427. Serial.print("#534 DEBUG_ACTION_TRIG[");Serial.print(DEBUG_ACTION_TRIG);Serial.print("] "); Serial.print("] LAST_DEBUG_ACTION_TRIG[");Serial.print(DEBUG_LAST_ACTION_TRIG);Serial.println("] ");
  428. // Serial.print("] COUNTER__MAIN_A["); Serial.print(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_A);
  429. // Serial.print("] COUNTER__MAIN_END_A["); Serial.print(ARDUINO_LOOP_LATENCY_COUNTER__MAIN_END_A);
  430. }
  431. DEBUG_LAST_ACTION_TRIG = DEBUG_ACTION_TRIG ;
  432. }
  433. #include "_PCINT/_PCINT_func_loop.h" //todo empty implement display etc
  434. #include "_Slave_Ports_func_loop.h" //todo implement