Bluecell_operate.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  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. }MBICBootProt_st;
  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. }MBICProt_st;
  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. ATTSET = 0x11,
  282. ATT_DL1_PATH = 0x12,
  283. ATT_UL1_PATH = 0x16,
  284. ATT_SelfTest1 = 0x18,
  285. ATT_DL2_PATH = 0x22,
  286. ATT_UL2_PATH = 0x26,
  287. ATT_SelfTest2 = 0x28,
  288. ATT_DL3_PATH = 0x32,
  289. ATT_UL3_PATH = 0x36,
  290. ATT_SelfTest3 = 0x38,
  291. ATT_DL4_PATH = 0x42,
  292. ATT_UL4_PATH = 0x46,
  293. ATT_SelfTest4 = 0x48,
  294. ALC1_EN = 0x51,
  295. ALC2_EN = 0x52,
  296. ALC3_EN = 0x53,
  297. ALC4_EN = 0x54,
  298. AGC1_EN = 0x61,
  299. AGC2_EN = 0x62,
  300. AGC3_EN = 0x63,
  301. AGC4_EN = 0x64,
  302. Bluecell_StatusReq = 0x77,
  303. };
  304. #define ALARM_ENVIRONMENT_FLAG 0x80
  305. #define ALARM_DL1_FLAG 0xFF
  306. #define ALARM_DL2_FLAG 0xFF
  307. #define ALARM_UL1_FLAG 0x0F
  308. #define ALARM_UL2_FLAG 0xFF
  309. typedef enum{
  310. ENVIRONMENT = 0,
  311. DL1,
  312. DL2,
  313. UL1,
  314. UL2,
  315. MAX_ALARM_Len,
  316. }AlarmList;
  317. typedef struct{
  318. uint16_t m15_dBm;
  319. uint16_t m16_dBm;
  320. uint16_t m17_dBm;
  321. uint16_t m18_dBm;
  322. uint16_t m19_dBm;
  323. uint16_t m20_dBm;
  324. uint16_t m21_dBm;
  325. uint16_t m22_dBm;
  326. uint16_t m23_dBm;
  327. uint16_t m24_dBm;
  328. uint16_t m25_dBm;
  329. uint16_t m26_dBm;
  330. uint16_t m27_dBm;
  331. uint16_t m28_dBm;
  332. uint16_t m29_dBm;
  333. uint16_t m30_dBm;
  334. uint16_t m31_dBm;
  335. uint16_t m32_dBm;
  336. uint16_t m33_dBm;
  337. uint16_t m34_dBm;
  338. uint16_t m35_dBm;
  339. uint16_t m36_dBm;
  340. uint16_t m37_dBm;
  341. uint16_t m38_dBm;
  342. uint16_t m39_dBm;
  343. uint16_t m40_dBm;
  344. uint16_t m41_dBm;
  345. uint16_t m42_dBm;
  346. uint16_t m43_dBm;
  347. uint16_t m44_dBm;
  348. uint16_t m45_dBm;
  349. uint16_t m46_dBm;
  350. uint16_t m47_dBm;
  351. uint16_t m48_dBm;
  352. uint16_t m49_dBm;
  353. uint16_t m50_dBm;
  354. uint16_t m51_dBm;
  355. uint16_t m52_dBm;
  356. uint16_t m53_dBm;
  357. uint16_t m54_dBm;
  358. uint16_t m55_dBm;
  359. uint16_t m56_dBm;
  360. uint16_t m57_dBm;
  361. uint16_t m58_dBm;
  362. uint16_t m59_dBm;
  363. uint16_t m60_dBm;
  364. }DET_UL;
  365. typedef struct{
  366. uint16_t p5_dBm;
  367. uint16_t p4_dBm;
  368. uint16_t p3_dBm;
  369. uint16_t p2_dBm;
  370. uint16_t p1_dBm;
  371. uint16_t m0_dBm;
  372. uint16_t m1_dBm;
  373. uint16_t m2_dBm;
  374. uint16_t m3_dBm;
  375. uint16_t m4_dBm;
  376. uint16_t m5_dBm;
  377. uint16_t m6_dBm;
  378. uint16_t m7_dBm;
  379. uint16_t m8_dBm;
  380. uint16_t m9_dBm;
  381. uint16_t m10_dBm;
  382. uint16_t m11_dBm;
  383. uint16_t m12_dBm;
  384. uint16_t m13_dBm;
  385. uint16_t m14_dBm;
  386. uint16_t m15_dBm;
  387. uint16_t m16_dBm;
  388. uint16_t m17_dBm;
  389. uint16_t m18_dBm;
  390. uint16_t m19_dBm;
  391. uint16_t m20_dBm;
  392. uint16_t m21_dBm;
  393. uint16_t m22_dBm;
  394. uint16_t m23_dBm;
  395. uint16_t m24_dBm;
  396. uint16_t m25_dBm;
  397. }DET_DL;
  398. typedef struct{
  399. uint8_t bluecell_header;
  400. uint8_t bluecell_type;
  401. uint8_t bluecell_length;
  402. uint8_t bluecell_crcindex;
  403. uint8_t Selftest0;
  404. uint8_t Selftest1;
  405. uint8_t Selftest2;
  406. uint8_t Selftest3;
  407. uint8_t ATT_DL1_PATH;
  408. uint8_t ATT_DL2_PATH;
  409. uint8_t ATT_DL3_PATH;
  410. uint8_t ATT_DL4_PATH;
  411. uint8_t ATT_UL1_PATH;
  412. uint8_t ATT_UL2_PATH;
  413. uint8_t ATT_UL3_PATH;
  414. uint8_t ATT_UL4_PATH;
  415. uint8_t ATT_DL1_H;
  416. uint8_t ATT_DL1_L;
  417. uint8_t ATT_DL2_H;
  418. uint8_t ATT_DL2_L;
  419. uint8_t ATT_DL3_H;
  420. uint8_t ATT_DL3_L;
  421. uint8_t ATT_DL4_H;
  422. uint8_t ATT_DL4_L;
  423. uint8_t ATT_UL1_H;
  424. uint8_t ATT_UL1_L;
  425. uint8_t ATT_UL2_H;
  426. uint8_t ATT_UL2_L;
  427. uint8_t ATT_UL3_H;
  428. uint8_t ATT_UL3_L;
  429. uint8_t ATT_UL4_H;
  430. uint8_t ATT_UL4_L;
  431. uint8_t DET_DL1_IN_H;
  432. uint8_t DET_DL1_IN_L;
  433. uint8_t DET_DL2_IN_H;
  434. uint8_t DET_DL2_IN_L;
  435. uint8_t DET_DL3_IN_H;
  436. uint8_t DET_DL3_IN_L;
  437. uint8_t DET_DL4_IN_H;
  438. uint8_t DET_DL4_IN_L;
  439. uint8_t DET_UL1_IN_H;
  440. uint8_t DET_UL1_IN_L;
  441. uint8_t DET_UL2_IN_H;
  442. uint8_t DET_UL2_IN_L;
  443. uint8_t DET_UL3_IN_H;
  444. uint8_t DET_UL3_IN_L;
  445. uint8_t DET_UL4_IN_H;
  446. uint8_t DET_UL4_IN_L;
  447. uint8_t DET_TEMP_H;
  448. uint8_t DET_TEMP_L;
  449. uint8_t ATT_AGC1_ONOFF;
  450. uint8_t ATT_ALC1_ONOFF;
  451. uint8_t ATT_AGC2_ONOFF;
  452. uint8_t ATT_ALC2_ONOFF;
  453. uint8_t ATT_AGC3_ONOFF;
  454. uint8_t ATT_ALC3_ONOFF;
  455. uint8_t ATT_AGC4_ONOFF;
  456. uint8_t ATT_ALC4_ONOFF;
  457. uint8_t ATT_AGC1_H;
  458. uint8_t ATT_AGC1_L;
  459. uint8_t ATT_ALC1_H;
  460. uint8_t ATT_ALC1_L;
  461. uint8_t ATT_AGC2_H;
  462. uint8_t ATT_AGC2_L;
  463. uint8_t ATT_ALC2_H;
  464. uint8_t ATT_ALC2_L;
  465. uint8_t ATT_AGC3_H;
  466. uint8_t ATT_AGC3_L;
  467. uint8_t ATT_ALC3_H;
  468. uint8_t ATT_ALC3_L;
  469. uint8_t ATT_AGC4_H;
  470. uint8_t ATT_AGC4_L;
  471. uint8_t ATT_ALC4_H;
  472. uint8_t ATT_ALC4_L;
  473. uint8_t bluecell_crc;
  474. }BLUESTATUS_st;
  475. typedef enum{
  476. Bluecell_DET_UL1_ADC_INDEX_H = 0,
  477. Bluecell_DET_UL1_ADC_INDEX_L,
  478. Bluecell_DET_UL2_ADC_INDEX_H,
  479. Bluecell_DET_UL2_ADC_INDEX_L,
  480. Bluecell_DET_UL3_ADC_INDEX_H,
  481. Bluecell_DET_UL3_ADC_INDEX_L,
  482. Bluecell_RFU_TEMP_ADC_INDEX_H,
  483. Bluecell_RFU_TEMP_ADC_INDEX_L,
  484. Bluecell_ADC1_MaxLength,
  485. }Bluecell_ADC1_Index;
  486. typedef enum{
  487. Bluecell_DET_UL4_ADC_INDEX_H = Bluecell_ADC1_MaxLength,
  488. Bluecell_DET_UL4_ADC_INDEX_L,
  489. Bluecell_DET_DL1_ADC_INDEX_H,
  490. Bluecell_DET_DL1_ADC_INDEX_L,
  491. Bluecell_DET_DL2_ADC_INDEX_H,
  492. Bluecell_DET_DL2_ADC_INDEX_L,
  493. Bluecell_DET_DL3_ADC_INDEX_H,
  494. Bluecell_DET_DL3_ADC_INDEX_L,
  495. Bluecell_DET_DL4_ADC_INDEX_H,
  496. Bluecell_DET_DL4_ADC_INDEX_L,
  497. Bluecell_ADC3_MaxLength,
  498. }Bluecell_ADC3_Index;
  499. #define ADC1_EA Bluecell_ADC1_MaxLength /2
  500. #define ADC3_EA Bluecell_ADC3_MaxLength /2
  501. #endif /* BLUECELL_OPERATE_H_ */