o
o /---o
/---/---o
o---/
\---\---o
o \---o
o
List system USB buses and devices; a modern lsusb
that attempts to maintain compatibility with, but also add new features. Includes a macOS system_profiler SPUSBDataType
parser module and libusb tool for non-macOS systems/gathering more verbose information.
The project started as a quick replacement for the barely working lsusb script and is my yearly Rust project to keep up to date! It is currently in flux as I build the foundations, learn about custom serde Deserializers and newer Rust features.
The name comes from the technical term for the type of blossom on a Apple tree: cyme - it is Apple related and also looks like a USB device tree 😃🌸.
lsusb
using --lsusb
argument. Supports all arguments including --verbose
output using libusb. Output is indentical for use with no args (list), almost matching for tree (driver port number not included) and near match for verbose.lsusb
but that also work when printing --tree
. Adds --filter_name
, --filter_serial
and option to hide empty --hide-buses
/--hide-hubs
.--tree
mode; shows device, configurations, interfaces and endpoints as tree depending on level of --verbose
.system_profiler
parsing module, lsusb
module using libusb and display
module for printing amoungst others.--json
output that honours filters and --tree
.lsd --blocks
lsd --icon
.system_profiler
.system_profiler
output with libusb output to keep non-user Apple buses.For pre-compiled binaries, see the releases.
From crates.io with a Rust tool-chain installed: cargo install cyme
. If wishing to do it from within a local clone: cargo install --path .
.
If wishing to use only macOS system_profiler
and not obtain more verbose information, remove the 'libusb' feature with cargo install --no-default-features cyme
I also have a Homebrew tap, which will also install a man page and completions:
brew tap tuna-f1sh/cyme
brew install cyme
To obtain device and interface drivers being used on Linux like lsusb
, one must install 'libudev-dev' via a package manager and the --features udev
feature when building. Only supported on Linux targets.
lsusb
If one wishes to create a macOS version of lsusb or just use this instead, create an alias one's environment with the --lsusb
compatibility flag:
alias lsusb='cyme --lsusb'
Will cover this more as it develops. Use cyme --help
for basic usage or man ./doc/cyme.1
.