123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- #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 <stdbool.h>
- // Изменить версию если поменялась структура настроек
- #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 */
|