123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539 |
- /*
- * Bluecell_operate.h
- *
- * Created on: 2020. 4. 3.
- * Author: YJ
- */
- #ifndef BLUECELL_OPERATE_H_
- #define BLUECELL_OPERATE_H_
- #include <stdbool.h>
- #include "Bluecell_operate.h"
- /*
- SYN
- Sub-UID
- R-Code
- TR-ID
- Seq-Num
- TTL
- Time
- ���� ����
- CMD
- Length
- Header Checksum
- SUB-DATA
- SUB-DATA-CRC
- ETX
- */
- /*
- *
- 0 80 ��ü ���� ��ȸ ��� AID �� ���� ���� ��û �� ���� (��û Frame�� SUB-DATA �� ���̴� 0)
- 1 81 ���� ��û ���� ��û�� REQ�� 0x01 �̰� ������ ��ü ������ ���¸� ����
- 10 90 Download Notification �ٿ�ε� ����
- 11 91 Download Data �ٿ�ε� data
- 12 92 Download Confirm �ٿ�ε� Ȯ��
- 13 93 Download Complete Download Complete Command
- 14 94 System-Reboot System Rebooting Command
- 40 C0 ���̺� ��ȸ �� ����
- 41 C1 ���̺� ���� �� ����
- *
- *
- */
- typedef enum{
- AllDataReq = 0, // -> Response 80
- DataCtrlReq, // -> Response 81
- DownNotification, // -> Response 90
- DownData, // -> Response 91
- DownConfirm , // -> Response 92
- DownComplete, // -> Response 93
- SystemReboot, // -> Response 94
- TableDataReq = 40,
- }MBICBootProt_st;
- typedef enum{
- MBIC_PREAMBLE_0 = 0,
- MBIC_PREAMBLE_1,
- MBIC_PREAMBLE_2,
- MBIC_PREAMBLE_3,
- MBIC_SUBUID_0,
- MBIC_SUBUID_1,
- MBIC_RCODE_0,
- MBIC_TRID_0,
- MBIC_TRID_1,
- MBIC_SEQSUM_0, // 10byte
- MBIC_TTL_0,
- MBIC_TIME_0,
- MBIC_TIME_1,
- MBIC_TIME_2,
- MBIC_TIME_3,
- MBIC_TIME_4,
- MBIC_TIME_5,
- MBIC_ERRRESPONSE_0,
- MBIC_CMD_0,
- MBIC_LENGTH_0, // 20byte
- MBIC_LENGTH_1,
- MBIC_HEADERCHECKSUM_0,
- MBIC_PAYLOADSTART,
- /*
- * PayLoadSTART
- */
- }MBICProt_st;
- typedef enum{
- Alarm_Bit_List = 0xE000,
- Alarm_Mask,
- Alarm_Test_Mode,
- Alarm_Test_Dummy,
- CPU_Version,
- ModuleINFORMATION_null1,
- CPU_Current_Bank,
- CPU_Bank_Select_Reboot_by,
- CPU_Bank1_Image_Version,
- CPU_Bank1_Image_BuildTime,
- CPU_Bank1_Image_Name,
- CPU_Bank2_Image_Version,
- CPU_Bank2_Image_BuildTime,
- CPU_Bank2_Image_Name,
- SW_Reset,
- Factory_Set_Initialization,
- }ModuleINFORMATION;
- typedef enum{
- Temperature = 0xE010,
- Temperature_Offset,
- Temp_High_Threshold,
- Temp_High_Threshold_Default,
- Temp_High_Alarm,
- LED_TEST,
- Node,
- Type,
- PCB_Version,
- Serial_Number,
- Manufacture,
- Manufacture_Date,
- ENVIRONMENT_INVENTORY_null1,
- Freq_ID,
- Carrier_ID,
- Carrier_ON_OFF,
- }ENVIRONMENT_INVENTORY;
- typedef enum{
- DLI_P1_Level= 0xE020,
- DLI_P2_Level,
- DLI_P3_Level,
- DLI_P4_Level,
- ULO_P1_Level,
- ULO_P2_Level,
- ULO_P3_Level,
- ULO_P4_Level,
- }Current_Volt;
- typedef enum{
- DLI_RF_Path1_ON_OFF= 0xE030,
- DLI_RF_Path2_ON_OFF,
- DLI_RF_Path3_ON_OFF,
- DLI_RF_Path4_ON_OFF,
- DLI_Gain_Atten1,
- DLI_Gain_Atten2,
- DLI_Gain_Atten3,
- DLI_Gain_Atten4,
- DLI_Gain_Atten_Offset1,
- DLI_Gain_Atten_Offset2,
- DLI_Gain_Atten_Offset3,
- DLI_Gain_Atten_Offset4,
- DLI_Level_High_Threshold,
- DLI_Level_Low_Threshold,
- DLI_Level_High_Low_Threshold_default,
- DLI_Level,
- }DL_Ctrl1;
- typedef enum{
- DLI_Level_High_Alarm1= 0xE040,
- DLI_Level_High_Alarm2,
- DLI_Level_High_Alarm3,
- DLI_Level_High_Alarm4,
- DLI_Level_Low_Alarm1,
- DLI_Level_Low_Alarm2,
- DLI_Level_Low_Alarm3,
- DLI_Level_Low_Alarm4,
- }DL_Ctrl2;
- typedef enum{
- DLI_AGC_ON_OFF= 0xE050,
- DLI_AGC_Threshold,
- DLI_AGC_Threshold_Default,
- DLI_Shutdown_ON_OFF,
- DLI_Shutdown_Threshold,
- DLI_Shutdown_Threshold_Default,
- DLI_Shutdown_Count,
- DLI_AGC_Alarm1,
- DLI_AGC_Alarm2,
- DLI_AGC_Alarm3,
- DLI_AGC_Alarm4,
- DLI_Shutdown_Alarm1,
- DLI_Shutdown_Alarm2,
- DLI_Shutdown_Alarm3,
- DLI_Shutdown_Alarm4,
- }DL_Ctrl3;
- typedef enum{
- ULO_RF_Path1_ON_OFF= 0xE060,
- ULO_RF_Path2_ON_OFF,
- ULO_RF_Path3_ON_OFF,
- ULO_RF_Path4_ON_OFF,
- ULO_Gain_Atten1,
- ULO_Gain_Atten2,
- ULO_Gain_Atten3,
- ULO_Gain_Atten4,
- ULO_Gain_Atten_Offset1,
- ULO_Gain_Atten_Offset2,
- ULO_Gain_Atten_Offset3,
- ULO_Gain_Atten_Offset4,
- ULO_Level_High_Threshold,
- UL_Ctrl1_null1,
- ULO_Level_High_Threshold_default,
- ULO_Level,
- }UL_Ctrl1;
- typedef enum{
- ULO_Level_High_Alarm1= 0xE070,
- ULO_Level_High_Alarm2,
- ULO_Level_High_Alarm3,
- ULO_Level_High_Alarm4,
- }UL_Ctrl2;
- typedef enum{
- ULO_ALC_ON_OFF= 0xE080,
- ULO_ALC_Threshold,
- ULO_ALC_Threshold_Default,
- ULO_Shutdown_ON_OFF,
- ULO_Shutdown_Threshold,
- ULO_Shutdown_Threshold_Default,
- ULO_Shutdown_Retry_Count,
- ULO_ALC_Alarm1,
- ULO_ALC_Alarm2,
- ULO_ALC_Alarm3,
- ULO_ALC_Alarm4,
- ULO_Shutdown_Alarm1,
- ULO_Shutdown_Alarm2,
- ULO_Shutdown_Alarm3,
- ULO_Shutdown_Alarm4,
- }UL_Ctrl3;
- #define MBIC_PREAMBLE0 0x16
- #define MBIC_PREAMBLE1 0x16
- #define MBIC_PREAMBLE2 0x16
- #define MBIC_PREAMBLE3 0x16
- #define MBIC_SUBUID0 0x00
- #define MBIC_SUBUID1 0xF1
- #define MBIC_RCODE
- #define MBIC_TRID
- #define MBIC_SEQNUM
- #define MBIC_TTL
- #define MBIC_TIME
- #define MBIC_ERRRESPONSE
- #define MBIC_CMD
- #define MBIC_LENGTH
- #define MBIC_CHECKSHUM
- #define MBIC_ETX 0x03
- /*
- *
- *
- * ALARM LIST
- *
- */
- struct Alarm_ENVIRONMENT {
- uint8_t ENVIRONMENT_Temp_High ;
- uint8_t ENVIRONMENT_Reserved0 ;
- uint8_t ENVIRONMENT_Reserved1 ;
- uint8_t ENVIRONMENT_Reserved2 ;
- uint8_t ENVIRONMENT_Reserved3 ;
- uint8_t ENVIRONMENT_Reserved4 ;
- uint8_t ENVIRONMENT_Reserved5 ;
- uint8_t ENVIRONMENT_Reserved6 ;
- };
- struct Alarm_DL {
- uint8_t DLI_P4_Level_Low ;
- uint8_t DLI_P3_Level_Low ;
- uint8_t DLI_P2_Level_Low ;
- uint8_t DLI_P1_Level_Low ;
- uint8_t ULO_P4_Level_High ;
- uint8_t ULO_P3_Level_High ;
- uint8_t ULO_P2_Level_High ;
- uint8_t ULO_P1_Level_High ;
- uint8_t DLI_P4_AGC_Alarm ;
- uint8_t DLI_P3_AGC_Alarm ;
- uint8_t DLI_P2_AGC_Alarm ;
- uint8_t DLI_P1_AGC_Alarm ;
- uint8_t DLI_P4_Shutdown_Alarm ;
- uint8_t DLI_P3_Shutdown_Alarm ;
- uint8_t DLI_P2_Shutdown_Alarm ;
- uint8_t DLI_P1_Shutdown_Alarm ;
- };
- struct Alarm_UL {
- uint8_t Reserved0 ;
- uint8_t Reserved1 ;
- uint8_t Reserved2 ;
- uint8_t Reserved3 ;
- uint8_t ULO_P4_Level_High ;
- uint8_t ULO_P3_Level_High ;
- uint8_t ULO_P2_Level_High ;
- uint8_t ULO_P1_Level_High ;
- uint8_t ULO_P4_ALC_Alarm ;
- uint8_t ULO_P3_ALC_Alarm ;
- uint8_t ULO_P2_ALC_Alarm ;
- uint8_t ULO_P1_ALC_Alarm ;
- uint8_t ULO_P4_Shutdown ;
- uint8_t ULO_P3_Shutdown ;
- uint8_t ULO_P2_Shutdown ;
- uint8_t ULO_P1_Shutdown ;
- };
- enum DATATYPE
- {
- ATTSET = 0x11,
- ATT_DL1_PATH = 0x12,
- ATT_UL1_PATH = 0x16,
- ATT_SelfTest1 = 0x18,
- ATT_DL2_PATH = 0x22,
- ATT_UL2_PATH = 0x26,
- ATT_SelfTest2 = 0x28,
- ATT_DL3_PATH = 0x32,
- ATT_UL3_PATH = 0x36,
- ATT_SelfTest3 = 0x38,
- ATT_DL4_PATH = 0x42,
- ATT_UL4_PATH = 0x46,
- ATT_SelfTest4 = 0x48,
- ALC1_EN = 0x51,
- ALC2_EN = 0x52,
- ALC3_EN = 0x53,
- ALC4_EN = 0x54,
- AGC1_EN = 0x61,
- AGC2_EN = 0x62,
- AGC3_EN = 0x63,
- AGC4_EN = 0x64,
- Bluecell_StatusReq = 0x77,
- };
- #define ALARM_ENVIRONMENT_FLAG 0x80
- #define ALARM_DL1_FLAG 0xFF
- #define ALARM_DL2_FLAG 0xFF
- #define ALARM_UL1_FLAG 0x0F
- #define ALARM_UL2_FLAG 0xFF
- typedef enum{
- ENVIRONMENT = 0,
- DL1,
- DL2,
- UL1,
- UL2,
- MAX_ALARM_Len,
- }AlarmList;
- typedef struct{
- uint16_t m15_dBm;
- uint16_t m16_dBm;
- uint16_t m17_dBm;
- uint16_t m18_dBm;
- uint16_t m19_dBm;
- uint16_t m20_dBm;
- uint16_t m21_dBm;
- uint16_t m22_dBm;
- uint16_t m23_dBm;
- uint16_t m24_dBm;
- uint16_t m25_dBm;
- uint16_t m26_dBm;
- uint16_t m27_dBm;
- uint16_t m28_dBm;
- uint16_t m29_dBm;
- uint16_t m30_dBm;
- uint16_t m31_dBm;
- uint16_t m32_dBm;
- uint16_t m33_dBm;
- uint16_t m34_dBm;
- uint16_t m35_dBm;
- uint16_t m36_dBm;
- uint16_t m37_dBm;
- uint16_t m38_dBm;
- uint16_t m39_dBm;
- uint16_t m40_dBm;
- uint16_t m41_dBm;
- uint16_t m42_dBm;
- uint16_t m43_dBm;
- uint16_t m44_dBm;
- uint16_t m45_dBm;
- uint16_t m46_dBm;
- uint16_t m47_dBm;
- uint16_t m48_dBm;
- uint16_t m49_dBm;
- uint16_t m50_dBm;
- uint16_t m51_dBm;
- uint16_t m52_dBm;
- uint16_t m53_dBm;
- uint16_t m54_dBm;
- uint16_t m55_dBm;
- uint16_t m56_dBm;
- uint16_t m57_dBm;
- uint16_t m58_dBm;
- uint16_t m59_dBm;
- uint16_t m60_dBm;
- }DET_UL;
- typedef struct{
- uint16_t p5_dBm;
- uint16_t p4_dBm;
- uint16_t p3_dBm;
- uint16_t p2_dBm;
- uint16_t p1_dBm;
- uint16_t m0_dBm;
- uint16_t m1_dBm;
- uint16_t m2_dBm;
- uint16_t m3_dBm;
- uint16_t m4_dBm;
- uint16_t m5_dBm;
- uint16_t m6_dBm;
- uint16_t m7_dBm;
- uint16_t m8_dBm;
- uint16_t m9_dBm;
- uint16_t m10_dBm;
- uint16_t m11_dBm;
- uint16_t m12_dBm;
- uint16_t m13_dBm;
- uint16_t m14_dBm;
- uint16_t m15_dBm;
- uint16_t m16_dBm;
- uint16_t m17_dBm;
- uint16_t m18_dBm;
- uint16_t m19_dBm;
- uint16_t m20_dBm;
- uint16_t m21_dBm;
- uint16_t m22_dBm;
- uint16_t m23_dBm;
- uint16_t m24_dBm;
- uint16_t m25_dBm;
- }DET_DL;
- typedef struct{
- uint8_t bluecell_header;
- uint8_t bluecell_type;
- uint8_t bluecell_length;
- uint8_t bluecell_crcindex;
- uint8_t Selftest0;
- uint8_t Selftest1;
- uint8_t Selftest2;
- uint8_t Selftest3;
- uint8_t ATT_DL1_PATH;
- uint8_t ATT_DL2_PATH;
- uint8_t ATT_DL3_PATH;
- uint8_t ATT_DL4_PATH;
- uint8_t ATT_UL1_PATH;
- uint8_t ATT_UL2_PATH;
- uint8_t ATT_UL3_PATH;
- uint8_t ATT_UL4_PATH;
- uint8_t ATT_DL1_H;
- uint8_t ATT_DL1_L;
- uint8_t ATT_DL2_H;
- uint8_t ATT_DL2_L;
- uint8_t ATT_DL3_H;
- uint8_t ATT_DL3_L;
- uint8_t ATT_DL4_H;
- uint8_t ATT_DL4_L;
- uint8_t ATT_UL1_H;
- uint8_t ATT_UL1_L;
- uint8_t ATT_UL2_H;
- uint8_t ATT_UL2_L;
- uint8_t ATT_UL3_H;
- uint8_t ATT_UL3_L;
- uint8_t ATT_UL4_H;
- uint8_t ATT_UL4_L;
- uint8_t DET_DL1_IN_H;
- uint8_t DET_DL1_IN_L;
- uint8_t DET_DL2_IN_H;
- uint8_t DET_DL2_IN_L;
- uint8_t DET_DL3_IN_H;
- uint8_t DET_DL3_IN_L;
- uint8_t DET_DL4_IN_H;
- uint8_t DET_DL4_IN_L;
- uint8_t DET_UL1_IN_H;
- uint8_t DET_UL1_IN_L;
- uint8_t DET_UL2_IN_H;
- uint8_t DET_UL2_IN_L;
- uint8_t DET_UL3_IN_H;
- uint8_t DET_UL3_IN_L;
- uint8_t DET_UL4_IN_H;
- uint8_t DET_UL4_IN_L;
- uint8_t DET_TEMP_H;
- uint8_t DET_TEMP_L;
- uint8_t ATT_AGC1_ONOFF;
- uint8_t ATT_ALC1_ONOFF;
- uint8_t ATT_AGC2_ONOFF;
- uint8_t ATT_ALC2_ONOFF;
- uint8_t ATT_AGC3_ONOFF;
- uint8_t ATT_ALC3_ONOFF;
- uint8_t ATT_AGC4_ONOFF;
- uint8_t ATT_ALC4_ONOFF;
- uint8_t ATT_AGC1_H;
- uint8_t ATT_AGC1_L;
- uint8_t ATT_ALC1_H;
- uint8_t ATT_ALC1_L;
- uint8_t ATT_AGC2_H;
- uint8_t ATT_AGC2_L;
- uint8_t ATT_ALC2_H;
- uint8_t ATT_ALC2_L;
- uint8_t ATT_AGC3_H;
- uint8_t ATT_AGC3_L;
- uint8_t ATT_ALC3_H;
- uint8_t ATT_ALC3_L;
- uint8_t ATT_AGC4_H;
- uint8_t ATT_AGC4_L;
- uint8_t ATT_ALC4_H;
- uint8_t ATT_ALC4_L;
- uint8_t bluecell_crc;
- }BLUESTATUS_st;
- typedef enum{
- Bluecell_DET_UL1_ADC_INDEX_H = 0,
- Bluecell_DET_UL1_ADC_INDEX_L,
- Bluecell_DET_UL2_ADC_INDEX_H,
- Bluecell_DET_UL2_ADC_INDEX_L,
- Bluecell_DET_UL3_ADC_INDEX_H,
- Bluecell_DET_UL3_ADC_INDEX_L,
- Bluecell_RFU_TEMP_ADC_INDEX_H,
- Bluecell_RFU_TEMP_ADC_INDEX_L,
- Bluecell_ADC1_MaxLength,
- }Bluecell_ADC1_Index;
- typedef enum{
- Bluecell_DET_UL4_ADC_INDEX_H = Bluecell_ADC1_MaxLength,
- Bluecell_DET_UL4_ADC_INDEX_L,
- Bluecell_DET_DL1_ADC_INDEX_H,
- Bluecell_DET_DL1_ADC_INDEX_L,
- Bluecell_DET_DL2_ADC_INDEX_H,
- Bluecell_DET_DL2_ADC_INDEX_L,
- Bluecell_DET_DL3_ADC_INDEX_H,
- Bluecell_DET_DL3_ADC_INDEX_L,
- Bluecell_DET_DL4_ADC_INDEX_H,
- Bluecell_DET_DL4_ADC_INDEX_L,
- Bluecell_ADC3_MaxLength,
- }Bluecell_ADC3_Index;
- #define ADC1_EA Bluecell_ADC1_MaxLength /2
- #define ADC3_EA Bluecell_ADC3_MaxLength /2
- #endif /* BLUECELL_OPERATE_H_ */
|