keybindings.json: 键盘快捷方式 json 文件。
setting.json: vscode 设置文件。

块选择:shift+箭头 / shift+Alt+鼠标

增加光标:Ctrl+Alt+上/下箭头 / Alt+click

复制一行:Shift+Alt+上/下箭头

移动一行:Alt+箭头

删除一行:Ctrl+Shift+K

F2 可以代码重构,对 project 下所有的函数名替换名称

格式化文档:Shift+Alt+F 格式化整个文档 / Ctrl+K → Ctrl+F 格式化某一行

Ctrl+Shift+[ / Ctrl+Shift+] 折叠函数

alt + <n> 切换标签页

自定义的一些快捷键

在 vscode 键盘快捷方式中自定义的一些快捷键:

alt + ↑/↓:调整终端大小。

Clangd 插件

配置 .clang-format

配置 compile_commands.json

clangd 默认会在 project 目录下寻找compile_commands.json,如果compile_commands.json在 project 目录之外,那么需要通过在settings.json中指定clangd.arguments->--compile-commands-dir=xxxcompile_commands.json的位置。

settings.json:

{
  "[c]": {
    "editor.defaultFormatter": "llvm-vs-code-extensions.vscode-clangd"
  },
  "[cpp]": {
    "editor.defaultFormatter": "llvm-vs-code-extensions.vscode-clangd"
  },
  "clangd.arguments": [
    "--log=error",
    "--header-insertion=never", // 是否需要自动插入头文件
    "--compile-commands-dir=../../../../out/rts3916_evb_nand"
  ],
  "editor.inlayHints.enabled": "offUnlessPressed",
  "C_Cpp.intelliSenseEngine": "disabled"
}

生成compile_commands.json有几种方法,1. bear, 2. compiledb, 3. cmake

bear -- make <xxx>

compile_commands.json中arguments的第一个编译器路径需要替换吗?

配置.clangd

用来配置 clangd 参数。

CompileFlags:
  Add: --target=mips # 需要修改为我们实际编译的架构, mips/arm/riscv32...
  Remove: # 这边应该是需要去掉的编译参数, 只是用来防止头文件报错
    [
      -march=rv32imac_zicsr_zifencei,
      -fno-allow-store-data-races,
      -fconserve-stack,
    ]

VSCode 调试

Run->Add Configuration 创建 launch.json。

launch.json

	"version": "0.2.0",
	"configurations": [
		{
			"name": "(gdb) Launch",
			"type": "cppdbg",
			"request": "launch", // 指明当前程序是launch还是attach
			"program": "${workspaceFolder}/ctarget", // 要调试的可执行文件
			"args": [], // 传入给程序的参数e.g. ["arg1", "arg2"]
			"stopAtEntry": false, // 停在main入口?
			"cwd": "${fileDirname}", // 设置当前工作目录
			"environment": [], // 环境变量e.g. [{ "name": "xxx", "value": "yyy" }]
			"externalConsole": false,
			"MIMode": "gdb", // gdb or lldb
			"preLaunchTask": "attack_phase3", // 调试开始前需要运行的task
			"postDebugTask": "", // 调试结束后需要运行的task
			"setupCommands": [ // 启动gdb/lldb的参数
			    {
				"description": "Enable pretty-printing for gdb",
				"text": "-enable-pretty-printing",
				"ignoreFailures": true
			    },
			]
		}
	]

比如调试 csapp 的 ctarget

	"version": "0.2.0",
	"configurations": [
		{
			"name": "(gdb) Launch",
			"type": "cppdbg",
			"request": "launch",
			"program": "${workspaceFolder}/attack_lab/ctarget",
			"args": ["-q", "<", "phase3-raw.txt"],
			"stopAtEntry": false,
			"cwd": "${workspaceFolder}/attack_lab/",
			"environment": [
				{
					"name": "LD_PRELOAD",
					"value": "${workspaceFolder}/attack_lab/printf.so"
				}
			],
			"externalConsole": false,
			"MIMode": "gdb",
			"preLaunchTask": "attack_phase3",
			"postDebugTask": "",
			"setupCommands": [
			    {
				"description": "Enable pretty-printing for gdb",
				"text": "-enable-pretty-printing",
				"ignoreFailures": true
			    },
			]
		}

	]

注意要设置cwdcurrent work directory, 默认的${fileDirname}会找不到phase3-raw.txt

step over: nexti
step into: stepi
step out: finish

task.json

可以在 launch.jason 中指定 preLaunchTask 或者 postDebugTask,对应 task.jason 中 tasks 的 label。

{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "task1",
      "type": "shell",
      "command": "touch 1.c"
    },
    {
      "label": "task2",
      "type": "shell",
      "command": "touch 2.c"
    },
    {
      "label": "attack_phase3",
      "dependsOn": ["task1", "task2"],
      "type": "shell"
    }
  ]
}

Others

watch 内存地址的数据,以 16 进制打印(加上,h)

或者也可以直接执行 gdb 命令-exec x/16x 0x5561dc78