summaryrefslogtreecommitdiff
path: root/nuttx/drivers
diff options
context:
space:
mode:
authorGregory Nutt <gnutt@nuttx.org>2013-08-10 19:21:39 -0600
committerGregory Nutt <gnutt@nuttx.org>2013-08-10 19:21:39 -0600
commit0e6621387a1b415e377fca1b60d70d25366e1680 (patch)
tree2249f0eee7dcc0b1c5b51d8c2675131811822fec /nuttx/drivers
parent3c5fcd7ca22c13071fc85c89036adf43f92ebaf2 (diff)
downloadpx4-nuttx-0e6621387a1b415e377fca1b60d70d25366e1680.tar.gz
px4-nuttx-0e6621387a1b415e377fca1b60d70d25366e1680.tar.bz2
px4-nuttx-0e6621387a1b415e377fca1b60d70d25366e1680.zip
Added FIONREAD and FIONWRITE to CDC/ACM driver. From Lorenz Meier
Diffstat (limited to 'nuttx/drivers')
-rw-r--r--nuttx/drivers/usbdev/cdcacm.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/nuttx/drivers/usbdev/cdcacm.c b/nuttx/drivers/usbdev/cdcacm.c
index 441ac907e..dcd5b9aa1 100644
--- a/nuttx/drivers/usbdev/cdcacm.c
+++ b/nuttx/drivers/usbdev/cdcacm.c
@@ -1937,6 +1937,52 @@ static int cdcuart_ioctl(FAR struct file *filep,int cmd,unsigned long arg)
break;
#endif
+ case FIONREAD:
+ {
+ int count;
+ irqstate_t state = irqsave();
+
+ /* Determine the number of bytes available in the buffer. */
+
+ if (serdev->recv.tail <= serdev->recv.head)
+ {
+ count = serdev->recv.head - serdev->recv.tail;
+ }
+ else
+ {
+ count = serdev->recv.size - (serdev->recv.tail - serdev->recv.head);
+ }
+
+ irqrestore(state);
+
+ *(int *)arg = count;
+ ret = 0;
+ }
+ break;
+
+ case FIONWRITE:
+ {
+ int count;
+ irqstate_t state = irqsave();
+
+ /* Determine the number of bytes free in the buffer. */
+
+ if (serdev->xmit.head < serdev->xmit.tail)
+ {
+ count = serdev->xmit.tail - serdev->xmit.head - 1;
+ }
+ else
+ {
+ count = serdev->xmit.size - (serdev->xmit.head - serdev->xmit.tail) - 1;
+ }
+
+ irqrestore(state);
+
+ *(int *)arg = count;
+ ret = 0;
+ }
+ break;
+
default:
ret = -ENOTTY;
break;