Use new libserialport blocking/nonblocking API calls.

This commit is contained in:
Martin Ling 2013-11-27 01:43:49 +00:00 committed by Uwe Hermann
parent 016f2e005d
commit 9647ce694b
2 changed files with 11 additions and 4 deletions

View File

@ -66,8 +66,8 @@ SR_PRIV int serial_open(struct sr_serial_dev_inst *serial, int flags)
sp_flags = (SP_MODE_READ | SP_MODE_WRITE); sp_flags = (SP_MODE_READ | SP_MODE_WRITE);
else if (flags & SERIAL_RDONLY) else if (flags & SERIAL_RDONLY)
sp_flags = SP_MODE_READ; sp_flags = SP_MODE_READ;
if (flags & SERIAL_NONBLOCK)
sp_flags |= SP_MODE_NONBLOCK; serial->nonblocking = (flags & SERIAL_NONBLOCK) ? 1 : 0;
ret = sp_open(serial->data, sp_flags); ret = sp_open(serial->data, sp_flags);
@ -203,7 +203,10 @@ SR_PRIV int serial_write(struct sr_serial_dev_inst *serial,
return SR_ERR; return SR_ERR;
} }
ret = sp_write(serial->data, buf, count); if (serial->nonblocking)
ret = sp_nonblocking_write(serial->data, buf, count);
else
ret = sp_blocking_write(serial->data, buf, count, 0);
switch (ret) { switch (ret) {
case SP_ERR_ARG: case SP_ERR_ARG:
@ -247,7 +250,10 @@ SR_PRIV int serial_read(struct sr_serial_dev_inst *serial, void *buf,
return SR_ERR; return SR_ERR;
} }
ret = sp_read(serial->data, buf, count); if (serial->nonblocking)
ret = sp_nonblocking_read(serial->data, buf, count);
else
ret = sp_blocking_read(serial->data, buf, count, 0);
switch (ret) { switch (ret) {
case SP_ERR_ARG: case SP_ERR_ARG:

View File

@ -75,6 +75,7 @@ struct sr_serial_dev_inst {
char *port; char *port;
char *serialcomm; char *serialcomm;
int fd; int fd;
int nonblocking;
struct sp_port *data; struct sp_port *data;
}; };
#endif #endif