mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 00:28:30 -04:00
GCS_MAVLink: optimise FTP for available bandwidth
when we don't have hardware flow control don't use more than 1/3 of available bandwidth for ftp outgoing transfers. This makes parameter download faster on radios without flow control
This commit is contained in:
parent
5de8fcc777
commit
1f05ee2232
@ -483,7 +483,27 @@ void GCS_MAVLINK::ftp_worker(void) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
const uint32_t transfer_size = 100;
|
/*
|
||||||
|
calculate a burst delay so that FTP burst
|
||||||
|
transfer doesn't use more than 1/3 of
|
||||||
|
available bandwidth on links that don't have
|
||||||
|
flow control. This reduces the chance of
|
||||||
|
lost packets a lot, which results in overall
|
||||||
|
faster transfers
|
||||||
|
*/
|
||||||
|
uint32_t burst_delay_ms = 0;
|
||||||
|
if (valid_channel(request.chan)) {
|
||||||
|
auto *port = mavlink_comm_port[request.chan];
|
||||||
|
if (port != nullptr && port->get_flow_control() != AP_HAL::UARTDriver::FLOW_CONTROL_ENABLE) {
|
||||||
|
const uint32_t bw = port->bw_in_kilobytes_per_second();
|
||||||
|
const uint16_t pkt_size = PAYLOAD_SIZE(request.chan, FILE_TRANSFER_PROTOCOL) - (sizeof(reply.data) - max_read);
|
||||||
|
burst_delay_ms = 3 * pkt_size / bw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// this transfer size is enough for a full parameter file with max parameters
|
||||||
|
const uint32_t transfer_size = 500;
|
||||||
for (uint32_t i = 0; (i < transfer_size); i++) {
|
for (uint32_t i = 0; (i < transfer_size); i++) {
|
||||||
// fill the buffer
|
// fill the buffer
|
||||||
const ssize_t read_bytes = AP::FS().read(ftp.fd, reply.data, MIN(sizeof(reply.data), max_read));
|
const ssize_t read_bytes = AP::FS().read(ftp.fd, reply.data, MIN(sizeof(reply.data), max_read));
|
||||||
@ -516,6 +536,8 @@ void GCS_MAVLINK::ftp_worker(void) {
|
|||||||
|
|
||||||
// prep the reply to be used again
|
// prep the reply to be used again
|
||||||
reply.seq_number++;
|
reply.seq_number++;
|
||||||
|
|
||||||
|
hal.scheduler->delay(burst_delay_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (reply.opcode != FTP_OP::Nack) {
|
if (reply.opcode != FTP_OP::Nack) {
|
||||||
|
Loading…
Reference in New Issue
Block a user