2019-12-05 13:22:36 +01:00
|
|
|
# Copyright (c) 2019 HAW Hamburg
|
|
|
|
#
|
|
|
|
# This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
# General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
# directory for more details.
|
|
|
|
#
|
|
|
|
menuconfig KCONFIG_USB
|
2023-04-05 15:07:01 +02:00
|
|
|
bool "USB device"
|
|
|
|
depends on HAS_PERIPH_USBDEV || HAS_TINYUSB_DEVICE || MODULE_USBDEV_MOCK
|
|
|
|
depends on TEST_KCONFIG
|
2019-12-05 13:22:36 +01:00
|
|
|
help
|
2023-04-05 15:07:01 +02:00
|
|
|
Enable the USB device peripheral.
|
|
|
|
|
2019-12-05 13:22:36 +01:00
|
|
|
|
|
|
|
if KCONFIG_USB
|
|
|
|
|
2023-04-05 15:07:01 +02:00
|
|
|
choice USB_IMPLEMENTATION
|
|
|
|
bool "USB implementation"
|
|
|
|
help
|
|
|
|
Select the USB implementation.
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
rsource "usbus/Kconfig"
|
|
|
|
|
2019-12-05 13:22:36 +01:00
|
|
|
menu "Power management"
|
|
|
|
|
|
|
|
config USB_MAX_POWER
|
|
|
|
int "Reported maximum power draw [mA]"
|
|
|
|
default 100
|
|
|
|
range 0 500
|
|
|
|
|
|
|
|
config USB_SELF_POWERED
|
|
|
|
bool "Report as self-powered device"
|
|
|
|
help
|
|
|
|
When enabled, the device advertises itself as a self-powered device to
|
|
|
|
the host computer.
|
|
|
|
|
|
|
|
endmenu # Power management
|
|
|
|
|
|
|
|
choice
|
|
|
|
bool "USB specification version"
|
|
|
|
|
|
|
|
config USB_SPEC_BCDVERSION_2_0
|
|
|
|
bool "USB v2.0"
|
|
|
|
help
|
|
|
|
The peripheral acts as an USB version 2.0 device.
|
|
|
|
|
|
|
|
config USB_SPEC_BCDVERSION_1_1
|
|
|
|
bool "USB v1.1"
|
|
|
|
help
|
|
|
|
The peripheral acts as an USB version 1.1 device.
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
2023-04-05 15:07:01 +02:00
|
|
|
config CUSTOM_USB_VID_PID
|
|
|
|
bool "Use custom VID and PID"
|
|
|
|
help
|
|
|
|
If using in USB in application then one must set a VID and PID.
|
|
|
|
If RIOT is internally using the USB, say for STDIO, then the VID and
|
|
|
|
PID depending in the internal peripheral configuration used.
|
|
|
|
|
2019-12-05 13:22:36 +01:00
|
|
|
config USB_PID
|
|
|
|
hex "Product ID"
|
2023-04-05 15:07:01 +02:00
|
|
|
depends on CUSTOM_USB_VID_PID
|
2019-12-05 13:22:36 +01:00
|
|
|
range 0x0000 0xFFFF
|
2023-06-02 12:32:19 +02:00
|
|
|
# default 0x7D02 if MODULE_RIOTBOOT_DFU
|
|
|
|
default 0x7D01
|
2019-12-05 13:22:36 +01:00
|
|
|
help
|
|
|
|
You must provide your own PID.
|
|
|
|
|
|
|
|
config USB_VID
|
|
|
|
hex "Vendor ID"
|
|
|
|
range 0x0000 0xFFFF
|
2023-04-05 15:07:01 +02:00
|
|
|
depends on CUSTOM_USB_VID_PID
|
2020-02-18 09:57:04 +01:00
|
|
|
default 0x1209
|
2019-12-05 13:22:36 +01:00
|
|
|
help
|
|
|
|
You must provide your own VID.
|
|
|
|
|
|
|
|
config USB_MANUF_STR
|
|
|
|
string "Manufacturer string"
|
|
|
|
default "RIOT-os.org"
|
|
|
|
|
|
|
|
config USB_PRODUCT_STR
|
|
|
|
string "Product string"
|
2022-08-29 16:39:05 +02:00
|
|
|
default BOARD
|
2019-12-05 13:22:36 +01:00
|
|
|
|
|
|
|
config USB_CONFIGURATION_STR
|
|
|
|
string "Configuration string"
|
|
|
|
default "USB config"
|
|
|
|
|
|
|
|
config USB_PRODUCT_BCDVERSION
|
|
|
|
hex "Device version"
|
|
|
|
default 0x0100
|
|
|
|
help
|
|
|
|
This is the version number of this peripheral. Not to be confused with
|
|
|
|
the USB version number.
|
|
|
|
|
|
|
|
config USB_DEFAULT_LANGID
|
|
|
|
hex "Reported string Language ID"
|
|
|
|
default 0x0409
|
|
|
|
help
|
|
|
|
The default value is EN-US (0x0409).
|
|
|
|
|
2020-12-16 17:22:30 +01:00
|
|
|
config USB_CUSTOM_SERIAL_STR
|
|
|
|
bool "Configure a custom USB serial string"
|
|
|
|
|
|
|
|
config USB_SERIAL_STR
|
|
|
|
string "Serial string"
|
|
|
|
depends on USB_CUSTOM_SERIAL_STR
|
|
|
|
help
|
|
|
|
USB peripheral serial string
|
|
|
|
|
|
|
|
Compile-time value to override the serial string with. An LUID-based hex
|
|
|
|
string is generated when this value is not used.
|
|
|
|
|
|
|
|
This string does not have to be a number, but it must be unique between
|
|
|
|
devices with identical VID:PID combination.
|
|
|
|
|
|
|
|
config USB_SERIAL_BYTE_LENGTH
|
|
|
|
int "USB peripheral serial string length"
|
|
|
|
depends on !USB_CUSTOM_SERIAL_STR
|
|
|
|
range 0 63
|
|
|
|
default 8
|
|
|
|
help
|
|
|
|
The length here is in bytes. The generated hex string is twice as many chars
|
|
|
|
in length due to conversion from bytes to hex chars.
|
|
|
|
|
|
|
|
comment "WARNING: The serial string is empty!"
|
|
|
|
depends on USB_SERIAL_STR = "" && USB_CUSTOM_SERIAL_STR
|
2020-02-13 16:15:52 +01:00
|
|
|
|
2019-12-05 13:22:36 +01:00
|
|
|
endif # KCONFIG_USB
|