Server data from the Official MCP Registry
Compiler-backed read-only Verilog and SystemVerilog project analysis.
Compiler-backed read-only Verilog and SystemVerilog project analysis.
pyslang-mcp is a well-designed read-only MCP server for HDL analysis with proper permission scoping and security guardrails. The codebase demonstrates good security hygiene with strict project-root validation, read-only tool constraints, and appropriate use of standard libraries. Minor code quality concerns around broad exception handling and informational logging practices do not materially impact security. Supply chain analysis found 3 known vulnerabilities in dependencies (0 critical, 2 high severity). Package verification found 1 issue.
3 files analyzed · 7 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-ariklapid-pyslang-mcp": {
"args": [
"pyslang-mcp"
],
"command": "uvx"
}
}
}From the project's GitHub README.
pyslang-mcp is a local Model Context Protocol server that gives AI agents
compiler-backed, read-only context for Verilog and SystemVerilog projects.
It wraps pyslang so an MCP client can ask
questions against parsed and elaborated HDL instead of plain text:
.f files resolve as expected?This is not a simulator, synthesizer, waveform viewer, linter replacement, or RTL refactoring tool. It is a small semantic analysis service for local HDL checkouts.
That read-only boundary is intentional. It keeps the server side-effect free, reduces the blast radius in IP-protected workspaces, and makes it safer to use in local and CI environments.
It was decided to keep pyslang-mcp read-only. The LLM handles the actual RTL
coding, while pyslang-mcp serves as the compile/elab-backed reader, checker,
and explainer for code that already exists. In other words, the model drafts
the RTL and the MCP server verifies what the compiler frontend sees.
[!NOTE] The project is currently early-stage and published on PyPI and the MCP Registry for local stdio use.
Most AI coding tools are good at searching text. HDL usually needs more than that.
In real projects, useful answers often depend on filelists, packages, includes,
defines, generate blocks, and hierarchy. pyslang-mcp gives an agent a compact
compiler-backed view of that structure, while keeping the server read-only and
scoped to a project root you provide.
Good fits:
.f file expands toInstall the package:
pip install pyslang-mcp
Run the local stdio server:
pyslang-mcp
For contributor setup, clone the repo and install it in editable mode:
git clone https://github.com/ariklapid/pyslang-mcp.git
cd pyslang-mcp
python -m venv .venv
./.venv/bin/pip install -e '.[dev]'
Run the checkout stdio server:
./.venv/bin/python -m pyslang_mcp
The installed console script works too:
./.venv/bin/pyslang-mcp
Run tests:
./.venv/bin/pytest
Use local stdio. The MCP client should launch the server on the same machine,
VM, or dev container that can see your RTL checkout.
{
"mcpServers": {
"pyslang-mcp": {
"command": "pyslang-mcp",
"args": []
}
}
}
For editable checkout installs, point the command at the checkout virtual environment instead:
{
"mcpServers": {
"pyslang-mcp": {
"command": "/absolute/path/to/pyslang-mcp/.venv/bin/python",
"args": ["-m", "pyslang_mcp"]
}
}
}
Tool calls must provide a project_root. Source paths, filelists, and include
directories may be absolute or relative, but they must stay under that root.
Analyze explicit files:
{
"project_root": "/path/to/rtl-project",
"files": ["rtl/pkg.sv", "rtl/top.sv"],
"include_dirs": ["include"],
"defines": {
"WIDTH": "32"
},
"top_modules": ["top"]
}
Analyze a filelist:
{
"project_root": "/path/to/rtl-project",
"filelist": "compile/project.f"
}
Find a symbol:
{
"project_root": "/path/to/rtl-project",
"filelist": "compile/project.f",
"query": "payload",
"match_mode": "exact",
"include_references": true
}
| Need | Tool |
|---|---|
| Load explicit files | pyslang_parse_files |
Load a .f filelist | pyslang_parse_filelist |
| Get parse and semantic diagnostics | pyslang_get_diagnostics |
| List modules, interfaces, and packages | pyslang_list_design_units |
| Inspect one design unit | pyslang_describe_design_unit |
| Walk the elaborated instance tree | pyslang_get_hierarchy |
| Find declarations and references | pyslang_find_symbol |
| Summarize syntax node shapes | pyslang_dump_syntax_tree_summary |
| Check preprocessing metadata and excerpts | pyslang_preprocess_files |
| Get a compact project overview | pyslang_get_project_summary |
Typical flow:
pyslang_parse_filelist or pyslang_parse_files.pyslang_get_diagnostics.pyslang_list_design_units to see what the compiler frontend found.pyslang_describe_design_unit, pyslang_get_hierarchy, or
pyslang_find_symbol for the actual review/debug question.The current parser intentionally supports a practical subset used by many RTL flows:
-f and -F+incdir+..., -I dir, and -Idir+define+..., -D NAME, and -DNAMEUnsupported filelist tokens are reported in the tool output instead of being silently ignored.
Use this server when compiler-backed context matters:
compile/project.f with +define+DEBUG and group diagnostics by
source file."top, show the instance hierarchy down to depth 4."axi_dma_top: ports, child instances, and declared names."payload_valid."legacy_widget is instantiated anywhere the elaborator
sees it."For single-line questions, comments, naming searches, or partial/incomplete
source sets, regular rg, editor search, or direct file reading is usually
faster and clearer.
project_root are rejected.pyslang_preprocess_files is summary-oriented. It returns preprocessing
metadata and source excerpts, not a guaranteed full standalone preprocessed
stream.streamable-http remains experimental. The internal MaaS path wraps it with
a bearer token for single-server use, but it is not a complete production
hosted security boundary by itself.Remote MaaS is planned as two separate tracks, not as one generic hosted mode:
Start with the internal MaaS quickstart for a single internal server. See REMOTE_DEPLOYMENT.md for the full Plan A / Plan B split.
Docker Compose is the recommended bring-up path because it avoids Python setup issues and mounts the RTL checkout read-only. Docker is not required; the quickstart also includes a native Python path for corporate servers where containers are not available.
The repo includes generated HDL examples under
examples/hdl:
easy, medium, and hardpyslang and verilator --lint-onlyRun the full corpus validator:
./.venv/bin/python scripts/validate_hdl_examples.py
Run the CI smoke subset:
./.venv/bin/python scripts/validate_hdl_examples.py --smoke-only
If your agent environment already has a broad RTL skill such as
rtl-analysis, rtl-audit, or llm-based-verilog-analysis, use
pyslang-verilog-context as the fine-grained compiler-evidence layer beneath
that broader skill.
Recommended setup:
pyslang-mcp server in your MCP client so the agent can call
the read-only pyslang_* tools.pyslang-verilog-context skill from
skills/pyslang-verilog-context.For Verilog/SystemVerilog tasks, use $pyslang-verilog-context before making
claims about diagnostics, design units, ports, hierarchy, declarations,
references, includes, defines, or filelist behavior. Treat its output as
compiler frontend evidence only. Do not present it as simulation, synthesis,
timing, CDC/RDC, formal, or full lint signoff.
The intended flow is:
user RTL request
-> broad RTL analysis/audit skill
-> pyslang-verilog-context
-> pyslang-mcp compiler-backed evidence
-> final answer with evidence and limitations
This keeps high-level RTL review policy in the broad skill while grounding
Verilog/SystemVerilog structure, diagnostics, hierarchy, symbols, includes, and
filelists in pyslang.
The repo includes a pyslang-verilog-context skill eval suite under
skills/pyslang-verilog-context/evals
and comparison reports under reports/. The current benchmark
compares three local evidence modes:
pyslang-mcp tool callspyslang-verilog-context sequencing with pyslang-mcpLatest local result from 2026-05-23:
| Benchmark | Text/no skill | MCP/no skill | Skill + MCP |
|---|---|---|---|
| 100 HDL analysis cases | 60/100 | 95/100 | 100/100 |
The benchmark mixes deterministic repo-local HDL fixtures with real public RTL
source files. The local fixtures exercise targeted behaviors such as filelists,
hierarchy, symbols, diagnostics, clean-frontend functional bugs, and RTL coding
and bug-audit discipline. The real public RTL cases use source files from
lowrisc-ibex,
pulp-common-cells, verilog-axis, pulp-axi,
pulp-register-interface, and picorv32. They exercise frontend diagnostic
status, design-unit inventory, and first-unit port counts on real source files.
See docs/evaluation-benchmarks.md for the
prompt/task shapes and MCP functions used.
Verification commands used for the reported run:
./.venv/bin/python skills/pyslang-verilog-context/scripts/validate_eval_fixtures.py
./.venv/bin/python -m pytest
./.venv/bin/python skills/pyslang-verilog-context/scripts/run_comparison_evals.py
./.venv/bin/python scripts/run_mcp_comparison.py --output-dir reports/mcp_comparison_comprehensive_20260523
./.venv/bin/python reports/real_examples_75/run_real75_comparison.py
./.venv/bin/python -m py_compile reports/real_examples_75/run_real75_comparison.py
These are deterministic scalar harnesses, not blind autonomous LLM-judge runs.
pyslang-mcp evidence remains frontend/compiler context only, not simulation,
synthesis, CDC/RDC, timing, formal, or full lint signoff.
Documentation-only eval/report updates do not require a PyPI release. A PyPI release is warranted when package code, public tool behavior, schemas, runtime dependencies, CLI behavior, or user-facing install/runtime docs change in a way published users need.
Implemented:
FastMCP stdio serverpython -m pyslang_mcp and pyslang-mcp.f parsingpyslang-mcpio.github.ariklapid/pyslang-mcpNot done yet:
Useful commands:
./.venv/bin/ruff check .
./.venv/bin/pyright
./.venv/bin/pytest
Architecture and contribution docs:
Apache-2.0. See LICENSE.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.