Skip to main content

HID tools

Project description

hid-tools is a set of tools to interact with the kernel's HID subsystem.

It can be run directly from the git repository or installed via pip3 install hid-tools.

Installation

The hid-tools repository does not need to be installed, all tools and kernel tests can be run straight from the git repository, for example the following commands clone the repository and run the hid-recorder tool.

$ git clone https://gitlab.freedesktop.org/libevdev/hid-tools
$ cd hid-tools
$ sudo ./hid-recorder

Where the tools need to be installed, it is recommended to use pip:

$ sudo pip3 install .

This installs all tools into the system-wide Python path. hid-tools needs root access to the /dev/hidraw nodes, an installation in the user-specific paths will not usually work without further commandline tweaking configuration. Removal of the tools works with pip as well:

$ pip3 uninstall hid-tools

Debugging tools for users

hid-recorder

hid-recorder prints the HID Report Descriptor from a /dev/hidraw device node and any HID reports coming from that device. The output format can be used with hid-replay for debugging. When run without any arguments, the tool prints a list of available devices.

$ sudo hid-recorder

hid-replay

hid-replay takes the output from hid-recorder and replays it through a virtual HID device that looks exactly like the one recorded. hid-replay requires UHID support so make sure pyudev is installed.

$ sudo hid-replay recording-file.hid

hid-decode

hid-decode takes a HID Report Descriptor and prints a human-readable version of it. hid-decode takes binary report descriptors, strings of bytes, and other formats.

$ hid-decode /sys/class/input/event5/device/device/report_descriptor

kernel tests

The hid-tools repository contains a number of tests exercising the kernel HID subsystem. The tests are not part of the pip3 module and must be run from the git repository. The most convenient invocation of the tests is by simply calling pytest. The test suite requires UHID support so make sure pyudev is installed.

$ git clone https://gitlab.freedesktop.org/libevdev/hid-tools
$ cd hid-tools

Note If your testing system is running X, please follow the steps below to let X drivers ignore uhid test devices. Otherwise, the X driver will recognize and handle the test devices, which would interfere with the kernel tests and the running session.

$ sudo cp tests/91-hid-tools-uhid-test.conf /etc/X11/xorg.conf.d/

Restart your X server End of Note

$ sudo pytest-3

See the pytest documentation for information on how to run a subset of tests.

hidtools python module

Technical limitations require that hid-tools ships with a Python module called hidtools. This module is not to be used by external applications.

The hidtools python module does not provide any API stability guarantee. It may change at any time

License

hid-tools is licensed under the GPLv2+.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hid_tools-0.12.tar.gz (85.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hid_tools-0.12-py3-none-any.whl (106.0 kB view details)

Uploaded Python 3

File details

Details for the file hid_tools-0.12.tar.gz.

File metadata

  • Download URL: hid_tools-0.12.tar.gz
  • Upload date:
  • Size: 85.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for hid_tools-0.12.tar.gz
Algorithm Hash digest
SHA256 aa8df2a6924b378891820e3080957c4b16a5bd4939765e24820e71142250cd89
MD5 a9545afb7390ad43a65275d81944e03f
BLAKE2b-256 f6a8efb6a2bb80bfb118fa61f31eef6c22c99c90d2fbd2a6ed91719da7245d79

See more details on using hashes here.

File details

Details for the file hid_tools-0.12-py3-none-any.whl.

File metadata

  • Download URL: hid_tools-0.12-py3-none-any.whl
  • Upload date:
  • Size: 106.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for hid_tools-0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 37e56369ac88d0b151f7529a77b53bac2f0dbdc2d0845a5d261b22ff0a524680
MD5 bb75cb80e6e4566487bbeae63db6d251
BLAKE2b-256 640115355c28be151d4fa85e00608b9b9e45c59340bb93f3e7b09315f5c664d3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page