2009-07-10 15:41:53 -04:00
|
|
|
/*
|
|
|
|
* Serial I/O helper routines
|
|
|
|
*
|
|
|
|
* Jim Paris <jim@jtan.com>
|
|
|
|
* $Id$
|
|
|
|
*/
|
2009-07-10 16:11:02 -04:00
|
|
|
#ifndef SERIAL_UTIL_H
|
|
|
|
#define SERIAL_UTIL_H
|
2009-07-10 15:41:53 -04:00
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
/* Open serial port in raw mode, with custom baudrate if necessary */
|
|
|
|
int serial_open(const char *device, int rate);
|
|
|
|
|
|
|
|
/* Like read(), but restarts after EINTR, and reads until count bytes
|
|
|
|
are received or a timeout occurs. */
|
|
|
|
int saferead_timeout(int fd, void *buf, size_t count, int timeout_ms);
|
|
|
|
|
2009-07-21 19:39:08 -04:00
|
|
|
static inline int saferead(int fd, void *buf, size_t count) {
|
|
|
|
return saferead_timeout(fd, buf, count, -1);
|
|
|
|
}
|
|
|
|
|
2009-07-10 15:41:53 -04:00
|
|
|
/* Like write(), but restarts after EINTR */
|
|
|
|
ssize_t safewrite(int fd, const void *buf, size_t count);
|
|
|
|
|
2009-10-14 17:35:50 -04:00
|
|
|
/* Read bytes until no more are available for specified time */
|
|
|
|
int drain_timeout(int fd, int msec);
|
|
|
|
|
2009-07-10 15:41:53 -04:00
|
|
|
/* Read bytes until no more are available for 0.1 sec */
|
2009-10-14 17:35:50 -04:00
|
|
|
static inline int drain(int fd) {
|
|
|
|
return drain_timeout(fd, 100);
|
|
|
|
}
|
2009-07-10 15:41:53 -04:00
|
|
|
|
|
|
|
/* Like fprintf, but to a fd, using safewrite */
|
|
|
|
int fdprintf(int fd, const char *fmt, ...);
|
|
|
|
|
|
|
|
/* Like fgets, but from a fd, using saferead_timeout. */
|
|
|
|
char *fdgets(char *s, int size, int fd, int timeout_ms);
|
|
|
|
|
|
|
|
/* Like perl chomp. */
|
|
|
|
void chomp(char *s);
|
|
|
|
|
|
|
|
#endif
|