Bluecell_operate.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743
  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. ATT_TableSet = 0x70,
  303. ATT_TableGet = 0x71,
  304. Bluecell_StatusReq = 0x77,
  305. Bluecell_StatusSave = 0x78,
  306. };
  307. #define ALARM_ENVIRONMENT_FLAG 0x80
  308. #define ALARM_DL1_FLAG 0xFF
  309. #define ALARM_DL2_FLAG 0xFF
  310. #define ALARM_UL1_FLAG 0x0F
  311. #define ALARM_UL2_FLAG 0xFF
  312. typedef enum{
  313. ENVIRONMENT = 0,
  314. DL1,
  315. DL2,
  316. UL1,
  317. UL2,
  318. MAX_ALARM_Len,
  319. }AlarmList;
  320. typedef struct{
  321. uint16_t m15_dBm;
  322. uint16_t m16_dBm;
  323. uint16_t m17_dBm;
  324. uint16_t m18_dBm;
  325. uint16_t m19_dBm;
  326. uint16_t m20_dBm;
  327. uint16_t m21_dBm;
  328. uint16_t m22_dBm;
  329. uint16_t m23_dBm;
  330. uint16_t m24_dBm;
  331. uint16_t m25_dBm;
  332. uint16_t m26_dBm;
  333. uint16_t m27_dBm;
  334. uint16_t m28_dBm;
  335. uint16_t m29_dBm;
  336. uint16_t m30_dBm;
  337. uint16_t m31_dBm;
  338. uint16_t m32_dBm;
  339. uint16_t m33_dBm;
  340. uint16_t m34_dBm;
  341. uint16_t m35_dBm;
  342. uint16_t m36_dBm;
  343. uint16_t m37_dBm;
  344. uint16_t m38_dBm;
  345. uint16_t m39_dBm;
  346. uint16_t m40_dBm;
  347. uint16_t m41_dBm;
  348. uint16_t m42_dBm;
  349. uint16_t m43_dBm;
  350. uint16_t m44_dBm;
  351. uint16_t m45_dBm;
  352. uint16_t m46_dBm;
  353. uint16_t m47_dBm;
  354. uint16_t m48_dBm;
  355. uint16_t m49_dBm;
  356. uint16_t m50_dBm;
  357. uint16_t m51_dBm;
  358. uint16_t m52_dBm;
  359. uint16_t m53_dBm;
  360. uint16_t m54_dBm;
  361. uint16_t m55_dBm;
  362. uint16_t m56_dBm;
  363. uint16_t m57_dBm;
  364. uint16_t m58_dBm;
  365. uint16_t m59_dBm;
  366. uint16_t m60_dBm;
  367. }DET_UL;
  368. typedef struct{
  369. uint16_t p5_dBm;
  370. uint16_t p4_dBm;
  371. uint16_t p3_dBm;
  372. uint16_t p2_dBm;
  373. uint16_t p1_dBm;
  374. uint16_t m0_dBm;
  375. uint16_t m1_dBm;
  376. uint16_t m2_dBm;
  377. uint16_t m3_dBm;
  378. uint16_t m4_dBm;
  379. uint16_t m5_dBm;
  380. uint16_t m6_dBm;
  381. uint16_t m7_dBm;
  382. uint16_t m8_dBm;
  383. uint16_t m9_dBm;
  384. uint16_t m10_dBm;
  385. uint16_t m11_dBm;
  386. uint16_t m12_dBm;
  387. uint16_t m13_dBm;
  388. uint16_t m14_dBm;
  389. uint16_t m15_dBm;
  390. uint16_t m16_dBm;
  391. uint16_t m17_dBm;
  392. uint16_t m18_dBm;
  393. uint16_t m19_dBm;
  394. uint16_t m20_dBm;
  395. uint16_t m21_dBm;
  396. uint16_t m22_dBm;
  397. uint16_t m23_dBm;
  398. uint16_t m24_dBm;
  399. uint16_t m25_dBm;
  400. }DET_DL;
  401. typedef struct{
  402. uint8_t bluecell_header;
  403. uint8_t bluecell_type;
  404. uint8_t bluecell_length;
  405. uint8_t bluecell_crcindex;
  406. uint8_t Selftest0;
  407. uint8_t Selftest1;
  408. uint8_t Selftest2;
  409. uint8_t Selftest3;
  410. uint8_t ATT_DL1_PATH;
  411. uint8_t ATT_DL2_PATH;
  412. uint8_t ATT_DL3_PATH;
  413. uint8_t ATT_DL4_PATH;
  414. uint8_t ATT_UL1_PATH;
  415. uint8_t ATT_UL2_PATH;
  416. uint8_t ATT_UL3_PATH;
  417. uint8_t ATT_UL4_PATH;
  418. uint8_t ATT_DL1_H;
  419. uint8_t ATT_DL1_L;
  420. uint8_t ATT_DL2_H;
  421. uint8_t ATT_DL2_L;
  422. uint8_t ATT_DL3_H;
  423. uint8_t ATT_DL3_L;
  424. uint8_t ATT_DL4_H;
  425. uint8_t ATT_DL4_L;
  426. uint8_t ATT_UL1_H;
  427. uint8_t ATT_UL1_L;
  428. uint8_t ATT_UL2_H;
  429. uint8_t ATT_UL2_L;
  430. uint8_t ATT_UL3_H;
  431. uint8_t ATT_UL3_L;
  432. uint8_t ATT_UL4_H;
  433. uint8_t ATT_UL4_L;
  434. uint8_t DET_DL1_IN_H;//ADC3 5
  435. uint8_t DET_DL1_IN_L;//ADC3 5
  436. uint8_t DET_DL2_IN_H;//ADC3 6
  437. uint8_t DET_DL2_IN_L;//ADC3 6
  438. uint8_t DET_DL3_IN_H;//ADC3 7
  439. uint8_t DET_DL3_IN_L;//ADC3 7
  440. uint8_t DET_DL4_IN_H;//ADC3 8
  441. uint8_t DET_DL4_IN_L;//ADC3 8
  442. uint8_t DET_UL1_IN_H;//ADC1 4
  443. uint8_t DET_UL1_IN_L;//ADC1 4
  444. uint8_t DET_UL2_IN_H;//ADC1 5
  445. uint8_t DET_UL2_IN_L;//ADC1 5
  446. uint8_t DET_UL3_IN_H;//ADC1 6
  447. uint8_t DET_UL3_IN_L;//ADC1 6
  448. uint8_t DET_UL4_IN_H;//ADC3 4
  449. uint8_t DET_UL4_IN_L;//ADC3 4
  450. uint8_t DET_TEMP_H;
  451. uint8_t DET_TEMP_L;
  452. uint8_t ATT_AGC1_ONOFF;
  453. uint8_t ATT_ALC1_ONOFF;
  454. uint8_t ATT_AGC2_ONOFF;
  455. uint8_t ATT_ALC2_ONOFF;
  456. uint8_t ATT_AGC3_ONOFF;
  457. uint8_t ATT_ALC3_ONOFF;
  458. uint8_t ATT_AGC4_ONOFF;
  459. uint8_t ATT_ALC4_ONOFF;
  460. uint8_t ATT_ALC1_H;
  461. uint8_t ATT_ALC1_L;
  462. uint8_t ATT_ALC2_H;
  463. uint8_t ATT_ALC2_L;
  464. uint8_t ATT_ALC3_H;
  465. uint8_t ATT_ALC3_L;
  466. uint8_t ATT_ALC4_H;
  467. uint8_t ATT_ALC4_L;
  468. uint8_t ATT_AGC1_H;
  469. uint8_t ATT_AGC1_L;
  470. uint8_t ATT_AGC2_H;
  471. uint8_t ATT_AGC2_L;
  472. uint8_t ATT_AGC3_H;
  473. uint8_t ATT_AGC3_L;
  474. uint8_t ATT_AGC4_H;
  475. uint8_t ATT_AGC4_L;
  476. uint8_t bluecell_crc;
  477. uint8_t bluecell_etx;
  478. }BLUESTATUS_st;
  479. typedef struct{
  480. uint16_t Table_0_0_dBm ;
  481. uint16_t Table_0_5_dBm ;
  482. uint16_t Table_1_0_dBm ;
  483. uint16_t Table_1_5_dBm ;
  484. uint16_t Table_2_0_dBm ;
  485. uint16_t Table_2_5_dBm ;
  486. uint16_t Table_3_0_dBm ;
  487. uint16_t Table_3_5_dBm ;
  488. uint16_t Table_4_0_dBm ;
  489. uint16_t Table_4_5_dBm ;
  490. uint16_t Table_5_0_dBm ;
  491. uint16_t Table_5_5_dBm ;
  492. uint16_t Table_6_0_dBm ;
  493. uint16_t Table_6_5_dBm ;
  494. uint16_t Table_7_0_dBm ;
  495. uint16_t Table_7_5_dBm ;
  496. uint16_t Table_8_0_dBm ;
  497. uint16_t Table_8_5_dBm ;
  498. uint16_t Table_9_0_dBm ;
  499. uint16_t Table_9_5_dBm ;
  500. uint16_t Table_10_0_dBm;
  501. uint16_t Table_10_5_dBm;
  502. uint16_t Table_11_0_dBm;
  503. uint16_t Table_11_5_dBm;
  504. uint16_t Table_12_0_dBm;
  505. uint16_t Table_12_5_dBm;
  506. uint16_t Table_13_0_dBm;
  507. uint16_t Table_13_5_dBm;
  508. uint16_t Table_14_0_dBm;
  509. uint16_t Table_14_5_dBm;
  510. uint16_t Table_15_0_dBm;
  511. uint16_t Table_15_5_dBm;
  512. uint16_t Table_16_0_dBm;
  513. uint16_t Table_16_5_dBm;
  514. uint16_t Table_17_0_dBm;
  515. uint16_t Table_17_5_dBm;
  516. uint16_t Table_18_0_dBm;
  517. uint16_t Table_18_5_dBm;
  518. uint16_t Table_19_0_dBm;
  519. uint16_t Table_19_5_dBm;
  520. uint16_t Table_20_0_dBm;
  521. uint16_t Table_20_5_dBm;
  522. uint16_t Table_21_0_dBm;
  523. uint16_t Table_21_5_dBm;
  524. uint16_t Table_22_0_dBm;
  525. uint16_t Table_22_5_dBm;
  526. uint16_t Table_23_0_dBm;
  527. uint16_t Table_23_5_dBm;
  528. uint16_t Table_24_0_dBm;
  529. uint16_t Table_24_5_dBm;
  530. uint16_t Table_25_0_dBm;
  531. uint16_t Table_25_5_dBm;
  532. uint16_t Table_26_0_dBm;
  533. uint16_t Table_26_5_dBm;
  534. uint16_t Table_27_0_dBm;
  535. uint16_t Table_27_5_dBm;
  536. uint16_t Table_28_0_dBm;
  537. uint16_t Table_28_5_dBm;
  538. uint16_t Table_29_0_dBm;
  539. uint16_t Table_29_5_dBm;
  540. uint16_t Table_30_0_dBm;
  541. uint16_t Table_30_5_dBm;
  542. uint16_t Table_31_0_dBm;
  543. uint16_t Table_31_5_dBm;
  544. }ATT_TABLE_st;
  545. typedef struct{
  546. uint16_t Table_Det5_dBm ;
  547. uint16_t Table_Det4_dBm ;
  548. uint16_t Table_Det3_dBm ;
  549. uint16_t Table_Det2_dBm ;
  550. uint16_t Table_Det1_dBm ;
  551. uint16_t Table_Det0_dBm ;
  552. uint16_t Table_Det_1_dBm ;
  553. uint16_t Table_Det_2_dBm ;
  554. uint16_t Table_Det_3_dBm ;
  555. uint16_t Table_Det_4_dBm ;
  556. uint16_t Table_Det_5_dBm ;
  557. uint16_t Table_Det_6_dBm ;
  558. uint16_t Table_Det_7_dBm ;
  559. uint16_t Table_Det_8_dBm ;
  560. uint16_t Table_Det_9_dBm ;
  561. uint16_t Table_Det_10_dBm ;
  562. uint16_t Table_Det_11_dBm ;
  563. uint16_t Table_Det_12_dBm ;
  564. uint16_t Table_Det_13_dBm ;
  565. uint16_t Table_Det_14_dBm ;
  566. uint16_t Table_Det_15_dBm ;
  567. uint16_t Table_Det_16_dBm ;
  568. uint16_t Table_Det_17_dBm ;
  569. uint16_t Table_Det_18_dBm ;
  570. uint16_t Table_Det_19_dBm ;
  571. uint16_t Table_Det_20_dBm ;
  572. uint16_t Table_Det_21_dBm ;
  573. uint16_t Table_Det_22_dBm ;
  574. uint16_t Table_Det_23_dBm ;
  575. uint16_t Table_Det_24_dBm ;
  576. uint16_t Table_Det_25_dBm ;
  577. }DET_TABLEDL_st;
  578. typedef struct{
  579. uint16_t Table_Det_15_dBm ;
  580. uint16_t Table_Det_16_dBm ;
  581. uint16_t Table_Det_17_dBm ;
  582. uint16_t Table_Det_18_dBm ;
  583. uint16_t Table_Det_19_dBm ;
  584. uint16_t Table_Det_20_dBm ;
  585. uint16_t Table_Det_21_dBm ;
  586. uint16_t Table_Det_22_dBm ;
  587. uint16_t Table_Det_23_dBm ;
  588. uint16_t Table_Det_24_dBm ;
  589. uint16_t Table_Det_25_dBm ;
  590. uint16_t Table_Det_26_dBm ;
  591. uint16_t Table_Det_27_dBm ;
  592. uint16_t Table_Det_28_dBm ;
  593. uint16_t Table_Det_29_dBm ;
  594. uint16_t Table_Det_30_dBm ;
  595. uint16_t Table_Det_31_dBm ;
  596. uint16_t Table_Det_32_dBm ;
  597. uint16_t Table_Det_33_dBm ;
  598. uint16_t Table_Det_34_dBm ;
  599. uint16_t Table_Det_35_dBm ;
  600. uint16_t Table_Det_36_dBm ;
  601. uint16_t Table_Det_37_dBm ;
  602. uint16_t Table_Det_38_dBm ;
  603. uint16_t Table_Det_39_dBm ;
  604. uint16_t Table_Det_40_dBm ;
  605. uint16_t Table_Det_41_dBm ;
  606. uint16_t Table_Det_42_dBm ;
  607. uint16_t Table_Det_43_dBm ;
  608. uint16_t Table_Det_44_dBm ;
  609. uint16_t Table_Det_45_dBm ;
  610. uint16_t Table_Det_46_dBm ;
  611. uint16_t Table_Det_47_dBm ;
  612. uint16_t Table_Det_48_dBm ;
  613. uint16_t Table_Det_49_dBm ;
  614. uint16_t Table_Det_50_dBm ;
  615. uint16_t Table_Det_51_dBm ;
  616. uint16_t Table_Det_52_dBm ;
  617. uint16_t Table_Det_53_dBm ;
  618. uint16_t Table_Det_54_dBm ;
  619. uint16_t Table_Det_55_dBm ;
  620. uint16_t Table_Det_56_dBm ;
  621. uint16_t Table_Det_57_dBm ;
  622. uint16_t Table_Det_58_dBm ;
  623. uint16_t Table_Det_59_dBm ;
  624. uint16_t Table_Det_60_dBm ;
  625. }DET_TABLEUL_st;
  626. typedef struct{
  627. uint16_t Table_10_Temp;
  628. uint16_t Table_15_Temp;
  629. uint16_t Table_20_Temp;
  630. uint16_t Table_25_Temp;
  631. uint16_t Table_30_Temp;
  632. uint16_t Table_35_Temp;
  633. uint16_t Table_40_Temp;
  634. uint16_t Table_45_Temp;
  635. uint16_t Table_50_Temp;
  636. uint16_t Table_55_Temp;
  637. }TEMP_TABLE_st;
  638. typedef enum{
  639. Bluecell_DET_UL1_ADC_INDEX_H = 0,
  640. Bluecell_DET_UL1_ADC_INDEX_L,
  641. Bluecell_DET_UL2_ADC_INDEX_H,
  642. Bluecell_DET_UL2_ADC_INDEX_L,
  643. Bluecell_DET_UL3_ADC_INDEX_H,
  644. Bluecell_DET_UL3_ADC_INDEX_L,
  645. Bluecell_RFU_TEMP_ADC_INDEX_H,
  646. Bluecell_RFU_TEMP_ADC_INDEX_L,
  647. Bluecell_ADC1_MaxLength,
  648. }Bluecell_ADC1_Index;
  649. typedef enum{
  650. Bluecell_DET_UL4_ADC_INDEX_H = Bluecell_ADC1_MaxLength,
  651. Bluecell_DET_UL4_ADC_INDEX_L,
  652. Bluecell_DET_DL1_ADC_INDEX_H,
  653. Bluecell_DET_DL1_ADC_INDEX_L,
  654. Bluecell_DET_DL2_ADC_INDEX_H,
  655. Bluecell_DET_DL2_ADC_INDEX_L,
  656. Bluecell_DET_DL3_ADC_INDEX_H,
  657. Bluecell_DET_DL3_ADC_INDEX_L,
  658. Bluecell_DET_DL4_ADC_INDEX_H,
  659. Bluecell_DET_DL4_ADC_INDEX_L,
  660. Bluecell_ADC3_MaxLength,
  661. }Bluecell_ADC3_Index;
  662. #define ADC1_EA Bluecell_ADC1_MaxLength /2
  663. #define ADC3_EA Bluecell_ADC3_MaxLength /2
  664. extern ATT_TABLE_st Att_DL1;
  665. extern ATT_TABLE_st Att_DL2;
  666. extern ATT_TABLE_st Att_DL3;
  667. extern ATT_TABLE_st Att_DL4;
  668. extern ATT_TABLE_st Att_UL1;
  669. extern ATT_TABLE_st Att_UL2;
  670. extern ATT_TABLE_st Att_UL3;
  671. extern ATT_TABLE_st Att_UL4;
  672. extern DET_TABLEDL_st Det_DL1;
  673. extern DET_TABLEDL_st Det_DL2;
  674. extern DET_TABLEDL_st Det_DL3;
  675. extern DET_TABLEDL_st Det_DL4;
  676. extern DET_TABLEUL_st Det_UL1;
  677. extern DET_TABLEUL_st Det_UL2;
  678. extern DET_TABLEUL_st Det_UL3;
  679. extern DET_TABLEUL_st Det_UL4;
  680. extern TEMP_TABLE_st Temp_DL1;
  681. extern TEMP_TABLE_st Temp_DL2;
  682. extern TEMP_TABLE_st Temp_DL3;
  683. extern TEMP_TABLE_st Temp_DL4;
  684. extern TEMP_TABLE_st Temp_UL1;
  685. extern TEMP_TABLE_st Temp_UL2;
  686. extern TEMP_TABLE_st Temp_UL3;
  687. extern TEMP_TABLE_st Temp_UL4;
  688. extern BLUESTATUS_st bluecell_Currdatastatus;
  689. extern void Bluecell_DataInit();
  690. #endif /* BLUECELL_OPERATE_H_ */