Arduino MCP Server
Provides tools for interacting with Arduino CLI, enabling AI agents to manage boards, install cores and libraries, create, compile, and upload sketches, monitor serial output, and convert images to C arrays for displays.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Arduino MCP Serverlist connected boards"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Arduino MCP Server
A comprehensive Model Context Protocol (MCP) server for Arduino CLI interactions, built with FastMCP. This server enables AI agents to seamlessly interact with Arduino CLI for development, debugging, code verification, and more.
Features
🛠️ Tools (All 3 MCP Pillars)
CLI Management: Check installation, get help for commands
Board Detection: List connected boards, find Arduino ports, auto-detect best port
Core Management: Search, install, and list Arduino cores
Library Management: Search, install, and list Arduino libraries
Sketch Operations: Create, compile, and upload sketches
Enhanced Serial Monitor: Bidirectional communication, buffering, file export
Image Conversion: Convert images to C arrays for display applications (requires ImageMagick)
Configuration: Initialize config, clean cache
📚 Resources
sketch://{path}- Read Arduino sketch files (.ino, .cpp, .h)arduino-config://main- Access Arduino CLI configurationboard-info://{fqbn}- Get detailed board information
💡 Prompts
Blink LED Example: Basic LED blinking sketch template
Sensor Reading Example: Analog sensor reading template
Sketch Project Workflow: IDE-like experience with board attach
Full Development Workflow: Complete Arduino development guide
Troubleshooting Guide: Common issues and solutions
🚀 Advanced Features
Logging: Comprehensive logging with info, warning, error levels (source)
Progress Reporting: Real-time progress updates for long operations (source)
Context Integration: Full MCP context support for enhanced interactions (source)
Annotations: Proper tool annotations for better UX (readOnly, destructive, openWorld hints)
Prerequisites
Python 3.10+
uv (Python package manager)
ImageMagick (optional, for image conversion)
Environment Variables
Customize the server behavior with these optional environment variables:
Variable | Default | Description |
|
| Path to Arduino CLI executable |
| OS-specific* | Override default sketch directory |
|
| Serial buffer size in MB |
| Auto-detected | Custom Arduino CLI config file path |
*Default sketch directories:
Windows:
%DOCUMENTS%\ArduinomacOS:
~/Documents/ArduinoLinux:
~/Arduino
Installation
Clone this repository:
git clone <your-repo-url>
cd arduino-mcpInstall dependencies with uv:
uv syncInstall Arduino CLI:
# Windows (using winget)
winget install ArduinoSA.CLI
# macOS
brew install arduino-cli
# Linux
curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | shUsage
Running the Server
Using uv:
uv run python -m arduino_mcp.serverUsing FastMCP CLI:
uv run fastmcp run arduino_mcp/server.py:mcpFor HTTP transport:
uv run fastmcp run arduino_mcp/server.py:mcp --transport http --port 8000Configuration for MCP Clients
For Cursor IDE
The project includes .cursor/mcp.json configuration. Cursor will automatically detect it when you open the project.
Alternatively, add to your global Cursor settings:
{
"mcpServers": {
"arduino": {
"command": "uvx",
"args": ["arduino-mcp"]
}
}
}For Claude Desktop
Add to your MCP configuration file:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"arduino": {
"command": "uvx",
"args": ["arduino-mcp"]
}
}
}Testing
To verify the Arduino MCP server is working:
# Test import
uv run python -c "from arduino_mcp import mcp; print('Server imports successfully')"
# Start the server
uv run fastmcp run arduino_mcp/server.py:mcpOnce running in Cursor IDE, you can test the tools directly in the chat interface.
Example Workflows
1. Project-Based Workflow with Board Attach (Recommended)
# Find your connected board
list_connected_boards()
# Create a new sketch
create_new_sketch("MyProject")
# Attach board settings to sketch (IDE-like experience!)
arduino_cli_command("board attach -p COM3 -b arduino:avr:uno MyProject")
# This creates sketch.yaml with your board settings
# Now compile and upload without repeating FQBN/port
compile_sketch("MyProject", "") # Reads from sketch.yaml
upload_sketch("MyProject", "", "") # Reads from sketch.yaml
# Monitor serial output with bidirectional communication
serial_monitor(
port="COM3",
baudrate=115200,
duration=30,
send_commands="LED ON\nLED OFF", # Send commands to device
save_to_file="output.log" # Save buffer to file
)Why use board attach?
Settings persist per-sketch (not globally)
No need to repeat FQBN and port every time
Team-friendly (sketch.yaml can be version controlled)
Works exactly like Arduino IDE 2.x
2. Basic Setup and Blink LED
# Check if Arduino CLI is installed
check_arduino_cli_installed()
# Find connected Arduino boards
list_connected_boards()
find_arduino_ports()
get_best_port()
# Create a new sketch
create_new_sketch("BlinkLED", "./sketches")
# Use the blink_led_example prompt for code template
# Compile the sketch
compile_sketch("./sketches/BlinkLED", "arduino:avr:uno")
# Upload to board
upload_sketch("./sketches/BlinkLED", "arduino:avr:uno", "COM3")2. Basic Setup and Blink LED
# Check if Arduino CLI is installed
arduino_cli_command("version")
# Find connected Arduino boards
list_connected_boards()
list_ports(arduino_only=True)
# Create a new sketch
create_new_sketch("BlinkLED", "./sketches")
# Use the blink_led_example prompt for code template
# Compile the sketch
compile_sketch("./sketches/BlinkLED", "arduino:avr:uno")
# Upload to board
upload_sketch("./sketches/BlinkLED", "arduino:avr:uno", "COM3")
# Monitor output
serial_monitor("COM3", baudrate=115200, duration=20)3. Library Installation and Usage
# Search for a library
search_libraries("Adafruit SSD1306")
# Install the library
install_library("Adafruit SSD1306")
# List installed libraries
list_installed_libraries()4. Enhanced Serial Monitor Features
# Basic monitoring (115200 is now the default)
serial_monitor("COM3", duration=30)
# Send commands while monitoring (bidirectional)
serial_monitor(
port="COM3",
baudrate=115200,
duration=30,
send_commands="GET_STATUS\nSET_LED 1"
)
# Save buffer to file for analysis
serial_monitor(
port="COM3",
baudrate=115200,
duration=60,
save_to_file="sensor_data.log"
)
# Combined: send commands and save output
serial_monitor(
port="COM3",
baudrate=115200,
duration=45,
send_commands="START_LOGGING",
save_to_file="experiment_results.txt"
)Buffer Features:
Circular buffer (10MB default, configurable via env var)
Memory-safe (won't crash on long-running captures)
Thread-safe operation
Automatic statistics (lines captured, buffer usage)
5. Image to C Array Conversion
# Check ImageMagick installation
check_imagemagick_installed()
# Convert image to C array for Arduino displays
convert_image_to_c_array(
"logo.png",
width=128,
height=64,
var_name="logo_bitmap",
output_file="logo.h"
)6. Resource Access
# Read a sketch file
read_resource("sketch://./BlinkLED/BlinkLED.ino")
# Get Arduino configuration
read_resource("arduino-config://main")
# Get board details
read_resource("board-info://arduino:avr:uno")Tools Reference
Board & Port Detection
check_arduino_cli_installed()- Verify Arduino CLI installationlist_connected_boards()- List all connected Arduino boardslist_serial_ports()- List all serial portsfind_arduino_ports()- Find Arduino-specific portsget_best_port()- Auto-detect best port candidateverify_port(port)- Verify if a port is accessible
Core Management
list_installed_cores()- List installed Arduino coressearch_cores(query)- Search for Arduino coresinstall_core(core)- Install an Arduino core
Library Management
search_libraries(query)- Search for Arduino librariesinstall_library(library)- Install an Arduino librarylist_installed_libraries()- List installed libraries
Sketch Operations
create_new_sketch(name, path)- Create a new Arduino sketchcompile_sketch(path, fqbn)- Compile an Arduino sketchupload_sketch(path, fqbn, port)- Upload sketch to board
Utilities
get_arduino_help(command)- Get help for Arduino CLI commandsinitialize_config()- Initialize Arduino CLI configurationclean_cache()- Clean Arduino CLI cachecheck_imagemagick_installed()- Check ImageMagick installationconvert_image_to_c_array(...)- Convert images to C arrays
Common FQBNs
Arduino Uno:
arduino:avr:unoArduino Mega 2560:
arduino:avr:megaArduino Nano:
arduino:avr:nanoArduino Leonardo:
arduino:avr:leonardoESP32:
esp32:esp32:esp32ESP8266:
esp8266:esp8266:generic
Architecture
arduino-mcp/
├── arduino_mcp/
│ ├── __init__.py # Package initialization
│ ├── server.py # Main MCP server with tools, resources, prompts
│ ├── cli_wrapper.py # Arduino CLI wrapper
│ ├── port_detector.py # Serial port detection utilities
│ ├── image_converter.py # ImageMagick image conversion
│ └── platform_utils.py # Cross-platform OS detection & handling
├── pyproject.toml # Project configuration
└── README.md # This fileCross-Platform Design
platform_utils.py: Centralized OS detection and platform-specific behavior
Automatic detection: Windows (COM*), macOS (/dev/tty.), Linux (/dev/ttyUSB, /dev/ttyACM*)
Serial keywords: Platform-specific Arduino device identification
Error handling: PermissionError for Linux, graceful fallbacks
Path handling: OS-appropriate path separators and formats
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
References
License
MIT License
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/niradler/arduino-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server