mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 01:28:29 -04:00
HAL_PX4: use fd IO instead of stdio
this allows for hal console output from within timers, which is very handy for debugging
This commit is contained in:
parent
c6305b5876
commit
d9d5eb52bf
@ -10,9 +10,8 @@ using namespace PX4;
|
||||
PX4UARTDriver::PX4UARTDriver() {}
|
||||
|
||||
/*
|
||||
this UART driver just maps to stdin/stdout, which goes to
|
||||
whatever is setup for the PX4 console. Baud rate control is not
|
||||
available.
|
||||
this UART driver just maps to fd 0/1, which goes to whatever is
|
||||
setup for the PX4 console. Baud rate control is not available.
|
||||
*/
|
||||
|
||||
void PX4UARTDriver::begin(uint32_t b) {}
|
||||
@ -35,23 +34,23 @@ void PX4UARTDriver::println_P(const prog_char_t *pstr) {
|
||||
void PX4UARTDriver::printf(const char *fmt, ...) {
|
||||
va_list ap;
|
||||
va_start(ap, fmt);
|
||||
vfprintf(stdout, fmt, ap);
|
||||
_vdprintf(1, fmt, ap);
|
||||
va_end(ap);
|
||||
}
|
||||
|
||||
void PX4UARTDriver::_printf_P(const prog_char *fmt, ...) {
|
||||
va_list ap;
|
||||
va_start(ap, fmt);
|
||||
vfprintf(stdout, fmt, ap);
|
||||
_vdprintf(1, fmt, ap);
|
||||
va_end(ap);
|
||||
}
|
||||
|
||||
void PX4UARTDriver::vprintf(const char *fmt, va_list ap) {
|
||||
vfprintf(stdout, fmt, ap);
|
||||
_vdprintf(1, fmt, ap);
|
||||
}
|
||||
|
||||
void PX4UARTDriver::vprintf_P(const prog_char *fmt, va_list ap) {
|
||||
vfprintf(stdout, fmt, ap);
|
||||
_vdprintf(1, fmt, ap);
|
||||
}
|
||||
|
||||
/* PX4 implementations of Stream virtual methods */
|
||||
@ -60,7 +59,7 @@ int16_t PX4UARTDriver::txspace() { return 128; }
|
||||
|
||||
int16_t PX4UARTDriver::read() {
|
||||
uint8_t c;
|
||||
if (fread(&c, 1, 1, stdin) == 1) {
|
||||
if (::read(0, &c, 1) == 1) {
|
||||
return c;
|
||||
}
|
||||
return -1;
|
||||
@ -72,7 +71,15 @@ int16_t PX4UARTDriver::peek() {
|
||||
|
||||
/* PX4 implementations of Print virtual methods */
|
||||
size_t PX4UARTDriver::write(uint8_t c) {
|
||||
return fwrite(&c, 1, 1, stdout);
|
||||
return ::write(1, &c, 1);
|
||||
}
|
||||
|
||||
void PX4UARTDriver::_vdprintf(int fd, const char *fmt, va_list ap) {
|
||||
char buf[128];
|
||||
int len = vsnprintf(buf, sizeof(buf), fmt, ap);
|
||||
if (len > 0) {
|
||||
::write(1, buf, len);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -33,6 +33,9 @@ public:
|
||||
|
||||
/* PX4 implementations of Print virtual methods */
|
||||
size_t write(uint8_t c);
|
||||
|
||||
private:
|
||||
void _vdprintf(int fd, const char *fmt, va_list ap);
|
||||
};
|
||||
|
||||
#endif // __AP_HAL_PX4_UARTDRIVER_H__
|
||||
|
Loading…
Reference in New Issue
Block a user