servomotor-mcp
Drive open-source Gearotons M17 servomotors from natural language via an MCP server with safety rails and a mock backend.
README
servomotor-mcp
Drive open-source Gearotons M17 servomotors from natural language.
An MCP server that exposes the M17 — a NEMA-17 integrated, closed-loop, RS-485 servomotor — as a small set of safe, high-level tools. Connect it to Claude Desktop, Claude Code, or any MCP client and control real motors by just asking:
"Home everything, then draw a square with the X and Y axes."
It ships with a mock backend, so you can try the whole thing with no hardware.
The first servomotor with an official MCP server. Open hardware, open firmware, open software — and now an open, AI-native control interface.
Quickstart (no hardware, ~2 minutes)
# Run the server directly with uv (recommended):
uvx --from servomotor-mcp servomotor-mcp
# or install it:
pip install servomotor-mcp
servomotor-mcp
Then add it to Claude Desktop — copy the block from
examples/claude_desktop_config.json into your
claude_desktop_config.json, restart Claude Desktop, and ask:
"What motors do you have connected?" See examples/demo_prompts.md
for the full scripted demo.
Drive real motors
Plug an M17 (or a daisy-chain of them) into a USB↔RS-485 adapter and switch the backend:
pip install 'servomotor-mcp[serial]' # pulls in the Gearotons servomotor library
GEAROTONS_MOTOR_BACKEND=serial \
GEAROTONS_SERIAL_PORT=/dev/ttyUSB0 \
servomotor-mcp
Tools
| Tool | What it does |
|---|---|
list_motors |
Discover motors on the bus + positions (call first). |
move_to |
Move a motor to an absolute angle (closed-loop). |
move_relative |
Nudge a motor by a delta. |
trapezoid_move |
Smooth accel/decel move (best for arms/plotters). |
home |
Home one or all motors. |
get_status |
Position / moving / voltage / errors. |
stop |
Halt one or all motors. |
reset |
Recover a motor from a latched fault (firmware system reset, ~2 s). |
run_sequence |
Run a choreographed sequence ("draw a square"). |
Safety rails (in the server, not the model)
The LLM can hallucinate a tool call; these make that safe — they run on every request:
- Alias allow-list — only configured motors can be driven.
- Position limits — absolute/relative targets are clamped to a per-motor software range, so a bad command can't drive an axis into a hard stop.
- Speed clamp — requested speeds are capped.
Clamps are reported back to the model (in safety_notes) rather than silently applied,
so it can see what actually happened and adjust. Configure via env:
GEAROTONS_MOTOR_ALIASES="x,y,z"
GEAROTONS_LIMITS='{"x":{"min_deg":-180,"max_deg":180,"max_speed":300},"z":{"min_deg":0,"max_deg":90}}'
How it works
natural language → Claude → MCP tool calls → this server → RS-485 → M17 motors
The server is a thin, safety-checked wrapper over the Gearotons servomotor Python
library (high-level, unit-aware commands — no DIR/STEP timing). The same intents run
against the mock backend for development and CI.
Develop / test
pip install -e '.[dev]'
pytest # safety + mock-bus tests, no hardware needed
GEAROTONS_MOCK_SIM_SECONDS=0.4 servomotor-mcp # lifelike timing for demos
Status
- ✅ MCP server, full tool surface, safety rails, mock backend — done; 16 unit tests pass.
- ✅
SerialBusreal-hardware backend — verified against a physical M17 (fw 0.15.0.0): discovery, telemetry, closed-loop moves at 0.000° repeatability, and a live safety clamp (a 200° command on a ±90° motor stopped at 90°). Seehardware_tests/. - 🔜 Live FastMCP-over-stdio run with Claude Desktop needs a Python ≥3.10 host (tool logic already hardware-verified); plus the physical demo build + video. See demo spec.
License
MIT. Hardware, firmware, and software for the M17 are open-source — see github.com/tomrodinger/servomotor.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.