Skip to content

Commit

Permalink
HAL_SITL: implement UART timestamp API
Browse files Browse the repository at this point in the history
  • Loading branch information
tridge committed May 16, 2018
1 parent 3d95ec8 commit d8a6781
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 1 deletion.
28 changes: 28 additions & 0 deletions libraries/AP_HAL_SITL/UARTDriver.cpp
Expand Up @@ -52,6 +52,9 @@ void UARTDriver::begin(uint32_t baud, uint16_t rxSpace, uint16_t txSpace)
{
const char *path = _sitlState->_uart_path[_portNumber];

// default to 1MBit
_uart_baudrate = 1000000U;

if (strcmp(path, "GPS1") == 0) {
/* gps */
_connected = true;
Expand Down Expand Up @@ -498,7 +501,32 @@ void UARTDriver::_timer_tick(void)
}
if (nread > 0) {
_readbuffer.write((uint8_t *)buf, nread);
_receive_timestamp = AP_HAL::micros64();
}
}

/*
return timestamp estimate in microseconds for when the start of
a nbytes packet arrived on the uart. This should be treated as a
time constraint, not an exact time. It is guaranteed that the
packet did not start being received after this time, but it
could have been in a system buffer before the returned time.
This takes account of the baudrate of the link. For transports
that have no baudrate (such as USB) the time estimate may be
less accurate.
A return value of zero means the HAL does not support this API
*/
uint64_t UARTDriver::receive_time_constraint_us(uint16_t nbytes) const
{
uint64_t last_receive_us = _receive_timestamp;
if (_uart_baudrate > 0) {
// assume 10 bits per byte.
uint32_t transport_time_us = (1000000UL * 10UL / _uart_baudrate) * nbytes;
last_receive_us -= transport_time_us;
}
return last_receive_us;
}

#endif // CONFIG_HAL_BOARD
Expand Down
17 changes: 16 additions & 1 deletion libraries/AP_HAL_SITL/UARTDriver.h
Expand Up @@ -66,6 +66,21 @@ class HALSITL::UARTDriver : public AP_HAL::UARTDriver {
bool set_unbuffered_writes(bool on) override;

void _timer_tick(void);

/*
return timestamp estimate in microseconds for when the start of
a nbytes packet arrived on the uart. This should be treated as a
time constraint, not an exact time. It is guaranteed that the
packet did not start being received after this time, but it
could have been in a system buffer before the returned time.
This takes account of the baudrate of the link. For transports
that have no baudrate (such as USB) the time estimate may be
less accurate.
A return value of zero means the HAL does not support this API
*/
uint64_t receive_time_constraint_us(uint16_t nbytes) const override;

private:
uint8_t _portNumber;
Expand Down Expand Up @@ -94,7 +109,7 @@ class HALSITL::UARTDriver : public AP_HAL::UARTDriver {
bool set_speed(int speed);

SITL_State *_sitlState;

uint64_t _receive_timestamp;
};

#endif

0 comments on commit d8a6781

Please sign in to comment.