forked from SZV10X_Software/SZV103_FM33A0xxEV_SiZhu

jinlicong
2024-06-12 f03cf3ae7a36954e64fc014e6bb7afd20c5a5247
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
#include "sizhu_event_record.h"
#include "sizhu_ctrl_word.h"
#include "system_mem_para.h"
//#include "rs485_data_analysis_pro.h"
//#include "power_manage.h"
#include "mbcrc1.h"
#include "system_flash_mem_manage.h"
#include "system_eep_mem_manage.h"
 
 
 
 
 
void    sizhu_event_log_eeprom_default_init(void)
{
    sizhu_valve_action_log_eeprom_default_init();
    sizhu_factory_reset_log_eeprom_default_init();
    sizhu_calibration_time_log_eeprom_default_init();
}
 
uint8_t sizhu_valve_action_log_eeprom_default_init(void)
{
    
}
 
uint8_t sizhu_factory_reset_log_eeprom_default_init(void)
{
    
}
 
uint8_t sizhu_calibration_time_log_eeprom_default_init(void)
{
    
}
 
void    sizhu_event_log_eeprom_only_read_init(void)
{
    sizhu_valve_action_log_only_read_init();
    sizhu_factory_reset_log_only_read_init();
    sizhu_calibration_time_log_only_read_init();
}
 
 
uint8_t sizhu_valve_action_log_only_read_init(void)
{
    
}
 
uint8_t sizhu_factory_reset_log_only_read_init(void)
{
    
}
 
uint8_t sizhu_calibration_time_log_only_read_init(void)
{
    
}
 
uint8_t sizhu_valve_action_log_save(uint8_t valve_action_source, uint16_t valve_action_type,uint16_t valve_action_ID,uint8_t * para_alarm_ptr)
{
}
uint8_t sizhu_factory_reset_log_save(uint8_t reset_source, uint16_t factory_id,uint8_t * para_alarm_ptr)
{
}
uint8_t sizhu_calibration_time_log_save(uint8_t calibration_source,uint16_t factory_id, uint8_t * para_alarm_ptr)
{
}
 
//·§¿Ø¼Ç¼
void sizhuValveActionLogHandle(VALVE_CTRL_SOURCE_T valve_ctrl_source, VALVE_CTRL_TYPE_T valve_action_type,uint16_t valve_action_ID)
{
    LOG_SIZHU_VALVE_ACTION_RECORD_SAVE_T    valve_ctrl_log_l;
    LOG_SIZHU_VALVE_ACTION_RECORD_SAVE_T    previous_log_l;
    uint32_t    previous_addr = 0;
    
    
    return;  //?û¾­¹ý²âÊÔ£¬ÏÈÆÁ±Î
    arrayA_2_arrayB((uint8_t *)&sys_clockBCD_g,(uint8_t *)&valve_ctrl_log_l.record_time_BCD,sizeof(sys_clockBCD_g), LITTLE_ENDIAN);
    
    valve_ctrl_log_l.valve_action_source = valve_ctrl_source; 
    valve_ctrl_log_l.valve_action_type = valve_action_type;
    valve_ctrl_log_l.valve_action_id = valve_action_ID;
    valve_ctrl_log_l.open_valve_times = save_valve_para_g.open_times;   
    valve_ctrl_log_l.close_valve_times = save_valve_para_g.close_times;
 
    FLASH_LOG_ADDR_CHECK(log_event_ctrl_g.valve_operation_log,VALVE_OPERATION_EVENT_LOG_START_ADDR,VALVE_OPERATION_EVENT_LOG_LENGTH,VALVE_OPERATION_EVENT_LOG_MAX_NUM);
    if(log_event_ctrl_g.valve_operation_log.log_count != 0){
        previous_addr = FlashLogPreviousAddrGet(log_event_ctrl_g.valve_operation_log.log_addr_save,VALVE_OPERATION_EVENT_LOG_START_ADDR,VALVE_OPERATION_EVENT_LOG_LENGTH,VALVE_OPERATION_EVENT_LOG_END_ADDR);
        if(FlashMultipleReadAndCrcCheck((uint8_t *)&previous_log_l,previous_addr,VALVE_OPERATION_EVENT_LOG_LENGTH)== PASS)
            valve_ctrl_log_l.serial_number = previous_log_l.serial_number +1;
        else
            valve_ctrl_log_l.serial_number = 0;
    }else{
        valve_ctrl_log_l.serial_number = 0;
    }
    
    //¼ÆËãCRC
    valve_ctrl_log_l.CRC16_MODBUS = usMBCRC16(0xFFFF, (uint8_t * )&valve_ctrl_log_l.record_time_BCD, sizeof(LOG_SIZHU_VALVE_ACTION_RECORD_SAVE_T) - sizeof(valve_ctrl_log_l.CRC16_MODBUS) );
    
    FlashMultipleWriteAndReadCheck((uint8_t *)&valve_ctrl_log_l,log_event_ctrl_g.valve_operation_log.log_addr_save,VALVE_OPERATION_EVENT_LOG_LENGTH);
    FLASH_LOG_CRTL_PARA_HANDLE(log_event_ctrl_g.valve_operation_log,VALVE_OPERATION_EVENT_LOG_START_ADDR,VALVE_OPERATION_EVENT_LOG_LENGTH,VALVE_OPERATION_EVENT_LOG_MAX_NUM);
    //?²ÎÊý´æ´¢
    if(paraCalcCrcAndWriteEepAB((uint8_t * )&log_event_ctrl_g,LOG_EVENT_CTRL_ADDR,LOG_EVENT_CTRL_ADDR + PARA_EEP_B_OFFSET_ADDR,sizeof(log_event_ctrl_g))==FAIL){
        
    }
}
 
//»Ö¸´³ö³§ÉèÖüǼ
void sizhuFactoryResetLogHandle(FACTORY_RESET_SOURCE modify_source, uint16_t manufactuer_code)
{
    LOG_SIZHU_FACTORY_RESET_RECORD_SAVE_T    factory_reset_log_l;
    LOG_SIZHU_FACTORY_RESET_RECORD_SAVE_T    previous_log_l;
    uint32_t    previous_addr = 0;
    
    
    return;  //?û¾­¹ý²âÊÔ£¬ÏÈÆÁ±Î
    arrayA_2_arrayB((uint8_t *)&sys_clockBCD_g,(uint8_t *)&factory_reset_log_l.record_time_BCD,sizeof(sys_clockBCD_g), LITTLE_ENDIAN);
    
    factory_reset_log_l.modify_source = modify_source; 
    factory_reset_log_l.factory_id = manufactuer_code;
 
    FLASH_LOG_ADDR_CHECK(log_event_ctrl_g.factory_reset_log,FACTORY_RESET_EVENT_LOG_START_ADDR,FACTORY_RESET_EVENT_LOG_LENGTH,FACTORY_RESET_EVENT_LOG_MAX_NUM);
    if(log_event_ctrl_g.factory_reset_log.log_count != 0){
        previous_addr = FlashLogPreviousAddrGet(log_event_ctrl_g.factory_reset_log.log_addr_save,FACTORY_RESET_EVENT_LOG_START_ADDR,FACTORY_RESET_EVENT_LOG_LENGTH,FACTORY_RESET_EVENT_LOG_END_ADDR);
        if(FlashMultipleReadAndCrcCheck((uint8_t *)&previous_log_l,previous_addr,FACTORY_RESET_EVENT_LOG_LENGTH)== PASS)
            factory_reset_log_l.serial_number = previous_log_l.serial_number +1;
        else
            factory_reset_log_l.serial_number = 0;
    }else{
        factory_reset_log_l.serial_number = 0;
    }
    
    //¼ÆËãCRC
    factory_reset_log_l.CRC16_MODBUS = usMBCRC16(0xFFFF, (uint8_t * )&factory_reset_log_l.record_time_BCD, sizeof(LOG_SIZHU_FACTORY_RESET_RECORD_SAVE_T) - sizeof(factory_reset_log_l.CRC16_MODBUS) );
    
    FlashMultipleWriteAndReadCheck((uint8_t *)&factory_reset_log_l,log_event_ctrl_g.factory_reset_log.log_addr_save,FACTORY_RESET_EVENT_LOG_LENGTH);
    FLASH_LOG_CRTL_PARA_HANDLE(log_event_ctrl_g.factory_reset_log,FACTORY_RESET_EVENT_LOG_START_ADDR,FACTORY_RESET_EVENT_LOG_LENGTH,FACTORY_RESET_EVENT_LOG_MAX_NUM);
    //?²ÎÊý´æ´¢
    if(paraCalcCrcAndWriteEepAB((uint8_t * )&log_event_ctrl_g,LOG_EVENT_CTRL_ADDR,LOG_EVENT_CTRL_ADDR + PARA_EEP_B_OFFSET_ADDR,sizeof(log_event_ctrl_g))==FAIL){
        
    }
}
 
//Уʱ¼Ç¼
void sizhuSetTimeLogHandle(SET_TIME_SOURCE modify_source, uint16_t manufactuer_code,sClockBCD time_after_cali)
{
    LOG_SIZHU_CALIBRATION_TIME_RECORD_SAVE_T    set_time_log_l;
    LOG_SIZHU_CALIBRATION_TIME_RECORD_SAVE_T    previous_log_l;
    uint32_t    previous_addr = 0;
    
    
    return;  //?û¾­¹ý²âÊÔ£¬ÏÈÆÁ±Î
    arrayA_2_arrayB((uint8_t *)&sys_clockBCD_g,(uint8_t *)&set_time_log_l.record_time_BCD,sizeof(sys_clockBCD_g), LITTLE_ENDIAN);
    set_time_log_l.modify_source = modify_source; 
    set_time_log_l.factory_id = manufactuer_code;
    arrayA_2_arrayB((uint8_t *)&time_after_cali,(uint8_t *)&set_time_log_l.set_time_BCD,sizeof(sys_clockBCD_g), LITTLE_ENDIAN);
 
    FLASH_LOG_ADDR_CHECK(log_event_ctrl_g.set_time_log,SET_TIME_EVENT_LOG_START_ADDR,SET_TIME_EVENT_LOG_LENGTH,SET_TIME_EVENT_LOG_MAX_NUM);
    if(log_event_ctrl_g.set_time_log.log_count != 0){
        previous_addr = FlashLogPreviousAddrGet(log_event_ctrl_g.set_time_log.log_addr_save,SET_TIME_EVENT_LOG_START_ADDR,SET_TIME_EVENT_LOG_LENGTH,SET_TIME_EVENT_LOG_END_ADDR);
        if(FlashMultipleReadAndCrcCheck((uint8_t *)&previous_log_l,previous_addr,SET_TIME_EVENT_LOG_LENGTH)== PASS)
            set_time_log_l.serial_number = previous_log_l.serial_number +1;
        else
            set_time_log_l.serial_number = 0;
    }else{
        set_time_log_l.serial_number = 0;
    }
    
    //¼ÆËãCRC
    set_time_log_l.CRC16_MODBUS = usMBCRC16(0xFFFF, (uint8_t * )&set_time_log_l.record_time_BCD, sizeof(LOG_SIZHU_CALIBRATION_TIME_RECORD_SAVE_T) - sizeof(set_time_log_l.CRC16_MODBUS) );
    
    FlashMultipleWriteAndReadCheck((uint8_t *)&set_time_log_l,log_event_ctrl_g.set_time_log.log_addr_save,SET_TIME_EVENT_LOG_LENGTH);
    FLASH_LOG_CRTL_PARA_HANDLE(log_event_ctrl_g.set_time_log,SET_TIME_EVENT_LOG_START_ADDR,SET_TIME_EVENT_LOG_LENGTH,SET_TIME_EVENT_LOG_MAX_NUM);
    //?²ÎÊý´æ´¢
    if(paraCalcCrcAndWriteEepAB((uint8_t * )&log_event_ctrl_g,LOG_EVENT_CTRL_ADDR,LOG_EVENT_CTRL_ADDR + PARA_EEP_B_OFFSET_ADDR,sizeof(log_event_ctrl_g))==FAIL){
        
    }
}