You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.5 KiB
52 lines
1.5 KiB
4 years ago
|
---
|
||
|
id: dev-guide-usb-logging
|
||
|
title: USB Logging
|
||
|
---
|
||
|
|
||
|
## Overview
|
||
|
|
||
|
If you are developing ZMK on a device that does not have a built in UART for debugging and log/console output,
|
||
|
Zephyr can be configured to create a USB CDC ACM device and the direct all `printk`, console output, and log
|
||
|
messages to that device instead.
|
||
|
|
||
|
## Kconfig
|
||
|
|
||
|
The following KConfig values need to be set, either by copy and paste into the `app/prj.conf` file, or by running
|
||
|
`west build -t menuconfig` and manually enabling the various settings in that UI.
|
||
|
|
||
|
```
|
||
|
# Turn on logging, and set ZMK logging to debug output
|
||
|
CONFIG_LOG=y
|
||
|
CONFIG_ZMK_LOG_LEVEL_DBG=y
|
||
|
|
||
|
# Turn on USB CDC ACM device
|
||
|
CONFIG_USB_CDC_ACM=y
|
||
|
CONFIG_USB_CDC_ACM_RINGBUF_SIZE=1024
|
||
|
CONFIG_USB_CDC_ACM_DEVICE_NAME="CDC_ACM"
|
||
|
CONFIG_USB_CDC_ACM_DEVICE_COUNT=1
|
||
|
|
||
|
# Enable serial console
|
||
|
CONFIG_SERIAL=y
|
||
|
CONFIG_CONSOLE=y
|
||
|
CONFIG_UART_INTERRUPT_DRIVEN=y
|
||
|
CONFIG_UART_LINE_CTRL=y
|
||
|
|
||
|
# Enable USB UART, and set the console device
|
||
|
CONFIG_UART_CONSOLE=y
|
||
|
CONFIG_USB_UART_CONSOLE=y
|
||
|
CONFIG_UART_CONSOLE_ON_DEV_NAME="CDC_ACM_0"
|
||
|
CONFIG_USB_UART_DTR_WAIT=n
|
||
|
```
|
||
|
|
||
|
## Viewing Logs
|
||
|
|
||
|
After flashing the updated ZMK image, the board should expose a USB CDC ACM device, that you can connect to and view the logs.
|
||
|
|
||
|
On Linux, this should be a device like `/dev/ttyACM0` and you can connect with `minicom` or `tio` as usual, e.g.:
|
||
|
|
||
|
```
|
||
|
sudo tio /dev/ttyACM0
|
||
|
```
|
||
|
|
||
|
From there, you should see the various log messages from ZMK and Zephyr, depending on which systems you have set to what log levels.
|