tty:support tty c_cc VMIN & VTIME
Signed-off-by: anjiahao <anjiahao@xiaomi.com>
This commit is contained in:
parent
e9dfa0094f
commit
0c9ca52f37
@ -26,8 +26,10 @@
|
|||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/param.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <time.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
@ -1047,9 +1049,22 @@ static ssize_t uart_read(FAR struct file *filep,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
dev->recvwaiting = true;
|
dev->recvwaiting = true;
|
||||||
ret = nxsem_wait(&dev->recvsem);
|
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
dev->minrecv = MIN(buflen - recvd, dev->minread - recvd);
|
||||||
|
if (dev->timeout)
|
||||||
|
{
|
||||||
|
ret = nxsem_tickwait(&dev->recvsem,
|
||||||
|
DSEC2TICK(dev->timeout));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
ret = nxsem_wait(&dev->recvsem);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dev->recvwaiting = false;
|
||||||
leave_critical_section(flags);
|
leave_critical_section(flags);
|
||||||
|
|
||||||
/* Was a signal received while waiting for data to be
|
/* Was a signal received while waiting for data to be
|
||||||
@ -1078,9 +1093,9 @@ static ssize_t uart_read(FAR struct file *filep,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CONFIG_SERIAL_REMOVABLE
|
#ifdef CONFIG_SERIAL_REMOVABLE
|
||||||
recvd = dev->disconnected ? -ENOTCONN : -EINTR;
|
recvd = dev->disconnected ? -ENOTCONN : ret;
|
||||||
#else
|
#else
|
||||||
recvd = -EINTR;
|
recvd = ret;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1539,6 +1554,10 @@ static int uart_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
|
|||||||
termiosp->c_iflag = dev->tc_iflag;
|
termiosp->c_iflag = dev->tc_iflag;
|
||||||
termiosp->c_oflag = dev->tc_oflag;
|
termiosp->c_oflag = dev->tc_oflag;
|
||||||
termiosp->c_lflag = dev->tc_lflag;
|
termiosp->c_lflag = dev->tc_lflag;
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
termiosp->c_cc[VTIME] = dev->timeout;
|
||||||
|
termiosp->c_cc[VMIN] = dev->minread;
|
||||||
|
#endif
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
}
|
}
|
||||||
@ -1560,6 +1579,10 @@ static int uart_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
|
|||||||
dev->tc_iflag = termiosp->c_iflag;
|
dev->tc_iflag = termiosp->c_iflag;
|
||||||
dev->tc_oflag = termiosp->c_oflag;
|
dev->tc_oflag = termiosp->c_oflag;
|
||||||
dev->tc_lflag = termiosp->c_lflag;
|
dev->tc_lflag = termiosp->c_lflag;
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
dev->timeout = termiosp->c_cc[VTIME];
|
||||||
|
dev->minread = termiosp->c_cc[VMIN];
|
||||||
|
#endif
|
||||||
ret = 0;
|
ret = 0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -1813,6 +1836,11 @@ int uart_register(FAR const char *path, FAR uart_dev_t *dev)
|
|||||||
nxsem_init(&dev->recvsem, 0, 0);
|
nxsem_init(&dev->recvsem, 0, 0);
|
||||||
nxmutex_init(&dev->polllock);
|
nxmutex_init(&dev->polllock);
|
||||||
|
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
dev->timeout = 0;
|
||||||
|
dev->minread = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Register the serial driver */
|
/* Register the serial driver */
|
||||||
|
|
||||||
sinfo("Registering %s\n", path);
|
sinfo("Registering %s\n", path);
|
||||||
|
@ -336,7 +336,20 @@ void uart_recvchars_done(FAR uart_dev_t *dev)
|
|||||||
* incoming data available.
|
* incoming data available.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (rxbuf->head >= rxbuf->tail)
|
||||||
|
{
|
||||||
|
nbytes = rxbuf->head - rxbuf->tail;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
nbytes = rxbuf->size - rxbuf->tail + rxbuf->head;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
if (nbytes >= dev->minrecv)
|
||||||
|
#else
|
||||||
if (nbytes)
|
if (nbytes)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
uart_datareceived(dev);
|
uart_datareceived(dev);
|
||||||
}
|
}
|
||||||
|
@ -222,7 +222,6 @@ void uart_recvchars(FAR uart_dev_t *dev)
|
|||||||
/* Add the character to the buffer */
|
/* Add the character to the buffer */
|
||||||
|
|
||||||
rxbuf->buffer[rxbuf->head] = ch;
|
rxbuf->buffer[rxbuf->head] = ch;
|
||||||
nbytes++;
|
|
||||||
|
|
||||||
/* Increment the head index */
|
/* Increment the head index */
|
||||||
|
|
||||||
@ -238,7 +237,20 @@ void uart_recvchars(FAR uart_dev_t *dev)
|
|||||||
* incoming data available.
|
* incoming data available.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (rxbuf->head >= rxbuf->tail)
|
||||||
|
{
|
||||||
|
nbytes = rxbuf->head - rxbuf->tail;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
nbytes = rxbuf->size - rxbuf->tail + rxbuf->head;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
if (nbytes >= dev->minrecv)
|
||||||
|
#else
|
||||||
if (nbytes)
|
if (nbytes)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
uart_datareceived(dev);
|
uart_datareceived(dev);
|
||||||
}
|
}
|
||||||
|
@ -321,6 +321,12 @@ struct uart_dev_s
|
|||||||
* retained in the f_priv field of the 'struct file'.
|
* retained in the f_priv field of the 'struct file'.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef CONFIG_SERIAL_TERMIOS
|
||||||
|
uint8_t minrecv; /* Minimum received bytes */
|
||||||
|
uint8_t minread; /* c_cc[VMIN] */
|
||||||
|
uint8_t timeout; /* c_cc[VTIME] */
|
||||||
|
#endif
|
||||||
|
|
||||||
struct pollfd *fds[CONFIG_SERIAL_NPOLLWAITERS];
|
struct pollfd *fds[CONFIG_SERIAL_NPOLLWAITERS];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user