mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-08 17:08:28 -04:00
AP_DroneCAN: get/set param timeout after 0.1 sec
This commit is contained in:
parent
6fe31396d9
commit
ee07d6bec8
@ -71,6 +71,8 @@ extern const AP_HAL::HAL& hal;
|
||||
#define AP_DRONECAN_VOLZ_FEEDBACK_ENABLED 0
|
||||
#endif
|
||||
|
||||
#define AP_DRONECAN_GETSET_TIMEOUT_MS 100 // timeout waiting for response from node after 0.1 sec
|
||||
|
||||
#define debug_dronecan(level_debug, fmt, args...) do { AP::can().log_text(level_debug, "DroneCAN", fmt, ##args); } while (0)
|
||||
|
||||
// Translation of all messages from DroneCAN structures into AP structures is done
|
||||
@ -368,6 +370,7 @@ void AP_DroneCAN::loop(void)
|
||||
|
||||
safety_state_send();
|
||||
notify_state_send();
|
||||
check_parameter_callback_timeout();
|
||||
send_parameter_request();
|
||||
send_parameter_save_request();
|
||||
send_node_status();
|
||||
@ -1265,6 +1268,25 @@ void AP_DroneCAN::handle_debug(const CanardRxTransfer& transfer, const uavcan_pr
|
||||
}
|
||||
|
||||
/*
|
||||
check for parameter get/set response timeout
|
||||
*/
|
||||
void AP_DroneCAN::check_parameter_callback_timeout()
|
||||
{
|
||||
WITH_SEMAPHORE(_param_sem);
|
||||
|
||||
// return immediately if not waiting for get/set parameter response
|
||||
if (param_request_sent_ms == 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
const uint32_t now_ms = AP_HAL::millis();
|
||||
if (now_ms - param_request_sent_ms > AP_DRONECAN_GETSET_TIMEOUT_MS) {
|
||||
param_request_sent_ms = 0;
|
||||
param_int_cb = nullptr;
|
||||
param_float_cb = nullptr;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
send any queued request to get/set parameter
|
||||
called from loop
|
||||
@ -1297,6 +1319,7 @@ bool AP_DroneCAN::set_parameter_on_node(uint8_t node_id, const char *name, float
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_REAL_VALUE;
|
||||
param_float_cb = cb;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = node_id;
|
||||
return true;
|
||||
}
|
||||
@ -1319,6 +1342,7 @@ bool AP_DroneCAN::set_parameter_on_node(uint8_t node_id, const char *name, int32
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_INTEGER_VALUE;
|
||||
param_int_cb = cb;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = node_id;
|
||||
return true;
|
||||
}
|
||||
@ -1340,6 +1364,7 @@ bool AP_DroneCAN::get_parameter_on_node(uint8_t node_id, const char *name, Param
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_EMPTY;
|
||||
param_float_cb = cb;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = node_id;
|
||||
return true;
|
||||
}
|
||||
@ -1361,6 +1386,7 @@ bool AP_DroneCAN::get_parameter_on_node(uint8_t node_id, const char *name, Param
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_EMPTY;
|
||||
param_int_cb = cb;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = node_id;
|
||||
return true;
|
||||
}
|
||||
@ -1381,6 +1407,7 @@ void AP_DroneCAN::handle_param_get_set_response(const CanardRxTransfer& transfer
|
||||
param_getset_req.value.integer_value = val;
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_INTEGER_VALUE;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = transfer.source_node_id;
|
||||
return;
|
||||
}
|
||||
@ -1393,10 +1420,12 @@ void AP_DroneCAN::handle_param_get_set_response(const CanardRxTransfer& transfer
|
||||
param_getset_req.value.real_value = val;
|
||||
param_getset_req.value.union_tag = UAVCAN_PROTOCOL_PARAM_VALUE_REAL_VALUE;
|
||||
param_request_sent = false;
|
||||
param_request_sent_ms = AP_HAL::millis();
|
||||
param_request_node_id = transfer.source_node_id;
|
||||
return;
|
||||
}
|
||||
}
|
||||
param_request_sent_ms = 0;
|
||||
param_int_cb = nullptr;
|
||||
param_float_cb = nullptr;
|
||||
}
|
||||
|
@ -153,6 +153,9 @@ private:
|
||||
// send notify vehicle state
|
||||
void notify_state_send();
|
||||
|
||||
// check for parameter get/set response timeout
|
||||
void check_parameter_callback_timeout();
|
||||
|
||||
// send queued parameter get/set request. called from loop
|
||||
void send_parameter_request();
|
||||
|
||||
@ -166,6 +169,7 @@ private:
|
||||
ParamGetSetIntCb *param_int_cb; // latest get param request callback function (for integers)
|
||||
ParamGetSetFloatCb *param_float_cb; // latest get param request callback function (for floats)
|
||||
bool param_request_sent = true; // true after a param request has been sent, false when queued to be sent
|
||||
uint32_t param_request_sent_ms; // system time that get param request was sent
|
||||
HAL_Semaphore _param_sem; // semaphore protecting this block of variables
|
||||
uint8_t param_request_node_id; // node id of most recent get param request
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user