Connects to a running KiCad 9.0+ instance via its IPC API to programmatically inspect and query PCB designs. You get tools for reading board info, listing footprints and nets, checking design settings, and querying zones, tracks, vias, and pads. Requires enabling the API server in KiCad's plugin preferences first, then the MCP server talks to it over IPC. Useful when you want to automate PCB analysis, extract component data, or build tooling around existing KiCad projects without manually exporting files. Read-only operations focused on inspection rather than modification.
mcp-kicad — MCP server exposing KiCad PCB Editor functionality via IPC API.
pip install mcp-kicad
The MCP server communicates with a running KiCad instance via the IPC API. Start KiCad first, then run the server:
mcp-kicad
Or configure it in your MCP client:
{
"mcpServers": {
"mcp-kicad": {
"command": "mcp-kicad",
"env": {}
}
}
}
The server exposes the following tools:
connect_kicad, check_connectionget_board_info, get_layers, get_board_design_settingslist_footprints, get_footprint, search_footprintslist_nets, get_net, list_netclasseslist_zoneslist_tracks, list_viaslist_padslist_texts, get_text_extentsget_project, get_versionfrom mcp_kicad import mcp_server
# Connect to running KiCad
result = mcp_server.connect_kicad()
# Get board info
board_info = mcp_server.get_board_info()
print(board_info)
# List all footprints
footprints = mcp_server.list_footprints()
for fp in footprints:
print(f"{fp['reference']}: {fp['value']}")
git clone https://github.com/daedalus/mcp-kicad.git
cd mcp-kicad
pip install -e ".[test]"
# run tests
pytest
# format
ruff format src/ tests/
# lint
ruff check src/ tests/
# type check
mypy src/
mcp-name: io.github.daedalus/mcp-kicad