#ifndef SETTINGS_API_H #define SETTINGS_API_H #include "at32f403a_407.h" #include "model_cfg.h" #include "usart.h" #include "sys_api.h" #include "io.h" #include // Изменить версию если поменялась структура настроек #define SETTINGS_VERSION 0x01 // ------------------------------------------------------------------- // // Draft // ------------------------------------------------------------------- // /* 1. Uptime (uint32_t) // + 2. Realtime (unix timestamp, uint32_t) // + 3. Версия прошивки // + 4. Модель (char 16 байт) // + */ // ------------------------------------------------------------------- // // Modbus // ------------------------------------------------------------------- // // Modbus typedef struct { rate_t baud; // Скорость порта parity_t parity; // Четность databits_t databits; // Число бит данных stopbits_t stopbits; // Число стоп-бит } modbus_t; // Общая структура настроек для IAP и FW typedef struct { uint16_t mb_port; // Настройки порта для modbus char model[MODEL_LEN]; // Модель } com_settings_t; #if 0 // Дискретные входы typedef struct { uint16_t debounce_time; // период антидребезга в мс (0 - 10 сек) } dinput_t; #endif // Полная структура настроек typedef struct { com_settings_t com_settings; uint32_t critical_section_crc; /* WARNING! До поля CritSecCRC включительно структура настроек должна быть * идентичной между бутлоадером и основным ПО и не должна изменяться при обновлении ПО. * Контроль целостности настроек внутри IAP выполняется только для критической секции, * т.к. контроль целостности всей структуры не имеет смысла * (структура настроек всегда будет отличаться внутри основного ПО). * В случае повреждения критического сектора, загружаются параметры по умолчанию. */ uint16_t settings_version; // Версия структуры настроек uint32_t control_word; // Слово для контроля целостности структуры настроек uint16_t di_mode_bits; // режим работы, 0 - вход, 1 - счетчик импульсов uint16_t di_norm_state_bits; // нормальное состояние (0 - разомкнут, 1 - замкнут) uint16_t di_debounce[DI_NUMBER]; // Дискретные входы uint16_t do_mode_bits; // режим работы выхода 0 - выход, 1 - ШИМ uint16_t do_bits; // последнее сохраненное значение на выходах uint16_t do_save_bits; // значение на выходах в бесопасном режиме работы uint16_t do_pwm[DO_NUMBER]; // значение заполнения ШИМ uint16_t do_pwm_save[DO_NUMBER]; // значение заполнения ШИМ в безопасном режиме uint16_t do_pwm_period[DO_NUMBER]; // период ШИМ в [0.1с (10..1000)] uint16_t do_pwm_period_save[DO_NUMBER]; // период ШИМ в безопасном режиме [0.1с (10..1000)] bool save_mode; // безопасный режим, 0 - выкл, 1 - вкл uint16_t save_delay; // время ожидания опроса (сек.) } settings_t; // Загрузка структуры настроек из flesh void settings_load(settings_t *settings); // void init_settings(void); // void settings_read_from_flash(uint8_t *data, uint32_t size); // uint32_t settings_get_crc(settings_t *settings); // uint32_t settings_get_crit_sec_crc(settings_t *settings); // Сброс всех настроек в значения по умолчанию void settings_set_all_default(void); // -------------------------------------------------------------------------- // // Настройки по умолчанию // void settings_set_modbus_def(uint16_t *mb_port); // void settings_conv_modbus_def(modbus_t *mb_settings, uint16_t *mb_port); // Установить параметры дискретных входов по умолчанию void settings_din_def(settings_t *settings); // Выходы void settings_do_def(settings_t *settings); // -------------------------------------------------------------------------- // // Запись структуры настроек во flash void settings_save(settings_t *settings); // void settings_write_to_flash(uint8_t *data, uint32_t size); // Очистка сектора настроек void settings_erase_flash_sector(void); // Системные настройки extern sys_settings_t sys_settings; // Общая структура настроек extern settings_t settings; #endif /* #ifndef SETTINGS_API_H */