Wraps sigrok-cli to give Claude direct access to logic analyzers and protocol decoders. You get tools to scan for connected hardware, capture data from devices, and decode 100+ protocols including I2C, SPI, UART, and CAN. The server parses raw sigrok-cli output into structured JSON, handling everything from listing supported decoders to checking firmware availability. Ships as a Docker container that communicates over stdio. Useful when you need to debug embedded systems or reverse engineer serial protocols and want Claude to analyze the captures. Some devices like the Kingst LA2016 need firmware files mounted separately since they can't be bundled for licensing reasons.
A Model Context Protocol (MCP) server for sigrok — enables AI agents like Claude Code, Codex, and Cursor to capture, decode, and analyze signals from logic analyzers and measurement devices. Supports I2C, SPI, UART, CAN, and 100+ protocols via sigrok-cli.
Documentation | Getting Started
| Tool | Description |
|---|---|
list_supported_hardware | List all supported hardware drivers |
list_supported_decoders | List all supported protocol decoders |
list_input_formats | List all supported input file formats |
list_output_formats | List all supported output file formats |
show_decoder_details | Show detailed info about a protocol decoder (options, channels, documentation) |
show_driver_details | Show detailed info about a hardware driver (functions, scan options, devices) |
show_version | Show sigrok-cli and library version information |
scan_devices | Scan for connected hardware devices |
capture_data | Capture communication data from a device and save to file |
decode_protocol | Decode protocol data from a captured file using protocol decoders |
check_firmware_status | Check firmware file availability in sigrok firmware directories |
docker pull ghcr.io/kenosinc/sigrok-mcp-server
docker run -i ghcr.io/kenosinc/sigrok-mcp-server
Requires Go 1.25+ and sigrok-cli installed on your system.
go build -o sigrok-mcp-server ./cmd/sigrok-mcp-server
./sigrok-mcp-server
The server communicates over stdio (stdin/stdout JSON-RPC).
Configuration is via environment variables:
| Variable | Default | Description |
|---|---|---|
SIGROK_CLI_PATH | sigrok-cli | Path to the sigrok-cli binary |
SIGROK_TIMEOUT_SECONDS | 30 | Command execution timeout in seconds |
SIGROK_WORKING_DIR | (empty) | Working directory for sigrok-cli execution |
Add to your claude_desktop_config.json:
{
"mcpServers": {
"sigrok": {
"command": "docker",
"args": ["run", "-i", "--rm", "ghcr.io/kenosinc/sigrok-mcp-server"]
}
}
}
To access USB devices from the container:
{
"mcpServers": {
"sigrok": {
"command": "docker",
"args": ["run", "-i", "--rm", "--privileged", "ghcr.io/kenosinc/sigrok-mcp-server"]
}
}
}
To also provide firmware files for devices that require them (e.g. Kingst LA2016):
{
"mcpServers": {
"sigrok": {
"command": "docker",
"args": [
"run", "-i", "--rm", "--privileged",
"-v", "/path/to/sigrok-firmware:/usr/local/share/sigrok-firmware:ro",
"ghcr.io/kenosinc/sigrok-mcp-server"
]
}
}
}
claude mcp add sigrok -- docker run -i --rm ghcr.io/kenosinc/sigrok-mcp-server
With USB access and firmware:
claude mcp add sigrok -- docker run -i --rm --privileged -v /path/to/sigrok-firmware:/usr/local/share/sigrok-firmware:ro ghcr.io/kenosinc/sigrok-mcp-server
Some hardware drivers require firmware files that cannot be bundled with this server due to licensing restrictions. The server works without firmware for devices that don't need it (e.g. demo, protocol-only analysis). For devices that require firmware (e.g. Kingst LA2016, Saleae Logic16), mount your firmware directory into the container at /usr/local/share/sigrok-firmware.
Use the check_firmware_status tool to verify firmware availability and diagnose device detection issues.
See the sigrok wiki for firmware extraction instructions for your device.
MCP Client (LLM)
| stdio (JSON-RPC)
v
sigrok-mcp-server (Go)
| exec.Command
v
sigrok-cli
|
v
libsigrok / libsigrokdecode
capture_data acquires data from devices; all other tools are read-only queriesA typical signal analysis workflow using Claude:
scan_devices — Discover connected hardwareshow_driver_details — Check driver capabilitiescapture_data — Capture communication data to filedecode_protocol — Decode captured data with protocol decoders# Build
go build ./...
# Test
go test ./... -race
# Lint
golangci-lint run ./...
cmd/sigrok-mcp-server/ Entry point
internal/
config/ Environment-based configuration
sigrok/
executor.go sigrok-cli command execution with timeout
parser.go Output parsing (list, decoder, driver, version, scan)
testdata/ Real sigrok-cli output fixtures
tools/
tools.go MCP tool definitions and registration
handlers.go Tool handler implementations
MIT (Kenos, Inc.)
SIGROK_CLI_PATHPath to sigrok-cli binary
SIGROK_TIMEOUT_SECONDSCommand execution timeout in seconds
SIGROK_WORKING_DIRWorking directory for sigrok-cli execution
com.mcparmory/google-sheets
domdomegg/google-sheets-mcp
henilcalagiya/google-sheets-mcp
cct15/war-dashboard-data
moooonad/mcp-google-sheets-full
io.github.br0ski777/csv-to-json