patchwork-mcp-server
Enables LLM agents to query Patchwork kernel patches, series, CI checks, and comments via natural language through a read-only MCP server.
README
patchwork-mcp-server
A Model Context Protocol (MCP) server that exposes the Patchwork REST API to LLM-based coding agents (Claude Code, Claude Desktop, Cursor, etc.).
It is a thin, read-only wrapper around /api/1.2/ so you can ask the
agent things like:
- "What's the state of my latest
seg6:series on netdev?" - "Show me failing CI checks on patch 14553325."
- "List the cover-letter thread for series 1089407."
- "Find the patch with Message-Id
20260505-seg6-mobile-v2-0-...."
Without this server, the same questions either require a working
~/.pwclientrc (which has trouble with CI checks and comment threads)
or hand-rolled curl against the REST API.
Install
Requires Python 3.10+. Install with uv:
# From PyPI (preferred once published)
uv tool install patchwork-mcp-server
# From a local checkout
uv tool install .
# From a Git remote
uv tool install git+https://github.com/higebu/patchwork-mcp-server
The package installs a patchwork-mcp-server executable into ~/.local/bin/. To
refresh an existing install after editing source locally:
uv tool install --reinstall .
Configuration
| Variable | Default | Purpose |
|---|---|---|
PATCHWORK_URL |
https://patchwork.kernel.org |
Base URL of the Patchwork instance |
PATCHWORK_API_VERSION |
1.2 |
REST API version segment |
Read-only access to public Patchwork instances needs no credentials.
Connect to Claude Code
After uv tool install, the executable is on your PATH, so registration
needs no path:
claude mcp add patchwork-mcp-server -- patchwork-mcp-server
For Claude Desktop, add it to ~/.config/claude/claude_desktop_config.json:
{
"mcpServers": {
"patchwork": {
"command": "patchwork-mcp-server"
}
}
}
Tools
| Tool | Purpose |
|---|---|
list_projects |
List Patchwork projects on the instance. |
find_by_msgid |
Look up patches/covers by Message-Id (works across projects). |
get_series |
Series with every patch's state, delegate, archived flag, check summary. |
get_patch |
Single patch with submitter, tags, series links, check summary. |
get_checks |
CI checks for a patch (checkpatch, build_, sashiko-, contest, ...). Optional fail_only. |
get_comments |
Comment thread on a cover letter or patch (time-ordered, body preview). |
recent_series |
Recent cover letters on a project, optional submitter filter, optional revision collapse. |
search_patches |
Substring search over patch names, with project/state/submitter filters. |
Example interaction
What's the state of my SRv6 Mobile series on netdev?
Behind the scenes the agent calls:
find_by_msgid("20260505-seg6-mobile-v2-0-9e8022bdfdb6@gmail.com")to discover series id1089407onnetdevbpf.get_series(1089407)for the per-patch state table.get_checks(<lead_patch>, fail_only=True)to triage CI.get_comments("cover", 14117478)to read the thread.
Development
cd patchwork-mcp-server
uv sync --group dev
just check # ruff lint + format check + pytest
just release patch bumps the version, regenerates CHANGELOG.md via
git-cliff, and tags locally. Push the tag to trigger the PyPI release
workflow.
License
MIT
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.