AP_HAL_SITL: do not let outbound queue length to grow too far
This basically limits our loop rate to whatever is listening on uartA can handle in terms of mavlink traffic.
This commit is contained in:
parent
7028eb8d24
commit
78e432af0c
@ -212,6 +212,20 @@ void SITL_State::wait_clock(uint64_t wait_time_usec)
|
|||||||
usleep(1000);
|
usleep(1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// check the outbound TCP queue size. If it is too long then
|
||||||
|
// MAVProxy/pymavlink take too long to process packets and it ends
|
||||||
|
// up seeing traffic well into our past and hits time-out
|
||||||
|
// conditions.
|
||||||
|
if (sitl_model->get_speedup() > 1) {
|
||||||
|
while (true) {
|
||||||
|
const int queue_length = ((HALSITL::UARTDriver*)hal.uartA)->get_system_outqueue_length();
|
||||||
|
// ::fprintf(stderr, "queue_length=%d\n", (signed)queue_length);
|
||||||
|
if (queue_length < 1024) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
usleep(1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define streq(a, b) (!strcmp(a, b))
|
#define streq(a, b) (!strcmp(a, b))
|
||||||
|
Loading…
Reference in New Issue
Block a user