2019-01-26 22:18:25 +00:00
|
|
|
#include "packet_tx_handler.h"
|
|
|
|
#include "station_config.h"
|
|
|
|
#include "rte_wx.h"
|
2019-04-03 12:26:04 +00:00
|
|
|
#include "rte_pv.h"
|
2019-01-26 22:18:25 +00:00
|
|
|
|
|
|
|
#include "./aprs/beacon.h"
|
|
|
|
#include "./aprs/wx.h"
|
|
|
|
#include "./aprs/telemetry.h"
|
|
|
|
|
|
|
|
#include "./drivers/tx20.h"
|
2019-05-05 12:25:48 +00:00
|
|
|
#include "./drivers/serial.h"
|
2019-01-26 22:18:25 +00:00
|
|
|
|
|
|
|
#include "main.h"
|
|
|
|
|
|
|
|
uint8_t packet_tx_beacon_interval = _BCN_INTERVAL;
|
|
|
|
uint8_t packet_tx_beacon_counter = 0;
|
|
|
|
|
2019-01-27 11:34:43 +00:00
|
|
|
#ifdef _METEO
|
2019-01-26 22:18:25 +00:00
|
|
|
uint8_t packet_tx_meteo_interval = _WX_INTERVAL;
|
|
|
|
uint8_t packet_tx_meteo_counter = 0;
|
2019-05-05 12:25:48 +00:00
|
|
|
|
|
|
|
uint8_t packet_tx_meteo_kiss_interval = 2;
|
|
|
|
uint8_t packet_tx_meteo_kiss_counter = 0;
|
2019-01-27 11:34:43 +00:00
|
|
|
#endif
|
2019-01-26 22:18:25 +00:00
|
|
|
|
|
|
|
uint8_t packet_tx_telemetry_interval = 10;
|
|
|
|
uint8_t packet_tx_telemetry_counter = 0;
|
|
|
|
|
2019-01-27 13:23:20 +00:00
|
|
|
uint8_t packet_tx_telemetry_descr_interval = 40;
|
2019-01-27 16:33:53 +00:00
|
|
|
uint8_t packet_tx_telemetry_descr_counter = 35;
|
2019-01-27 13:23:20 +00:00
|
|
|
|
2019-01-26 22:18:25 +00:00
|
|
|
// this shall be called in 60 seconds periods
|
|
|
|
void packet_tx_handler(void) {
|
2020-03-23 20:41:01 +00:00
|
|
|
dallas_qf_t dallas_qf = DALLAS_QF_UNKNOWN;
|
2019-04-15 20:46:36 +00:00
|
|
|
|
2019-05-05 12:25:48 +00:00
|
|
|
uint16_t ln = 0;
|
|
|
|
|
2019-01-26 22:18:25 +00:00
|
|
|
packet_tx_beacon_counter++;
|
|
|
|
packet_tx_telemetry_counter++;
|
2019-01-27 13:23:20 +00:00
|
|
|
packet_tx_telemetry_descr_counter++;
|
2019-01-27 11:34:43 +00:00
|
|
|
#ifdef _METEO
|
|
|
|
packet_tx_meteo_counter++;
|
2019-05-05 12:25:48 +00:00
|
|
|
packet_tx_meteo_kiss_counter++;
|
2019-01-27 11:34:43 +00:00
|
|
|
#endif
|
2019-01-26 22:18:25 +00:00
|
|
|
|
|
|
|
if (packet_tx_beacon_counter >= packet_tx_beacon_interval) {
|
|
|
|
|
|
|
|
SendOwnBeacon();
|
|
|
|
|
|
|
|
main_wait_for_tx_complete();
|
|
|
|
|
|
|
|
packet_tx_beacon_counter = 0;
|
|
|
|
}
|
|
|
|
|
2019-01-27 11:34:43 +00:00
|
|
|
#ifdef _METEO
|
2019-01-26 22:18:25 +00:00
|
|
|
if (packet_tx_meteo_counter >= packet_tx_meteo_interval) {
|
|
|
|
|
2019-01-27 11:34:43 +00:00
|
|
|
#if defined _DALLAS_AS_TELEM
|
|
|
|
// _DALLAS_AS_TELEM wil be set during compilation wx packets will be filled by temperature from MS5611 sensor
|
|
|
|
SendWXFrame(&VNAME, rte_wx_temperature_valid, rte_wx_pressure_valid);
|
|
|
|
#else
|
2020-01-04 13:15:33 +00:00
|
|
|
SendWXFrame(rte_wx_average_windspeed, rte_wx_max_windspeed, rte_wx_average_winddirection, rte_wx_temperature_dallas_valid, rte_wx_pressure_valid);
|
2020-03-02 21:05:43 +00:00
|
|
|
|
2020-01-04 13:15:33 +00:00
|
|
|
|
2019-01-27 11:34:43 +00:00
|
|
|
#endif
|
2020-01-04 13:15:33 +00:00
|
|
|
|
2019-01-26 22:18:25 +00:00
|
|
|
main_wait_for_tx_complete();
|
|
|
|
|
|
|
|
packet_tx_meteo_counter = 0;
|
|
|
|
}
|
2019-05-05 12:25:48 +00:00
|
|
|
|
|
|
|
if (packet_tx_meteo_kiss_counter >= packet_tx_meteo_kiss_interval) {
|
|
|
|
|
|
|
|
srl_wait_for_tx_completion();
|
|
|
|
|
2020-01-04 13:15:33 +00:00
|
|
|
SendWXFrameToBuffer(rte_wx_average_windspeed, rte_wx_max_windspeed, rte_wx_average_winddirection, rte_wx_temperature_dallas_valid, rte_wx_pressure_valid, srl_tx_buffer, TX_BUFFER_LN, &ln);
|
2019-05-05 12:25:48 +00:00
|
|
|
|
|
|
|
srl_start_tx(ln);
|
|
|
|
|
|
|
|
|
|
|
|
packet_tx_meteo_kiss_counter = 0;
|
|
|
|
}
|
2020-01-04 13:15:33 +00:00
|
|
|
#endif // #ifdef _METEO
|
2019-01-26 22:18:25 +00:00
|
|
|
|
|
|
|
if (packet_tx_telemetry_counter >= packet_tx_telemetry_interval) {
|
|
|
|
|
2019-04-28 07:36:24 +00:00
|
|
|
// if there weren't any erros related to communication with DS12B20 from previous function call
|
2019-04-15 20:46:36 +00:00
|
|
|
if (rte_wx_error_dallas_qf == DALLAS_QF_UNKNOWN) {
|
2019-04-28 07:36:24 +00:00
|
|
|
dallas_qf = rte_wx_current_dallas_qf; // it might be DEGRADATED so we need to copy a value directly
|
|
|
|
|
|
|
|
// reset current QF to check if there will be at least one successfull readout of temperature
|
|
|
|
rte_wx_current_dallas_qf = DALLAS_QF_UNKNOWN;
|
2019-04-15 20:46:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// if there were any errors
|
|
|
|
else {
|
2019-04-28 07:36:24 +00:00
|
|
|
|
|
|
|
// if we had at least one successfull communication with the sensor
|
|
|
|
if (rte_wx_current_dallas_qf == DALLAS_QF_FULL || rte_wx_current_dallas_qf == DALLAS_QF_DEGRADATED) {
|
|
|
|
// set the error reason
|
|
|
|
dallas_qf = DALLAS_QF_DEGRADATED;
|
|
|
|
}
|
|
|
|
// if they wasn't any successfull comm
|
|
|
|
else {
|
|
|
|
// set that it is totally dead and not avaliable
|
|
|
|
dallas_qf = DALLAS_QF_NOT_AVALIABLE;
|
|
|
|
}
|
2019-04-15 20:46:36 +00:00
|
|
|
|
|
|
|
// and reset the error
|
|
|
|
rte_wx_error_dallas_qf = DALLAS_QF_UNKNOWN;
|
2019-04-28 07:36:24 +00:00
|
|
|
|
|
|
|
rte_wx_current_dallas_qf = DALLAS_QF_UNKNOWN;
|
2019-04-15 20:46:36 +00:00
|
|
|
}
|
|
|
|
|
2019-04-03 12:26:04 +00:00
|
|
|
#ifdef _VICTRON
|
|
|
|
//
|
2019-04-15 20:46:36 +00:00
|
|
|
telemetry_send_values_pv(rx10m, digi10m, rte_pv_battery_current, rte_pv_battery_voltage, rte_pv_cell_voltage, dallas_qf, rte_wx_ms5611_qf, rte_wx_dht_valid.qf);
|
2019-04-03 12:26:04 +00:00
|
|
|
//
|
|
|
|
#else
|
|
|
|
//
|
2019-01-27 11:34:43 +00:00
|
|
|
#if defined _DALLAS_AS_TELEM
|
|
|
|
// if _DALLAS_AS_TELEM will be enabled the fifth channel will be set to temperature measured by DS12B20
|
2019-05-05 07:48:51 +00:00
|
|
|
telemetry_send_values(rx10m, tx10m, digi10m, kiss10m, rte_wx_temperature_dallas_valid, dallas_qf, rte_wx_ms5611_qf, rte_wx_dht_valid.qf, rte_wx_tx20_excessive_slew_rate);
|
2019-01-27 11:34:43 +00:00
|
|
|
#elif defined _METEO
|
|
|
|
// if _METEO will be enabled, but without _DALLAS_AS_TELEM the fifth channel will be used to transmit temperature from MS5611
|
|
|
|
// which may be treated then as 'rack/cabinet internal temperature'. Dallas DS12B10 will be used for ragular WX frames
|
2019-10-27 19:50:01 +00:00
|
|
|
telemetry_send_values(rx10m, tx10m, digi10m, kiss10m, rte_wx_temperature_ms_valid, dallas_qf, rte_wx_ms5611_qf, rte_wx_dht.qf, rte_wx_tx20_excessive_slew_rate);
|
2019-01-27 11:34:43 +00:00
|
|
|
#else
|
|
|
|
// if user will disable both _METEO and _DALLAS_AS_TELEM value will be zeroed internally anyway
|
2019-05-29 04:11:05 +00:00
|
|
|
telemetry_send_values(rx10m, tx10m, digi10m, kiss10m, 0.0f, dallas_qf, rte_wx_ms5611_qf, rte_wx_dht.qf, rte_wx_tx20_excessive_slew_rate);
|
2019-01-27 11:34:43 +00:00
|
|
|
#endif
|
2019-04-03 12:26:04 +00:00
|
|
|
//
|
|
|
|
#endif
|
2019-01-26 22:18:25 +00:00
|
|
|
main_wait_for_tx_complete();
|
|
|
|
|
|
|
|
packet_tx_telemetry_counter = 0;
|
|
|
|
|
2019-01-27 11:34:43 +00:00
|
|
|
rx10m = 0, tx10m = 0, digi10m = 0, kiss10m = 0;
|
|
|
|
|
2019-05-05 07:48:51 +00:00
|
|
|
rte_wx_tx20_excessive_slew_rate = 0;
|
|
|
|
|
2019-01-26 22:18:25 +00:00
|
|
|
}
|
|
|
|
|
2019-01-27 13:23:20 +00:00
|
|
|
if (packet_tx_telemetry_descr_counter >= packet_tx_telemetry_descr_interval) {
|
2019-04-03 12:26:04 +00:00
|
|
|
#ifdef _VICTRON
|
|
|
|
telemetry_send_chns_description_pv();
|
2019-04-04 17:57:21 +00:00
|
|
|
|
|
|
|
main_wait_for_tx_complete();
|
|
|
|
|
|
|
|
telemetry_send_status(&rte_pv_average, &rte_pv_last_error, rte_pv_struct.system_state);
|
|
|
|
|
|
|
|
main_wait_for_tx_complete();
|
2019-04-03 12:26:04 +00:00
|
|
|
#else
|
2019-01-27 13:23:20 +00:00
|
|
|
telemetry_send_chns_description();
|
2019-04-04 17:57:21 +00:00
|
|
|
|
2019-01-27 13:23:20 +00:00
|
|
|
main_wait_for_tx_complete();
|
|
|
|
|
2019-01-27 16:33:53 +00:00
|
|
|
telemetry_send_status();
|
|
|
|
|
|
|
|
main_wait_for_tx_complete();
|
2019-04-04 17:57:21 +00:00
|
|
|
#endif
|
|
|
|
|
2019-01-27 16:33:53 +00:00
|
|
|
|
|
|
|
packet_tx_telemetry_descr_counter = 0;
|
2019-01-27 13:23:20 +00:00
|
|
|
}
|
|
|
|
|
2019-01-26 22:18:25 +00:00
|
|
|
}
|