Bluecell_operate.h 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. /*
  2. * Bluecell_operate.h
  3. *
  4. * Created on: 2020. 4. 3.
  5. * Author: YJ
  6. */
  7. #ifndef BLUECELL_OPERATE_H_
  8. #define BLUECELL_OPERATE_H_
  9. #include <stdbool.h>
  10. #include "Bluecell_operate.h"
  11. /*
  12. SYN
  13. Sub-UID
  14. R-Code
  15. TR-ID
  16. Seq-Num
  17. TTL
  18. Time
  19. ���� ����
  20. CMD
  21. Length
  22. Header Checksum
  23. SUB-DATA
  24. SUB-DATA-CRC
  25. ETX
  26. */
  27. /*
  28. *
  29. 0 80 ��ü ���� ��ȸ ��� AID �׸� ���� ���� ��û �� ���� (��û Frame�� SUB-DATA �� ���̴� 0)
  30. 1 81 ���� ��û ���� ��û�� REQ�� 0x01 �̰� ������ ��ü ������ ���¸� ����
  31. 10 90 Download Notification �ٿ�ε� ����
  32. 11 91 Download Data �ٿ�ε� data
  33. 12 92 Download Confirm �ٿ�ε� Ȯ��
  34. 13 93 Download Complete Download Complete Command
  35. 14 94 System-Reboot System Rebooting Command
  36. 40 C0 ���̺� ��ȸ �� ����
  37. 41 C1 ���̺� ���� �� ����
  38. *
  39. *
  40. */
  41. typedef enum{
  42. AllDataReq = 0, // -> Response 80
  43. DataCtrlReq, // -> Response 81
  44. DownNotification, // -> Response 90
  45. DownData, // -> Response 91
  46. DownConfirm , // -> Response 92
  47. DownComplete, // -> Response 93
  48. SystemReboot, // -> Response 94
  49. TableDataReq = 40,
  50. };
  51. typedef enum{
  52. MBIC_PREAMBLE_0 = 0,
  53. MBIC_PREAMBLE_1,
  54. MBIC_PREAMBLE_2,
  55. MBIC_PREAMBLE_3,
  56. MBIC_SUBUID_0,
  57. MBIC_SUBUID_1,
  58. MBIC_RCODE_0,
  59. MBIC_TRID_0,
  60. MBIC_TRID_1,
  61. MBIC_SEQSUM_0, // 10byte
  62. MBIC_TTL_0,
  63. MBIC_TIME_0,
  64. MBIC_TIME_1,
  65. MBIC_TIME_2,
  66. MBIC_TIME_3,
  67. MBIC_TIME_4,
  68. MBIC_TIME_5,
  69. MBIC_ERRRESPONSE_0,
  70. MBIC_CMD_0,
  71. MBIC_LENGTH_0, // 20byte
  72. MBIC_LENGTH_1,
  73. MBIC_HEADERCHECKSUM_0,
  74. MBIC_PAYLOADSTART,
  75. /*
  76. * PayLoadSTART
  77. */
  78. };
  79. typedef enum{
  80. Alarm_Bit_List = 0xE000,
  81. Alarm_Mask,
  82. Alarm_Test_Mode,
  83. Alarm_Test_Dummy,
  84. CPU_Version,
  85. ModuleINFORMATION_null1,
  86. CPU_Current_Bank,
  87. CPU_Bank_Select_Reboot_by,
  88. CPU_Bank1_Image_Version,
  89. CPU_Bank1_Image_BuildTime,
  90. CPU_Bank1_Image_Name,
  91. CPU_Bank2_Image_Version,
  92. CPU_Bank2_Image_BuildTime,
  93. CPU_Bank2_Image_Name,
  94. SW_Reset,
  95. Factory_Set_Initialization,
  96. }ModuleINFORMATION;
  97. typedef enum{
  98. Temperature = 0xE010,
  99. Temperature_Offset,
  100. Temp_High_Threshold,
  101. Temp_High_Threshold_Default,
  102. Temp_High_Alarm,
  103. LED_TEST,
  104. Node,
  105. Type,
  106. PCB_Version,
  107. Serial_Number,
  108. Manufacture,
  109. Manufacture_Date,
  110. ENVIRONMENT_INVENTORY_null1,
  111. Freq_ID,
  112. Carrier_ID,
  113. Carrier_ON_OFF,
  114. }ENVIRONMENT_INVENTORY;
  115. typedef enum{
  116. DLI_P1_Level= 0xE020,
  117. DLI_P2_Level,
  118. DLI_P3_Level,
  119. DLI_P4_Level,
  120. ULO_P1_Level,
  121. ULO_P2_Level,
  122. ULO_P3_Level,
  123. ULO_P4_Level,
  124. }Current_Volt;
  125. typedef enum{
  126. DLI_RF_Path1_ON_OFF= 0xE030,
  127. DLI_RF_Path2_ON_OFF,
  128. DLI_RF_Path3_ON_OFF,
  129. DLI_RF_Path4_ON_OFF,
  130. DLI_Gain_Atten1,
  131. DLI_Gain_Atten2,
  132. DLI_Gain_Atten3,
  133. DLI_Gain_Atten4,
  134. DLI_Gain_Atten_Offset1,
  135. DLI_Gain_Atten_Offset2,
  136. DLI_Gain_Atten_Offset3,
  137. DLI_Gain_Atten_Offset4,
  138. DLI_Level_High_Threshold,
  139. DLI_Level_Low_Threshold,
  140. DLI_Level_High_Low_Threshold_default,
  141. DLI_Level,
  142. }DL_Ctrl1;
  143. typedef enum{
  144. DLI_Level_High_Alarm1= 0xE040,
  145. DLI_Level_High_Alarm2,
  146. DLI_Level_High_Alarm3,
  147. DLI_Level_High_Alarm4,
  148. DLI_Level_Low_Alarm1,
  149. DLI_Level_Low_Alarm2,
  150. DLI_Level_Low_Alarm3,
  151. DLI_Level_Low_Alarm4,
  152. }DL_Ctrl2;
  153. typedef enum{
  154. DLI_AGC_ON_OFF= 0xE050,
  155. DLI_AGC_Threshold,
  156. DLI_AGC_Threshold_Default,
  157. DLI_Shutdown_ON_OFF,
  158. DLI_Shutdown_Threshold,
  159. DLI_Shutdown_Threshold_Default,
  160. DLI_Shutdown_Count,
  161. DLI_AGC_Alarm1,
  162. DLI_AGC_Alarm2,
  163. DLI_AGC_Alarm3,
  164. DLI_AGC_Alarm4,
  165. DLI_Shutdown_Alarm1,
  166. DLI_Shutdown_Alarm2,
  167. DLI_Shutdown_Alarm3,
  168. DLI_Shutdown_Alarm4,
  169. }DL_Ctrl3;
  170. typedef enum{
  171. ULO_RF_Path1_ON_OFF= 0xE060,
  172. ULO_RF_Path2_ON_OFF,
  173. ULO_RF_Path3_ON_OFF,
  174. ULO_RF_Path4_ON_OFF,
  175. ULO_Gain_Atten1,
  176. ULO_Gain_Atten2,
  177. ULO_Gain_Atten3,
  178. ULO_Gain_Atten4,
  179. ULO_Gain_Atten_Offset1,
  180. ULO_Gain_Atten_Offset2,
  181. ULO_Gain_Atten_Offset3,
  182. ULO_Gain_Atten_Offset4,
  183. ULO_Level_High_Threshold,
  184. UL_Ctrl1_null1,
  185. ULO_Level_High_Threshold_default,
  186. ULO_Level,
  187. }UL_Ctrl1;
  188. typedef enum{
  189. ULO_Level_High_Alarm1= 0xE070,
  190. ULO_Level_High_Alarm2,
  191. ULO_Level_High_Alarm3,
  192. ULO_Level_High_Alarm4,
  193. }UL_Ctrl2;
  194. typedef enum{
  195. ULO_ALC_ON_OFF= 0xE080,
  196. ULO_ALC_Threshold,
  197. ULO_ALC_Threshold_Default,
  198. ULO_Shutdown_ON_OFF,
  199. ULO_Shutdown_Threshold,
  200. ULO_Shutdown_Threshold_Default,
  201. ULO_Shutdown_Retry_Count,
  202. ULO_ALC_Alarm1,
  203. ULO_ALC_Alarm2,
  204. ULO_ALC_Alarm3,
  205. ULO_ALC_Alarm4,
  206. ULO_Shutdown_Alarm1,
  207. ULO_Shutdown_Alarm2,
  208. ULO_Shutdown_Alarm3,
  209. ULO_Shutdown_Alarm4,
  210. }UL_Ctrl3;
  211. #define MBIC_PREAMBLE0 0x16
  212. #define MBIC_PREAMBLE1 0x16
  213. #define MBIC_PREAMBLE2 0x16
  214. #define MBIC_PREAMBLE3 0x16
  215. #define MBIC_SUBUID0 0x00
  216. #define MBIC_SUBUID1 0xF1
  217. #define MBIC_RCODE
  218. #define MBIC_TRID
  219. #define MBIC_SEQNUM
  220. #define MBIC_TTL
  221. #define MBIC_TIME
  222. #define MBIC_ERRRESPONSE
  223. #define MBIC_CMD
  224. #define MBIC_LENGTH
  225. #define MBIC_CHECKSHUM
  226. #define MBIC_ETX 0x03
  227. /*
  228. *
  229. *
  230. * ALARM LIST
  231. *
  232. */
  233. struct Alarm_ENVIRONMENT {
  234. uint8_t ENVIRONMENT_Temp_High ;
  235. uint8_t ENVIRONMENT_Reserved0 ;
  236. uint8_t ENVIRONMENT_Reserved1 ;
  237. uint8_t ENVIRONMENT_Reserved2 ;
  238. uint8_t ENVIRONMENT_Reserved3 ;
  239. uint8_t ENVIRONMENT_Reserved4 ;
  240. uint8_t ENVIRONMENT_Reserved5 ;
  241. uint8_t ENVIRONMENT_Reserved6 ;
  242. };
  243. struct Alarm_DL {
  244. uint8_t DLI_P4_Level_Low ;
  245. uint8_t DLI_P3_Level_Low ;
  246. uint8_t DLI_P2_Level_Low ;
  247. uint8_t DLI_P1_Level_Low ;
  248. uint8_t ULO_P4_Level_High ;
  249. uint8_t ULO_P3_Level_High ;
  250. uint8_t ULO_P2_Level_High ;
  251. uint8_t ULO_P1_Level_High ;
  252. uint8_t DLI_P4_AGC_Alarm ;
  253. uint8_t DLI_P3_AGC_Alarm ;
  254. uint8_t DLI_P2_AGC_Alarm ;
  255. uint8_t DLI_P1_AGC_Alarm ;
  256. uint8_t DLI_P4_Shutdown_Alarm ;
  257. uint8_t DLI_P3_Shutdown_Alarm ;
  258. uint8_t DLI_P2_Shutdown_Alarm ;
  259. uint8_t DLI_P1_Shutdown_Alarm ;
  260. };
  261. struct Alarm_UL {
  262. uint8_t Reserved0 ;
  263. uint8_t Reserved1 ;
  264. uint8_t Reserved2 ;
  265. uint8_t Reserved3 ;
  266. uint8_t ULO_P4_Level_High ;
  267. uint8_t ULO_P3_Level_High ;
  268. uint8_t ULO_P2_Level_High ;
  269. uint8_t ULO_P1_Level_High ;
  270. uint8_t ULO_P4_ALC_Alarm ;
  271. uint8_t ULO_P3_ALC_Alarm ;
  272. uint8_t ULO_P2_ALC_Alarm ;
  273. uint8_t ULO_P1_ALC_Alarm ;
  274. uint8_t ULO_P4_Shutdown ;
  275. uint8_t ULO_P3_Shutdown ;
  276. uint8_t ULO_P2_Shutdown ;
  277. uint8_t ULO_P1_Shutdown ;
  278. };
  279. enum DATATYPE
  280. {
  281. ATTDL1 = 0x11,
  282. ATT_DL1_PATH_OFF = 0x12,
  283. ATT_DL1_PATH_ON = 0x13,
  284. ATTUL1 = 0x15,
  285. ATT_UL1_PATH_OFF = 0x16,
  286. ATT_UL1_PATH_ON = 0x17,
  287. ATT_SelfTest1_OFF = 0x18,
  288. ATT_SelfTest1_ON = 0x19,
  289. ATTDL2 = 0x21,
  290. ATT_DL2_PATH_OFF = 0x22,
  291. ATT_DL2_PATH_ON = 0x23,
  292. ATTUL2 = 0x25,
  293. ATT_UL2_PATH_OFF = 0x26,
  294. ATT_UL2_PATH_ON = 0x27,
  295. ATT_SelfTest2_OFF = 0x28,
  296. ATT_SelfTest2_ON = 0x29,
  297. ATTDL3 = 0x31,
  298. ATT_DL3_PATH_OFF = 0x32,
  299. ATT_DL3_PATH_ON = 0x33,
  300. ATTUL3 = 0x35,
  301. ATT_UL3_PATH_OFF = 0x36,
  302. ATT_UL3_PATH_ON = 0x37,
  303. ATT_SelfTest3_OFF = 0x38,
  304. ATT_SelfTest3_ON = 0x39,
  305. ATTDL4 = 0x41,
  306. ATT_DL4_PATH_OFF = 0x42,
  307. ATT_DL4_PATH_ON = 0x43,
  308. ATTUL4 = 0x45,
  309. ATT_UL4_PATH_OFF = 0x46,
  310. ATT_UL4_PATH_ON = 0x47,
  311. ATT_SelfTest4_OFF = 0x48,
  312. ATT_SelfTest4_ON = 0x49,
  313. };
  314. #define ALARM_ENVIRONMENT_FLAG 0x80
  315. #define ALARM_DL1_FLAG 0xFF
  316. #define ALARM_DL2_FLAG 0xFF
  317. #define ALARM_UL1_FLAG 0x0F
  318. #define ALARM_UL2_FLAG 0xFF
  319. typedef enum{
  320. ENVIRONMENT = 0,
  321. DL1,
  322. DL2,
  323. UL1,
  324. UL2,
  325. MAX_ALARM_Len,
  326. }AlarmList;
  327. typedef struct{
  328. uint16_t m15_dBm;
  329. uint16_t m16_dBm;
  330. uint16_t m17_dBm;
  331. uint16_t m18_dBm;
  332. uint16_t m19_dBm;
  333. uint16_t m20_dBm;
  334. uint16_t m21_dBm;
  335. uint16_t m22_dBm;
  336. uint16_t m23_dBm;
  337. uint16_t m24_dBm;
  338. uint16_t m25_dBm;
  339. uint16_t m26_dBm;
  340. uint16_t m27_dBm;
  341. uint16_t m28_dBm;
  342. uint16_t m29_dBm;
  343. uint16_t m30_dBm;
  344. uint16_t m31_dBm;
  345. uint16_t m32_dBm;
  346. uint16_t m33_dBm;
  347. uint16_t m34_dBm;
  348. uint16_t m35_dBm;
  349. uint16_t m36_dBm;
  350. uint16_t m37_dBm;
  351. uint16_t m38_dBm;
  352. uint16_t m39_dBm;
  353. uint16_t m40_dBm;
  354. uint16_t m41_dBm;
  355. uint16_t m42_dBm;
  356. uint16_t m43_dBm;
  357. uint16_t m44_dBm;
  358. uint16_t m45_dBm;
  359. uint16_t m46_dBm;
  360. uint16_t m47_dBm;
  361. uint16_t m48_dBm;
  362. uint16_t m49_dBm;
  363. uint16_t m50_dBm;
  364. uint16_t m51_dBm;
  365. uint16_t m52_dBm;
  366. uint16_t m53_dBm;
  367. uint16_t m54_dBm;
  368. uint16_t m55_dBm;
  369. uint16_t m56_dBm;
  370. uint16_t m57_dBm;
  371. uint16_t m58_dBm;
  372. uint16_t m59_dBm;
  373. uint16_t m60_dBm;
  374. }DET_UL;
  375. typedef struct{
  376. uint16_t p5_dBm;
  377. uint16_t p4_dBm;
  378. uint16_t p3_dBm;
  379. uint16_t p2_dBm;
  380. uint16_t p1_dBm;
  381. uint16_t m0_dBm;
  382. uint16_t m1_dBm;
  383. uint16_t m2_dBm;
  384. uint16_t m3_dBm;
  385. uint16_t m4_dBm;
  386. uint16_t m5_dBm;
  387. uint16_t m6_dBm;
  388. uint16_t m7_dBm;
  389. uint16_t m8_dBm;
  390. uint16_t m9_dBm;
  391. uint16_t m10_dBm;
  392. uint16_t m11_dBm;
  393. uint16_t m12_dBm;
  394. uint16_t m13_dBm;
  395. uint16_t m14_dBm;
  396. uint16_t m15_dBm;
  397. uint16_t m16_dBm;
  398. uint16_t m17_dBm;
  399. uint16_t m18_dBm;
  400. uint16_t m19_dBm;
  401. uint16_t m20_dBm;
  402. uint16_t m21_dBm;
  403. uint16_t m22_dBm;
  404. uint16_t m23_dBm;
  405. uint16_t m24_dBm;
  406. uint16_t m25_dBm;
  407. }DET_DL;
  408. #endif /* BLUECELL_OPERATE_H_ */