找回密码
 立即注册
首页 业界区 业界 搭建阅读linux源码的舒适环境(vscode+clangd) ...

搭建阅读linux源码的舒适环境(vscode+clangd)

吉娅寿 2025-6-3 00:09:40
准备linux源码

linux官网下载源码压缩包

https://www.kernel.org/
1.png

解压

由于源码是经过两次压缩的,所以需要解压两次
  1. xz -d linux-6.14.7.tar.xz
复制代码
  1. tar xvf linux-6.14.7.tar
复制代码
编译内核

生成.config文件

假设是需要生成x86_64下的架构下的编译框架
  1. cd ~/code/linux/linux-6.14.7/
  2. make ARCH=x86_64 defconfig
复制代码
  1. sinizu@sinizu-GP65-Leopard-9SD ~/c/l/linux-6.14.7 [1]> make ARCH=x86_64 defconfig                                                                                                      (base)
  2.   HOSTCC  scripts/basic/fixdep
  3.   HOSTCC  scripts/kconfig/conf.o
  4.   HOSTCC  scripts/kconfig/confdata.o
  5.   HOSTCC  scripts/kconfig/expr.o
  6.   LEX     scripts/kconfig/lexer.lex.c
  7.   YACC    scripts/kconfig/parser.tab.[ch]
  8.   HOSTCC  scripts/kconfig/lexer.lex.o
  9.   HOSTCC  scripts/kconfig/menu.o
  10.   HOSTCC  scripts/kconfig/parser.tab.o
  11.   HOSTCC  scripts/kconfig/preprocess.o
  12.   HOSTCC  scripts/kconfig/symbol.o
  13.   HOSTCC  scripts/kconfig/util.o
  14.   HOSTLD  scripts/kconfig/conf
  15. *** Default configuration is based on 'x86_64_defconfig'
  16. #
  17. # configuration written to .config
  18. #
复制代码
查看.config文件,实际上就是内核的配置,是否要开启某些功能,这里咱们已经选择了默认的配置,如下所示
  1. sinizu@sinizu-GP65-Leopard-9SD ~/c/l/linux-6.14.7> cat .config                                                                                                                         (base)
  2. #
  3. # Automatically generated file; DO NOT EDIT.
  4. # Linux/x86_64 6.14.7 Kernel Configuration
  5. #
  6. CONFIG_CC_VERSION_TEXT="gcc (Ubuntu 13.3.0-6ubuntu2~24.04) 13.3.0"
  7. CONFIG_CC_IS_GCC=y
  8. CONFIG_GCC_VERSION=130300
  9. CONFIG_CLANG_VERSION=0
  10. CONFIG_AS_IS_GNU=y
  11. CONFIG_AS_VERSION=24200
  12. CONFIG_LD_IS_BFD=y
  13. CONFIG_LD_VERSION=24200
  14. CONFIG_LLD_VERSION=0
  15. CONFIG_RUSTC_VERSION=108600
  16. CONFIG_RUSTC_LLVM_VERSION=190107
  17. CONFIG_CC_CAN_LINK=y
  18. CONFIG_CC_CAN_LINK_STATIC=y
  19. CONFIG_CC_HAS_ASM_GOTO_OUTPUT=y
  20. CONFIG_CC_HAS_ASM_GOTO_TIED_OUTPUT=y
  21. CONFIG_TOOLS_SUPPORT_RELR=y
  22. CONFIG_CC_HAS_ASM_INLINE=y
  23. CONFIG_CC_HAS_NO_PROFILE_FN_ATTR=y
  24. CONFIG_LD_CAN_USE_KEEP_IN_OVERLAY=y
  25. CONFIG_RUSTC_HAS_COERCE_POINTEE=y
  26. CONFIG_PAHOLE_VERSION=0
  27. CONFIG_IRQ_WORK=y
  28. CONFIG_BUILDTIME_TABLE_SORT=y
  29. CONFIG_THREAD_INFO_IN_TASK=y
复制代码
开始编译

由于内核项目中make工程已经提供了生成compile_commands.json文件的配置,所以可以直接使用,只需指定框架即可
  1. make ARCH=x86_64 compile_commands.json                                                                                             
复制代码
  1. sinizu@sinizu-GP65-Leopard-9SD ~/c/l/linux-6.14.7> make ARCH=x86_64 compile_commands.json                                                                                              (base)
  2.   SYSHDR  arch/x86/include/generated/uapi/asm/unistd_32.h
  3.   SYSHDR  arch/x86/include/generated/uapi/asm/unistd_64.h
  4.   SYSHDR  arch/x86/include/generated/uapi/asm/unistd_x32.h
  5.   SYSTBL  arch/x86/include/generated/asm/syscalls_32.h
  6.   SYSHDR  arch/x86/include/generated/asm/unistd_32_ia32.h
  7.   SYSHDR  arch/x86/include/generated/asm/unistd_64_x32.h
  8.   SYSTBL  arch/x86/include/generated/asm/syscalls_64.h
  9.   HOSTCC  arch/x86/tools/relocs_32.o
  10.   HOSTCC  arch/x86/tools/relocs_64.o
  11.   HOSTCC  arch/x86/tools/relocs_common.o
  12.   HOSTLD  arch/x86/tools/relocs
  13.   HOSTCC  scripts/selinux/mdp/mdp
  14.   HOSTCC  scripts/kallsyms
  15.   HOSTCC  scripts/sorttable
复制代码
检查是否生产compile_command.json
  1. ...
  2.   CC      arch/x86/pci/mmconfig_64.o
  3.   CC      arch/x86/pci/direct.o
  4.   CC      arch/x86/pci/mmconfig-shared.o
  5.   CC      arch/x86/pci/fixup.o
  6.   CC      arch/x86/pci/acpi.o
  7.   CC      arch/x86/pci/legacy.o
  8.   CC      arch/x86/pci/irq.o
  9.   CC      arch/x86/pci/common.o
  10.   CC      arch/x86/pci/early.o
  11.   CC      arch/x86/pci/bus_numa.o
  12.   CC      arch/x86/pci/amd_bus.o
  13.   AR      arch/x86/pci/built-in.a
  14.   CC      arch/x86/power/cpu.o
  15.   CC      arch/x86/power/hibernate_64.o
  16.   AS      arch/x86/power/hibernate_asm_64.o
  17.   CC      arch/x86/power/hibernate.o
  18.   AR      arch/x86/power/built-in.a
  19.   CC      arch/x86/video/video-common.o
  20.   AR      arch/x86/video/built-in.a
  21.   AR      built-in.a
  22.   AR      vmlinux.a
  23.   GEN     compile_commands.json
  24. sinizu@sinizu-GP65-Leopard-9SD ~/c/l/linux-6.14.7> ls -lh                                                                                                                              (base)
  25. 总计 8.4M
  26. drwxrwxr-x  23 sinizu sinizu 4.0K  5月 18 14:26 arch/
  27. drwxrwxr-x   3 sinizu sinizu 4.0K  5月 21 20:12 block/
  28. -rw-rw-r--   1 sinizu sinizu 238K  5月 21 20:27 built-in.a
  29. drwxrwxr-x   2 sinizu sinizu 4.0K  5月 21 20:07 certs/
  30. -rw-rw-r--   1 sinizu sinizu 6.8M  5月 21 20:27 compile_commands.json
  31. -rw-rw-r--   1 sinizu sinizu  496  5月 18 14:26 COPYING
  32. -rw-rw-r--   1 sinizu sinizu 104K  5月 18 14:26 CREDITS
复制代码
可见编译参数的json文件已经生成。
准备vscode环境

下载vscode

https://code.visualstudio.com/
按照官网下载软件,并进行安装,安装过程略
安装clangd插件

插件市场搜索clangd,直接进行安装即可
2.png

准备clangd

安装clangd

github下载最新版本的clangd
https://github.com/clangd/clangd/releases/tag/18.1.3
解压将clangd的可执行文件配置到vscode中

假设解压后,我的clangd位于如下路径
  1. /home/sinizu/clangd_18.1.3/bin/clangd
复制代码
打开vscode,按下shift+ctrl+p,选择用户配置,如下所示
3.png

接下来,将如下的配置行写到配置的json文件中
  1. "clangd.path": "/home/sinizu/clangd_18.1.3/bin/clangd",
复制代码
4.png

大功告成

将linux文件夹打开,随便打开一个文件,可以看到clangd正在索引
5.png

等待索引完毕,就可以直接ctrl+鼠标左键进行代码跳转了!
其他说明

可选择的内核配置


  • 自行配置内核参数(图像界面)
  1. make ARCH=x86_64 menuconfig  # 终端文本界面
  2. # 或
  3. make ARCH=x86_64 xconfig     # 图形界面(需安装 Qt)
复制代码

  • 和当前操作系统一样的配置
  1. cp /boot/config-$(uname -r) .config
复制代码
缺少工具安装

如果报错缺少工具(如 menuconfig),安装依赖:
  1. sudo apt-get install build-essential ncurses-dev libssl-dev  # Ubuntu/Debian
  2. # 或
  3. sudo dnf install ncurses-devel openssl-devel                 # Fedora
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册