Skip to main content

MCP (Model Context Protocol) server for Saleae Logic analyzers

Project description

Logic Analyzer AI MCP

An MCP (Model Context Protocol) server for interfacing with Saleae Logic analyzers. This tool allows AI assistants (like Claude) to control hardware logic analyzers, capture signals, and export data for analysis.

Features

  • Device Management: List connected devices, configure sample rates and channels.
  • Automation: Start and stop captures programmatically.
  • Data Export: Export captures to CSV/binary formats.
  • Analysis: Perform basic signal analysis (frequency, duty cycle, analog stats) directly via MCP.
  • Logic 2 Integration: Leverages the Saleae Logic 2 automation API for modern device support (Logic 8/16, Pro 8/16).
  • Adaptive Configuration: Works with fixed-voltage devices (like Logic 8) by correctly handling threshold settings.

Prerequisites

  1. Saleae Logic 2 Software: Must be installed and running.
  2. Enable Automation:
    • Open Logic 2.
    • Go to Preferences > Salese Logic 2 (or "Automation").
    • Enable "Enable scripting socket server".
    • Keep the default port 10430.

Installation

From PyPI (Easiest)

pip install logic-analyzer-mcp

Or with uv:

uv pip install logic-analyzer-mcp

From Source (For development)

  1. Clone the repository:

    git clone https://github.com/michelebergo/logic-analyzer-ai-mcp.git
    cd logic-analyzer-ai-mcp
    
  2. Create a virtual environment and sync dependencies:

    uv venv
    uv sync
    
  3. (Optional) Install manually if not syncing:

    uv pip install -e .
    

Usage

Running the MCP Server manually

To run the server and see available tools:

# Activate virtual environment first
.venv\Scripts\activate

# Run the server with Logic 2 automation enabled
python -m src.logic_analyzer_mcp --logic2

Configuration for Claude Desktop

To use this with Claude Desktop, add the following to your config file:

  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Mac: ~/Library/Application Support/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "saleae_logic": {
      "command": "c:\\path\\to\\logic-analyzer-ai-mcp\\.venv\\Scripts\\python.exe",
      "args": [
        "c:\\path\\to\\logic-analyzer-ai-mcp\\src\\logic_analyzer_mcp.py",
        "--logic2"
      ]
    }
  }
}

Note: Replace c:\\path\\to\\... with the actual absolute path to your project folder.

Available Tools

Once connected, the AI assistant will have access to tools like:

  • logic2_reconnect: Connect to the running Saleae software.
  • get_available_devices: List connected hardware or simulation devices.
  • create_device_config: Set up channels and sample rates.
  • capture_and_analyze_digital: One-shot capture + frequency/duty cycle analysis.
  • capture_and_analyze_analog: One-shot capture + voltage statistics.
  • start_capture / wait_capture / save_capture: Granular control over the capture workflow.
  • start_capture_with_trigger: Wait for a digital event (e.g. Rising Edge) before capturing.
  • add_protocol_analyzer: Add decoders like Serial, I2C, SPI to the capture.
  • export_analyzer_data: Export decoded text data to CSV.

Advanced Usage Examples

Using Digital Triggers

To capture only when a specific event happens:

  1. Configure device (create_device_config).
  2. Start trigger capture:
    # Example: Wait for Rising Edge on Channel 0, then record 1 second
    start_capture_with_trigger(
        device_config_name="my_config",
        trigger_channel_index=0,
        trigger_type="RISING",
        after_trigger_seconds=1.0
    )
    

Protocol Decoding (e.g. Serial)

To decode UART/Serial data and export the text:

  1. Perform a capture (standard or triggered).
  2. Add an analyzer:
    add_protocol_analyzer(
        name="Async Serial",
        label="MySerial",
        settings={
            "Input Channel": 0,
            "Bit Rate": 115200
        }
    )
    
  3. Export the decoded table:
    export_analyzer_data(
        filepath="C:\\temp\\serial_data.csv",
        analyzer_label="MySerial"
    )
    

Troubleshooting

  • "Connection Refused": Ensure Logic 2 is running and the scripting server is enabled on port 10430.
  • "Threshold Error": If using Logic 8 (which doesn't support variable thresholds), ensure you don't pass a digital_threshold_volts value (the tool handles this automatically now).

License

MIT

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

logic_analyzer_mcp-0.1.0.tar.gz (29.0 kB view details)

Uploaded Source

Built Distribution

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

logic_analyzer_mcp-0.1.0-py3-none-any.whl (25.8 kB view details)

Uploaded Python 3

File details

Details for the file logic_analyzer_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: logic_analyzer_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 29.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for logic_analyzer_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 90fbdfcdeecf0e853dcaec618832fd9224d657634c5713d7f35d957379f36df2
MD5 af9c53bdbba5750814068836fd6ed69a
BLAKE2b-256 415fdd14f5d48ab71dd694f74a90b02721b4d34c9804c47382204b41aadf0fe6

See more details on using hashes here.

File details

Details for the file logic_analyzer_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: logic_analyzer_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 25.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.18 {"installer":{"name":"uv","version":"0.9.18","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for logic_analyzer_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b5c95ca268599186456d22b9f8ab7fe393eab3da2477bc574f7775509c1768cc
MD5 968b7a05fe397fafe6ca75f247afb3d2
BLAKE2b-256 438e7e1c5483ad170da52ab895aa94271a6b89e9c73f8e287c8a4e10d6e90863

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