2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
2021-06-08 20:05:01 +02:00
|
|
|
* apps/examples/hidkbd/hidkbd_main.c
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
2021-06-08 20:05:01 +02:00
|
|
|
#include <assert.h>
|
2011-03-20 19:18:19 +01:00
|
|
|
#include <errno.h>
|
|
|
|
|
|
|
|
#include <nuttx/usb/usbhost.h>
|
|
|
|
|
2012-12-26 22:37:50 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
|
|
|
# include <nuttx/streams.h>
|
|
|
|
# include <nuttx/input/kbd_codec.h>
|
|
|
|
#endif
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
2013-11-29 21:26:13 +01:00
|
|
|
* Pre-processor Definitions
|
2011-03-20 19:18:19 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2021-02-15 05:07:16 +01:00
|
|
|
/* Configuration ************************************************************/
|
2011-03-20 19:18:19 +01:00
|
|
|
|
|
|
|
#ifdef CONFIG_USBHOST_INT_DISABLE
|
|
|
|
# error "Interrupt endpoints are disabled (CONFIG_USBHOST_INT_DISABLE)"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Provide some default values for other configuration settings */
|
|
|
|
|
|
|
|
#ifndef CONFIG_EXAMPLES_HIDKBD_DEVNAME
|
|
|
|
# define CONFIG_EXAMPLES_HIDKBD_DEVNAME "/dev/kbda"
|
|
|
|
#endif
|
|
|
|
|
2021-08-01 09:28:27 +02:00
|
|
|
#if !defined(CONFIG_HIDKBD_ENCODED) || !defined(CONFIG_LIBC_KBDCODEC)
|
2012-12-26 22:37:50 +01:00
|
|
|
# undef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
|
|
|
#endif
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Private Types
|
|
|
|
****************************************************************************/
|
|
|
|
|
2012-12-26 22:37:50 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
|
|
|
struct hidbkd_instream_s
|
|
|
|
{
|
|
|
|
struct lib_instream_s stream;
|
|
|
|
FAR char *buffer;
|
|
|
|
ssize_t nbytes;
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Private Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
2012-12-26 22:37:50 +01:00
|
|
|
* Name: hidkbd_getstream
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Get one character from the keyboard.
|
|
|
|
*
|
2011-03-20 19:18:19 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2012-12-26 22:37:50 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
|
|
|
static int hidkbd_getstream(FAR struct lib_instream_s *this)
|
|
|
|
{
|
2021-02-15 05:07:16 +01:00
|
|
|
FAR struct hidbkd_instream_s *kbdstream = \
|
|
|
|
(FAR struct hidbkd_instream_s *)this;
|
2012-12-26 22:37:50 +01:00
|
|
|
|
|
|
|
DEBUGASSERT(kbdstream && kbdstream->buffer);
|
|
|
|
if (kbdstream->nbytes > 0)
|
|
|
|
{
|
|
|
|
kbdstream->nbytes--;
|
|
|
|
kbdstream->stream.nget++;
|
|
|
|
return (int)*kbdstream->buffer++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return EOF;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: hidkbd_decode
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Decode encoded keyboard input
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifdef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
|
|
|
static void hidkbd_decode(FAR char *buffer, ssize_t nbytes)
|
|
|
|
{
|
|
|
|
struct hidbkd_instream_s kbdstream;
|
|
|
|
struct kbd_getstate_s state;
|
|
|
|
uint8_t ch;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
/* Initialize */
|
|
|
|
|
|
|
|
memset(&state, 0, sizeof(struct kbd_getstate_s));
|
|
|
|
kbdstream.stream.get = hidkbd_getstream;
|
|
|
|
kbdstream.stream.nget = 0;
|
|
|
|
kbdstream.buffer = buffer;
|
|
|
|
kbdstream.nbytes = nbytes;
|
|
|
|
|
|
|
|
/* Loop until all of the bytes have been consumed. We implicitly assume
|
2017-05-11 21:40:03 +02:00
|
|
|
* that the escaped sequences do not cross buffer boundaries. That
|
2012-12-26 22:37:50 +01:00
|
|
|
* might be true if the read buffer were small or the data rates high.
|
|
|
|
*/
|
|
|
|
|
2021-02-15 05:07:16 +01:00
|
|
|
for (; ; )
|
2012-12-26 22:37:50 +01:00
|
|
|
{
|
|
|
|
/* Decode the next thing from the buffer */
|
|
|
|
|
2012-12-27 15:01:59 +01:00
|
|
|
ret = kbd_decode((FAR struct lib_instream_s *)&kbdstream, &state, &ch);
|
2012-12-29 00:40:54 +01:00
|
|
|
if (ret == KBD_ERROR) /* Error or end-of-file */
|
2012-12-26 22:37:50 +01:00
|
|
|
{
|
2012-12-29 00:40:54 +01:00
|
|
|
/* Break out when all of the data has been processed */
|
|
|
|
|
2012-12-26 22:37:50 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-12-29 00:40:54 +01:00
|
|
|
/* Normal data? Or special key? Press? Or release? */
|
2012-12-26 22:37:50 +01:00
|
|
|
|
2012-12-27 15:01:59 +01:00
|
|
|
switch (ret)
|
2012-12-26 22:37:50 +01:00
|
|
|
{
|
2012-12-27 15:01:59 +01:00
|
|
|
case KBD_PRESS: /* Key press event */
|
|
|
|
printf("Normal Press: %c [%02x]\n", isprint(ch) ? ch : '.', ch);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case KBD_RELEASE: /* Key release event */
|
|
|
|
printf("Normal Release: %c [%02x]\n", isprint(ch) ? ch : '.', ch);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case KBD_SPECPRESS: /* Special key press event */
|
|
|
|
printf("Special Press: %d\n", ch);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case KBD_SPECREL: /* Special key release event */
|
|
|
|
printf("Special Release: %d\n", ch);
|
|
|
|
break;
|
|
|
|
|
2012-12-29 00:40:54 +01:00
|
|
|
case KBD_ERROR: /* Error or end-of-file, already handled */
|
2012-12-27 15:01:59 +01:00
|
|
|
default:
|
|
|
|
printf("Unexpected: %d\n", ret);
|
|
|
|
break;
|
2012-12-26 22:37:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
2012-08-30 22:13:50 +02:00
|
|
|
* Name: hidkbd_main
|
2011-03-20 19:18:19 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2014-09-06 17:23:23 +02:00
|
|
|
int main(int argc, FAR char *argv[])
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
|
|
|
char buffer[256];
|
|
|
|
ssize_t nbytes;
|
|
|
|
int fd;
|
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
/* Eventually logic here will open the kbd device and perform the HID
|
|
|
|
* keyboard test.
|
2013-08-14 01:43:19 +02:00
|
|
|
*/
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2021-02-15 05:07:16 +01:00
|
|
|
for (; ; )
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2017-03-09 22:17:28 +01:00
|
|
|
/* Open the keyboard device. Loop until the device is successfully
|
|
|
|
* opened.
|
2011-03-20 19:18:19 +01:00
|
|
|
*/
|
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
do
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2017-03-09 22:17:28 +01:00
|
|
|
printf("Opening device %s\n", CONFIG_EXAMPLES_HIDKBD_DEVNAME);
|
|
|
|
fd = open(CONFIG_EXAMPLES_HIDKBD_DEVNAME, O_RDONLY);
|
|
|
|
if (fd < 0)
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2017-03-09 22:17:28 +01:00
|
|
|
printf("Failed: %d\n", errno);
|
|
|
|
fflush(stdout);
|
|
|
|
sleep(3);
|
2011-03-20 19:18:19 +01:00
|
|
|
}
|
2017-03-09 22:17:28 +01:00
|
|
|
}
|
|
|
|
while (fd < 0);
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
printf("Device %s opened\n", CONFIG_EXAMPLES_HIDKBD_DEVNAME);
|
|
|
|
fflush(stdout);
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
/* Loop until there is a read failure (or EOF?) */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
do
|
|
|
|
{
|
|
|
|
/* Read a buffer of data */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2017-03-09 22:17:28 +01:00
|
|
|
nbytes = read(fd, buffer, 256);
|
|
|
|
if (nbytes > 0)
|
|
|
|
{
|
|
|
|
/* On success, echo the buffer to stdout */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2012-12-26 22:37:50 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_HIDKBD_ENCODED
|
2017-03-09 22:17:28 +01:00
|
|
|
hidkbd_decode(buffer, nbytes);
|
2012-12-26 22:37:50 +01:00
|
|
|
#else
|
2020-01-02 13:09:50 +01:00
|
|
|
write(1, buffer, nbytes);
|
2012-12-26 22:37:50 +01:00
|
|
|
#endif
|
2011-03-20 19:18:19 +01:00
|
|
|
}
|
|
|
|
}
|
2017-03-09 22:17:28 +01:00
|
|
|
while (nbytes > 0);
|
|
|
|
|
2021-02-15 05:07:16 +01:00
|
|
|
printf("Closing device %s: %d\n", CONFIG_EXAMPLES_HIDKBD_DEVNAME,
|
|
|
|
(int)nbytes);
|
2017-03-09 22:17:28 +01:00
|
|
|
fflush(stdout);
|
|
|
|
close(fd);
|
2011-03-20 19:18:19 +01:00
|
|
|
}
|
2012-12-26 21:04:57 +01:00
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
return 0;
|
|
|
|
}
|