SSH and serial-port control for embedded devices over MCP — log into a Raspberry Pi, talk to a UART, drive a USB-CDC console from your assistant. Drive it from your IDE, terminal, or AI agent and let the model run the lab bench for you.
mcp-remote-access is an MCP server that exposes SSH (over paramiko)
and serial / UART (over pyserial) as MCP tools. It's the "give the
agent root on the bench" MCP — once it's running, your assistant can
log into a Pi, run commands, transfer files, open the serial console,
send AT-style command sequences, and reset a device over DTR/RTS.
It's deliberately thin: 24 tools, two transports, no orchestration language. Higher-level workflow logic lives in your agent's prompts.
What it does well:
- 🤖 AI-native via MCP. First-class Model Context Protocol server with 24 tools across SSH and UART.
- 🐍 Embedded-friendly. Connect to a serial port by VID / PID /
serial / description match — no more guessing
/dev/ttyUSB0vs/dev/ttyUSB1. - ⏳ Background SSH commands. Long-running commands (
make,pytest,tcpdump) run async viassh_execute_background; poll withssh_check_background. - 🤝 Prompt-aware UART.
serial_expectandserial_wait_forhandle login prompts, AT-style flows, and bootloader handshakes without race conditions. - 🔌 DTR / RTS control. Hard-reset MCUs over USB-serial, send break signals, hold the boot pin low — the usual embedded tricks.
- 🔒 AGPL-3.0-or-later. Memory-only credentials, no on-disk session store.
git clone https://github.com/RFingAdam/mcp-remote-access.git
cd mcp-remote-access
uv pip install -e .|
CLI Run the MCP server directly (stdio): uv run --directory /path/to/mcp-remote-access \
mcp-remote-access |
Add to an MCP client Codex CLI: codex mcp add remote-access -- \
uv run --directory /path/to/mcp-remote-access mcp-remote-accessClaude Code: claude mcp add remote-access -- \
uv run --directory /path/to/mcp-remote-access mcp-remote-access |
|
MCP (Claude Desktop, Claude Code, Codex CLI, any MCP client) Add to your client's config file: {
"mcpServers": {
"remote-access": {
"command": "uv",
"args": ["run", "--directory", "/path/to/mcp-remote-access", "mcp-remote-access"]
}
}
}Then ask your assistant:
The agent calls |
|
24 MCP tools across two transports. Full reference in docs/tools.md.
| Tool | Purpose |
|---|---|
ssh_connect |
Connect to a host via SSH (password or key auth) |
ssh_execute |
Run a command on a connected host (sync) |
ssh_execute_background |
Run a long-running command async, returns job_id |
ssh_check_background |
Check status / collect output of a background command |
ssh_list_background |
List all active background commands |
ssh_upload |
Upload a file via SFTP |
ssh_download |
Download a file via SFTP |
ssh_disconnect |
Close an SSH connection |
ssh_list_connections |
Show active SSH connections |
| Tool | Purpose |
|---|---|
serial_list_ports |
List available serial ports (with VID/PID, description, serial #) |
serial_connect |
Connect by port name |
serial_connect_match |
Connect by VID / PID / serial / description match |
serial_esp32_connect |
ESP32-aware connect (BOOT/RESET sequence, auto-baud) |
serial_send |
Send data (with optional response read + configurable line ending) |
serial_read |
Read available data |
serial_wait_for |
Wait for a pattern in the incoming stream |
serial_expect |
Expect / send sequences (login prompts, AT flows) |
serial_send_break |
Send a break signal |
serial_set_dtr |
Set DTR line state |
serial_set_rts |
Set RTS line state |
serial_reset_device |
Reset device via DTR/RTS sequence |
serial_flush |
Flush serial buffers |
serial_disconnect |
Close a serial connection |
serial_list_connections |
Show active serial connections |
mcp-remote-access fits in the following eng-mcp-suite
workflow bundles:
lab-automation— pair withmcp-rs-spectrum-analyzer,mcp-rs-siggen,copper-mountain-vna-mcpto fully script a bench (DUT login over SSH or UART, lab gear over SCPI).embedded-bringup—serial_connect_match+serial_expect+ssh_uploadfor boot-loader interaction and image flashing.
Part of eng-mcp-suite.
Use in the lab-automation workflow bundle.
See the suite manifest for the full list of sibling MCPs and bundle definitions.
- 📘 Quick Start — install through first call.
- 🛠️ Tool reference — every MCP tool, every argument.
- 📐 Usage examples — practical end-to-end walkthroughs.
- 🏗️ Architecture — how this MCP fits in eng-mcp-suite.
This MCP server is part of
An open umbrella for engineering MCP servers across RF, EMC, PCB, signal integrity, EM simulation, and lab test. Same brand, same docs structure, designed to compose. See the full catalog or jump to a sibling:
| Domain | Sibling MCPs |
|---|---|
| RF / Transmission lines | lineforge |
| EMC regulatory | mcp-emc-regulations |
| PCB / SI | mcp-pcb-emcopilot (private — public soon) |
| EM simulation | mcp-openems, mcp-nec2-antenna (private — public soon) |
| Diagrams | drawio-engineering-mcp |
| 3D / rendering | mcp-blender |
| Remote access | mcp-remote-access (this repo) |
| Lab gear | copper-mountain-vna-mcp, mcp-rs-spectrum-analyzer, mcp-rs-siggen, mcp-rs-cmw500 |
- SSH passwords are kept in memory only and cleared on server restart.
- Connections are session-scoped; the server does not persist a session store on disk.
- Use SSH keys where possible.
- The MCP server runs over stdio — it only accepts connections from the local MCP client, never from the network.
SSH connection issues — verify the host is reachable
(ping vpn-ap.local), that SSH is listening on the target
(ssh pi@vpn-ap.local from the same shell), and that credentials are
correct.
Serial port issues — check port permissions
(ls -la /dev/ttyUSB*), add your user to the dialout group
(sudo usermod -a -G dialout $USER and re-login), and confirm the
device is present (dmesg | tail).
VID/PID match selects wrong device — serial_connect_match returns
the first hit; pair the match on description or serial_number to
disambiguate.
Contributions are welcome.
- Pick a GitHub issue.
- Fork + branch (
feature/your-thingorfix/your-bug). - Run tests (
uv run pytest) if present. - Open a PR — link the issue, request review.
AGPL-3.0-or-later. Relicensed from Apache-2.0 in v0.2.0 to align with the eng-mcp-suite toolkit-wide AGPL move.
- paramiko — SSH transport.
- pyserial — serial / UART transport.
- The MCP working group — for the Model Context Protocol specification.
Part of eng-mcp-suite — built for RF engineers, PCB designers, EMC labs, and AI agents.