mirror of
git://git.yoctoproject.org/meta-intel
synced 2026-01-01 13:58:05 +00:00
formfactor: detect USB HID keyboard and touch screen
The new machconfig probes USB keyboard and touch screen, and then sets HAVE_* variables according to detection. Detectable devices: USB HID keyboards (Generic Desktop) USB HID touch screens (Digitizer) Note: The intention is to have a way to provide initial formfactor settings in a boot procedure. That means supported keyboard and touch screen must be connected before machconfig runs. Any new connection or disconnection won't be detected until machconfig is executed again. Limitation: There could be some USB HID devices presents more than one usage in a single descriptor. We will add support once such device emerges. Some platforms may have _virtual_ devices provided by BIOS. It will cause false detection when they are presented as types we supported. We can add black list logic when it becomes a big concern. Fixes [YOCTO #9205] Signed-off-by: Jianxun Zhang <jianxun.zhang@linux.intel.com> Signed-off-by: Tom Zanussi <tom.zanussi@linux.intel.com>
This commit is contained in:
parent
53f25dc1e2
commit
eaadd02702
39
common/recipes-bsp/formfactor/formfactor/machconfig
Normal file
39
common/recipes-bsp/formfactor/formfactor/machconfig
Normal file
|
|
@ -0,0 +1,39 @@
|
|||
# Note: superuser permission is required to run usbhid-dump
|
||||
# successfully.
|
||||
|
||||
# HEX keys are according to the USB HID spec and USB HID usage table
|
||||
# We can add more keys as needed in the future.
|
||||
|
||||
# This test may not be very accurate, as we only look for the first
|
||||
# two lines of a descriptor section. Example:
|
||||
#
|
||||
# 001:003:000:DESCRIPTOR 1460501386.337809
|
||||
# 05 01 09 02 A1 01 09 01 A1 00 05 09 19 01 29 03
|
||||
# 15 00 25 01 95 03 75 01 81 02 .. .. .. .. .. ..
|
||||
# .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ..
|
||||
#
|
||||
# By doing so we eliminate false matches when HEX keys are in the lines
|
||||
# in the middle of the whole descriptor section.
|
||||
|
||||
if type usbhid-dump &>/dev/null; then
|
||||
if USBHID_DUMP_OUTPUT=$(usbhid-dump -e descriptor 2>/dev/null|grep -A1 DESCRIPTOR); then
|
||||
# checker for generic USB HID keyboard
|
||||
USBHID_KBD_CMD="grep -E '^ 05 01 09 06'"
|
||||
|
||||
# checker for touch screen
|
||||
USBHID_TS_CMD="grep -E '^ 05 0D 09 04'"
|
||||
|
||||
if echo "$USBHID_DUMP_OUTPUT"|eval $USBHID_TS_CMD &>/dev/null; then
|
||||
HAVE_TOUCHSCREEN=1
|
||||
fi
|
||||
|
||||
if echo "$USBHID_DUMP_OUTPUT"|eval $USBHID_KBD_CMD &>/dev/null; then
|
||||
HAVE_KEYBOARD=1
|
||||
else
|
||||
# config script in OE will set HAVE_KEYBOARD=1
|
||||
# if we don't set any value. We have to explicitly
|
||||
# tell it when keyboard is not detected.
|
||||
HAVE_KEYBOARD=0
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
1
common/recipes-bsp/formfactor/formfactor_0.0.bbappend
Normal file
1
common/recipes-bsp/formfactor/formfactor_0.0.bbappend
Normal file
|
|
@ -0,0 +1 @@
|
|||
FILESEXTRAPATHS_prepend := "${THISDIR}/${PN}:"
|
||||
Loading…
Reference in New Issue
Block a user