VSCode使用clangd构建Linux驱动开发环境


前言

最初在使用Linux内核源码进行驱动开发时,由于没有代码补全、自动提示等功能写起来十分不方便,虽然有人使用Source Insight来阅读源码,但是我用起来还是感觉怪怪的,有时间同一个函数会找到很多的定义,不便判断。在调用层次方面,还是clangd更好用。


一、VSCode安装clangd插件并搭建环境

Clangd 是一个基于 Clang 的语言服务器,它提供了代码智能感知和导航功能。通过与 VSCode 集成,可以实现以下功能:

  • 代码补全和自动提示:Clangd 可以根据代码上下文提供准确的补全建议和自动提示,帮助开发者快速编写代码。
  • 代码跳转和导航:Clangd 可以识别代码中的符号引用、函数调用等,并支持跳转到定义、查看声明等操作,便于阅读和理解复杂的内核源代码。
  • 实时错误和警告检查:Clangd 可以实时检查代码中的语法错误、潜在问题和警告信息,帮助开发者及早发现和修复问题。
  • 重构支持:Clangd 提供了一些重构功能,如重命名变量、提取函数等,可以简化代码重构的过程。

1、安装插件

在这里插入图片描述

2、禁用或卸载Microsoft C/C++ Intelligence

因为和clangd有冲突,这种语法高亮的插件往往只能二者存其一。
在这里插入图片描述

3、安装clangd安装包

VSCode clangd插件本身是不能运行的,它还需要clangd的环境,所以接下来安装clangd。

下载地址
在Ubuntu中最好不要使用apt安装,因为版本比较旧,建议下载后手动安装。
在这里插入图片描述
解压后,
将bin文件夹下的 clangd 移动到 /usr/bin 目录下,
将lib文件夹下的所有移动到 /usr/local/lib 目录下。
之后打开终端,键入:

clangd --version

在这里插入图片描述
就算成功。

4、修改拓展设置

修改正确clangd路径:
在这里插入图片描述

二、使用bear构建源码的 compile_commands.json文件

如果没有bear的话就安装一下:

sudo apt install bear

我使用的是韦东山的imx6ull-qemu模拟开发板的内核源码,内核编译命令如下:

ml@ml-virtual-machine:~$ cd linux-4.9.88
ml@ml-virtual-machine:~$ make mrproper
ml@ml-virtual-machine:~$ make 100ask_imx6ull_qemu_defconfig
ml@ml-virtual-machine:~$ bear make zImage -j4 //编译zImage 内核
ml@ml-virtual-machine:~$ make clean  // 清除生成文件

倒数第二条带有bear的指令就是生成compile_commands.json文件的。

compile_commands.json文件记录了你的工程是如何构建的,使用到了哪些源码文件,源码文件之间的包含关系,引用路径之类的,这些可以帮助clangd构建符号关系索引库。
在这里插入图片描述
在这里插入图片描述

三、修改compile_commands.json文件

目前,这个文件还不能用,需要修改编译工具链成对应的工具链,比如我这里需要全局替换:

"cc"  -->  "arm-linux-gnueabihf-gcc"

在这里插入图片描述

保存后关闭VSCode,如果有.cache文件夹的话,删除掉它。之后重新用VSCode打开源码目录,随便打开一个.c文件,clangd便自动开始索引文件了,索引文件会保存在 .cache 目录下。
在这里插入图片描述

如果这个过程特别快,只有几秒钟的话,那就是上述步骤有错误。正常来说,这个索引过程会有几分钟。

在这里插入图片描述

四、驱动程序和应用程序的编写

对于驱动程序来说,我的方法是在当前源码目录下新建一个文件夹,在这个文件夹下进行驱动程序的编写,这样跳转、补全之类的都比较方便。
在这里插入图片描述

然后保存工作区,方便下次打开:
在这里插入图片描述

对应用程序来说,不便放在源码工作区当中,可以像这样单独打开一个用于编写应用程序:
keyi

驱动程序写完后,拷贝到应用程序所在目录的驱动程序文件中。
在这里插入图片描述

此后,便可以方便快捷的编写驱动程序和应用程序了。

五、配置文件的添加

clangd 是集成了 clang-tidy 和 clang-format 的,所以二者的配置文件也能在clangd下面使用。比如,我根据我的喜好更改了 format 格式和它的函数参数提示。
在这里插入图片描述

.clangd 文件

# 提示嵌入,不使用函数参数嵌入提示
InlayHints:
    Designators: Yes
    Enabled: Yes
    ParameterNames: No
    DeducedTypes: Yes

CompileFlags:
    Add: [-xc, -Wall]

.clang-format 文件

BasedOnStyle: LLVM
UseTab: Never
IndentWidth: 4
TabWidth: 4

# 最外层大括号换行
# BreakBeforeBraces: Linux

BreakBeforeBraces: Allman
AllowShortIfStatementsOnASingleLine: true
IndentCaseLabels: false
ColumnLimit: 120

六、其它(可选)

如果你已经配置完成,就不要在意这里的设置。

在这里插入图片描述

参考

使用VSCode clangd插件进行linux内核代码阅读和嵌入式开发

  • 5
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值