专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

ghdl/ext Docker 镜像 - 轩辕镜像

ext
ghdl/ext
即用型Docker镜像,集成GHDL及配套工具(如GHDL语言服务器、GtkWave、VUnit等),适用于VHDL开发与验证。
2 收藏0 次下载
😅 镜像要是出问题,背锅的一定是你
中文简介版本下载
😅 镜像要是出问题,背锅的一定是你

GHDL 及补充工具 Docker 镜像文档

一、镜像概述和主要用途

本镜像为即用型 Docker 镜像,集成了 GHDL(VHDL 编译器/模拟器)及其补充工具(包括 ghdl-language-server、GtkWave、VUnit 等)。旨在提供一个标准化、开箱即用的 VHDL 开发与验证环境,避免用户手动安装和配置各类工具依赖,确保开发环境一致性。

二、核心功能和特性

2.1 集成工具
  • GHDL:开源 VHDL 编译器、模拟器和综合器,支持 VHDL 93/02/08 标准,提供从代码分析到仿真执行的全流程支持。
  • ghdl-language-server:基于 GHDL 的语言服务器协议(LSP)实现,支持代码补全、跳转定义、语法检查等 IDE 集成功能。
  • GtkWave:波形文件查看器,支持 VCD、GHW 等格式,用于分析仿真波形结果。
  • VUnit:开源 VHDL 单元测试框架,支持自动化测试用例管理、结果报告生成,提升代码可靠性。
  • 其他补充工具:根据镜像版本可能包含 Make、Git 等辅助开发工具(详见 dockerfiles)。

三、使用场景和适用范围

  • VHDL 项目开发:快速搭建本地或 CI 环境,进行代码编写、编译与调试。
  • 仿真验证:通过 GHDL 编译 VHDL 代码并执行仿真,结合 GtkWave 分析波形。
  • 单元测试:使用 VUnit 编写测试用例,自动化验证模块功能。
  • IDE 集成:通过 ghdl-language-server 与 VS Code、Vim 等 IDE 集成,获得现代开发体验。
  • CI/CD 流程:在持续集成/部署中使用,确保跨平台环境一致性。
  • 教学与演示:快速部署标准化环境,降低新手入门门槛。

四、使用方法和配置说明

4.1 获取镜像

镜像可从 GHDL 官方 Docker 仓库 获取(需根据具体版本标签拉取,以下示例默认使用 latest 标签):

bash
docker pull ghdl/ghdl:latest  # 假设官方镜像路径,实际请参考仓库文档
4.2 基本使用(docker run)
4.2.1 启动交互式终端

挂载本地项目目录至容器内工作目录(如 /work),启动交互式 shell:

bash
docker run -it --rm \
  -v $(pwd):/work  # 挂载当前目录到容器内 /work
  -w /work         # 设置工作目录为 /work
  ghdl/ghdl:latest \
  bash             # 启动 bash 终端
  • -it:交互式终端模式,支持命令输入。
  • --rm:容器退出后自动删除,避免残留。
  • -v $(pwd):/work:将本地当前目录(项目代码)挂载到容器内 /work,实现文件共享。
4.2.2 常用命令示例

在容器终端中执行以下命令,完成典型开发流程:

  1. 编译 VHDL 代码(以 design.vhd 为例):

    bash
    ghdl -a design.vhd  # 分析(编译)VHDL 文件
    ghdl -e top_entity  #  elaborate(链接)顶层实体,生成可执行仿真文件
    
  2. 执行仿真并生成波形:

    bash
    ghdl -r top_entity --wave=wave.ghw  # 运行仿真,输出 GHW 格式波形文件
    
  3. 使用 GtkWave 查看波形(需宿主机支持 X11 转发,或挂载波形文件到宿主机后本地查看):

    bash
    gtkwave wave.ghw  # 在容器内直接打开波形查看器(需配置 X11 转发)
    
  4. 运行 VUnit 测试(假设项目中已集成 VUnit):

    bash
    vunit run --output-path=test_results  # 执行测试用例,输出结果到 test_results 目录
    
4.3 Docker Compose 配置示例

创建 docker-compose.yml 文件,定义服务配置:

yaml
version: '3.8'

services:
  ghdl-env:
    image: ghdl/ghdl:latest
    volumes:
      - ./project:/work  # 挂载宿主机项目目录(./project)到容器 /work
      - ./wavefiles:/wave  # 可选:单独挂载波形文件目录
    working_dir: /work
    tty: true  # 启用终端交互
    stdin_open: true  # 保持标准输入打开
    # 如需支持 GtkWave 图形界面,添加 X11 转发配置(适用于 Linux 宿主机):
    environment:
      - DISPLAY=${DISPLAY}
    volumes_from:
      - /tmp/.X11-unix:/tmp/.X11-unix

启动服务:

bash
docker-compose up -d  # 后台启动服务
docker-compose exec ghdl-env bash  # 进入容器终端
4.4 配置说明
4.4.1 环境变量

当前镜像未定义特殊环境变量,工具配置(如 GHDL 后端选择、VUnit 路径等)需通过工具自身配置文件或命令行参数实现。

4.4.2 数据持久化

通过 -v 挂载宿主机目录(如项目代码、波形文件、测试结果)实现数据持久化,避免容器销毁后数据丢失。

4.4.3 IDE 集成

若需通过 IDE(如 VS Code)使用 ghdl-language-server,可在容器内启动语言服务器,并配置 IDE 连接至容器内 LSP 端口(需映射端口 -p 2087:2087,具体端口参考工具文档)。

五、注意事项

  • GtkWave 图形界面:在非 Linux 宿主机(如 Windows/macOS)上使用时,需额外配置图形转发工具(如 Xming、VcXsrv)。
  • 镜像版本:不同版本镜像可能集成工具版本不同,建议通过 官方 dockerfiles 确认具体工具版本。
  • 性能优化:大规模项目仿真建议挂载本地目录时使用 :delegated 或 :cached 选项(适用于 Docker Desktop)提升文件 I/O 性能。
查看更多 ext 相关镜像 →
bitnami/external-dns logo
bitnami/external-dns
外部DNS的Bitnami安全镜像
211B+ pulls
上次更新:未知
bitnamicharts/external-dns logo
bitnamicharts/external-dns
Bitnami提供的Helm图表,用于部署和管理ExternalDNS,实现Kubernetes资源与DNS提供商记录的自动同步。
10M+ pulls
上次更新:未知
docker/ucp-interlock-extension logo
docker/ucp-interlock-extension
暂无描述
10M+ pulls
上次更新:未知
docker/extended-logs-extension logo
docker/extended-logs-extension
暂无描述
500K+ pulls
上次更新:未知
rancher/external-dns logo
rancher/external-dns
该容器镜像已停止维护,不建议使用。
21M+ pulls
上次更新:未知
mirantis/ucp-interlock-extension logo
mirantis/ucp-interlock-extension
暂无描述
1M+ pulls
上次更新:未知

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
ghdl/ext
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.