English | 简体中文
该工具包旨在快速开发内核模块,但不保证内核模块能够完全兼容对应版本的内核。
如果需要完全兼容性,请下载完整内核代码并自行编译,具体方法请参考相关文档。
如果不想下载 Clang,可以使用 NDK Clang 进行编译,但可能会导致编译产物的结构体偏移有所不同。
submodule 下的 prebuilts tarball 文件很大,非必要不要 clone submodules
内核模块开发模板:
| 场景 | 推荐模式 |
|---|---|
| Linux 本机开发 | Host 模式(推荐) |
| macOS / Windows 开发 | DevContainer 模式(推荐) |
| CI / 自动化构建 | Docker 模式 |
Note
Host 模式将内核源码和 Clang 工具链直接解压到 /opt/ddk 目录,无需 Docker 或容器环境,是 Linux 用户的首选开发方式。
git-lfs(用于拉取 submodule 中的大文件,必须在克隆前安装并初始化)zstd(用于解压.tar.zst归档文件)jq(用于 VSCode 配置脚本)
安装并启用 Git LFS:
# Debian/Ubuntu
sudo apt install git-lfs
# Arch
sudo pacman -S git-lfs
git lfs installWarning
prebuilts submodule 中包含大量通过 Git LFS 存储的预编译归档文件,体积较大,请确保已安装 git-lfs 并有足够的磁盘空间和网络带宽。
git clone --recurse-submodules https://github.com/Ylarod/ddk.git
cd ddk如果已经克隆但未初始化 submodule:
git submodule update --init --recursivebash host/install.sh安装脚本会将 prebuilts/ 中的内核源码(src)、编译头文件(kdir)和 Clang 工具链(clang)解压到 /opt/ddk:
/opt/ddk/
├── src/ # 各 Android 版本内核源码
│ ├── android12-5.10/
│ ├── android13-5.10/
│ └── ...
├── kdir/ # 各 Android 版本编译头文件
└── clang/ # Clang 工具链
首先确保 ~/.ddk/mapping.json 存在(从仓库根目录的 mapping.json 复制):
mkdir -p ~/.ddk
cp mapping.json ~/.ddk/mapping.json然后运行配置脚本:
bash host/vscode_clangd_configure.sh该脚本会:
- 读取
~/.ddk/mapping.json获取 Android 版本与 Clang 版本的对应关系 - 将
host/.vscode模板(含文件过滤规则、编辑器设置、compile_commands.json生成脚本等)复制到每个/opt/ddk/src/<android-version>/目录 - 配置各目录下
.vscode/settings.json中的clangd.path,指向对应版本的 Clang
支持 --dry-run 参数预览操作:
bash host/vscode_clangd_configure.sh --dry-run用 VSCode 打开对应的内核源码目录,安装 clangd 扩展 后即可获得代码补全、跳转、引用查找等功能:
code /opt/ddk/src/android16-6.12Tip
对于中国大陆用户,可以使用 docker.cnb.cool/ylarod/ddk/ddk 来代替 ghcr.io/ylarod/ddk
DevContainer 通过容器提供与平台无关的一致开发环境,适合无法直接使用 Host 模式的 macOS 或 Windows 用户。
Warning
当你使用这个方法的时候,你必须手动 source envsetup.sh
把下面内容放置到 .devcontainer/devcontainer.json。
可以修改 features 的内容来自由组装想要的镜像,可以选择的版本参考 ddk image versions
参考:
对于 M1 Mac + OrbStack 用户,参考 ddk-module-template 中的 .devcontainer 配置可以开发,还需要提前拉取镜像:
docker run --platform linux/amd64 --rm -it docker.cnb.cool/ylarod/ddk/ddk-builder:latest对于 x86_64 用户:
{
"name": "ddk-module-dev",
"image": "docker.cnb.cool/ylarod/ddk/ddk-builder:latest",
"features": {
"ghcr.io/ylarod/ddk/features/ddk-toolchain:latest": {
"androidVer": "android12-5.10",
"setDefault": true
},
"ghcr.io/ylarod/ddk/features/ddk-src:latest": {
"androidVer": "android12-5.10",
"withKdir": true,
"setDefault": true
}
},
"remoteUser": "root",
"postCreateCommand": "echo Devcontainer ready",
"customizations": {
"vscode": {
"extensions": [
"github.copilot",
"github.copilot-chat",
"github.vscode-github-actions",
"llvm-vs-code-extensions.vscode-clangd",
"ms-azuretools.vscode-containers",
"ms-azuretools.vscode-docker",
"ms-ceintl.vscode-language-pack-zh-hans"
]
}
}
}把下面内容放置到 .devcontainer/devcontainer.json。
可以修改 image 的内容来选择对应的版本开发,可以选择的版本参考 ddk image versions
{
"name": "ddk-module-dev",
"image": "ghcr.io/ylarod/ddk:android16-6.12",
"remoteUser": "root",
"postCreateCommand": "echo Devcontainer ready",
"customizations": {
"vscode": {
"extensions": [
"github.copilot",
"github.copilot-chat",
"github.vscode-github-actions",
"llvm-vs-code-extensions.vscode-clangd",
"ms-azuretools.vscode-containers",
"ms-azuretools.vscode-docker",
"ms-ceintl.vscode-language-pack-zh-hans"
]
}
}
}Note
Docker 模式通过封装好的镜像直接构建,适合 CI 流水线和自动化场景,不推荐作为日常交互式开发环境。
推荐先安装便捷脚本 ddk(封装常用 docker 命令,强制 --platform linux/amd64 并将当前目录挂载为容器内的 /build)。
安装(macOS/Linux):
# 将 ddk 安装到 /usr/local/bin 并赋予可执行权限
sudo curl -fsSL https://raw.githubusercontent.com/Ylarod/ddk/main/scripts/ddk -o /usr/local/bin/ddk
sudo chmod +x /usr/local/bin/ddk用法示例:
# 拉取镜像
ddk pull android12-5.10
# 进入项目目录
cd /path/to/source
# 构建
ddk build --target android12-5.10
# 传递 make 参数
ddk build --target android12-5.10 -- CFLAGS=-O2
# 清理
ddk clean --target android12-5.10
# 交互式 shell
ddk shell --target android12-5.10如果你不想在每次命令中传入 target,可以设置环境变量 DDK_TARGET:
export DDK_TARGET=android12-5.10
ddk build # 会使用 DDK_TARGET参考下面的文件构建:
- 通用 Matrix 构建模板:ddk-lkm.yml
- Module Template 构建:module.yml