zephyr/samples/subsys/usb/hid-keyboard
Declan Snyder 8ed80ddb37 boards: mimxrt1060_evk: Convert to variants
Convert qspi and hyperflash to variants instead of revisions by popular
demand.

And convert evkb into a revision instead of a different board.

Signed-off-by: Declan Snyder <declan.snyder@nxp.com>
2024-12-20 22:59:59 +01:00
..
src usb: device_next: add device configuration change notification 2024-08-16 08:50:25 -04:00
app.overlay usb: device_next: rename the rate properties to use the correct unit 2024-06-13 08:03:49 -04:00
CMakeLists.txt
Kconfig
large_in_report.overlay usb: device_next: rename the rate properties to use the correct unit 2024-06-13 08:03:49 -04:00
large_out_report.overlay usb: device_next: rename the rate properties to use the correct unit 2024-06-13 08:03:49 -04:00
out_report.overlay usb: device_next: rename the rate properties to use the correct unit 2024-06-13 08:03:49 -04:00
prj.conf
README.rst samples: usb: fix API references 2024-07-10 14:36:46 +02:00
sample.yaml boards: mimxrt1060_evk: Convert to variants 2024-12-20 22:59:59 +01:00

.. zephyr:code-sample:: usb-hid-keyboard
   :name: USB HID keyboard
   :relevant-api: usbd_api usbd_hid_device input_interface

   Implement a basic HID keyboard device.

Overview
********

This sample application demonstrates the HID keyboard implementation using the
new experimental USB device stack.

Requirements
************

This project requires an experimental USB device driver (UDC API) and uses the
:ref:`input` API. There must be a :dtcompatible:`gpio-keys` group of buttons
or keys defined at the board level that can generate input events.
At least one key is required and up to four can be used. The first three keys
are used for Num Lock, Caps Lock and Scroll Lock. The fourth key is used to
report HID keys 1, 2, 3 and the right Alt modifier at once.

The example can use up to three LEDs, configured via the devicetree alias such
as ``led0``, to indicate the state of the keyboard LEDs.

Building and Running
********************

This sample can be built for multiple boards, in this example we will build it
for the nRF52840DK board:

.. zephyr-app-commands::
   :zephyr-app: samples/subsys/usb/hid-keyboard
   :board: nrf52840dk/nrf52840
   :goals: build flash
   :compact: