Valgrind Clion

Posted onby admin

In this video, I show you how to install and setup CLion so that you can successfully begin to code in C and C. We install MinGW to allow CLion to compile.

CLion has a Valgrind integration[1] offering a convenient way to analyse your program with Valgrind and also a nice interface to easily inspect the results.

However, sometimes it’s hard to spot the source of your problem only by looking at Valgrind reports: Ok, I’m accessing a Dangling pointer on this method. But, what instance of my class is actually causing the problem? If only I could set a breakpoint where the invalid read happens….

Fortunately, it’s possible to debug a program running under Valgrind[2]. The bad news is that CLion does not support this feature out of the box. But don’t worry, it’s not hard to properly configure CLion to be able to do this.

Sudo apt-get install valgrind 配置 CLion. 安装成功后,配置 Valgrind 路径. 在 clion 下编译可执行文件,编译成功后,点击下图红框 等待程序运行结束,在 Run 面板中点击 Valgrind,即可查看结果: 参考资料. Valgrind Memcheck; valgrind-macos. Some developers names Deleaker “a Valgrind for Visual Studio”. Indeed, you may consider Deleaker as an alternative for Valgrind that works on Windows and integrates with all major development environments including Visual Studio, C Builder, Qt Creator, and CLion. I will try with the screenshot of CLion maybe, where I run valgrind. Jendker ( 2018-09-26 11:41:24 -0500 ) edit I was trying OpenCV master right now, but there are so many changes in the flags, that it is difficult to compile my program. Getting Valgrind to Work with CLion on Windows 10 Ubuntu WSL I couldn't find this anywhere, and I finally figured it out after hours of tinkering. To whatever lost soul is trying to get this to work like I.

In this post I’ll show you how you can configure the CLion debugger to debug a program running under Valgrind. Only a few steps are required.


Configure Valgrind on CLion[1]

To be able to use Valgrind with CLion we first need to install it:

Now we need to configure CLion to launch Valgrind in vgdb mode. In vgdb mode, Valgrind will start a gdbserver debugging our program under Valgrind.

Open CLion settings and navigate to Build, Execution, Deployment > Dynamic Analysis Tools > Valgrind.

Append the following options to the existing Analysis options:

--vgdb=yes enables the Valgrind gdbserver. --vgdb-error=0 tells Valgrind to pause the debugging session so we have time to launch a remote gdb session as described below.

Create a CLion configuration to debug the Valgrind gdbserver[3]

We need to create a CLion debug configuration to connect to the gdbserver that Valgrind will create.

Go to Run > Edit Configurations…

Create a new GDB Remote Debug configuration.

Name the configuration something like Valgrind gdb

On the ‘target remote’ args field write /usr/bin/vgdb. The pipe character is important[2][4].

Debugging your program under Valgrind

Now you are ready to debug your program under Valgrind.

Select the configuration of the program you want to debug and run it with Valgrind memcheck.

Valgrind now waits for a debugger to connect before starting your program.

Without stopping the valgrind process, select the GDB Remote Debug you created and run it in debug mode.

Now Valgrind will detect that a debugger has connected and it will start your program. On the Run tab you can see the output of the program under analysis. You’ll see there the Valgrind report once the program stops.

Valgrind Executable Not Found Clion

Valgrind ClionValgrind

On the Debug tab you have your usual debug controls.

Clion Valgrind Wsl

Valgrind will raise a trap signal (SIGTRAP) when it detects a problem. You can then inspect the stack trace, and your usual debugging commands. You can also unleash the power of Valgrind by sending commands to it through CLion’s gdb console[5].


Clion Valgrind Permission Denied

CLion won’t display the output of monitor commands sent to Valgrind’s gdbserver.


Regular Valgrind analysis

We just configured Valgrind to wait for a gdb debugger before starting your program. If you want to run a regular Valgrind analysis without the debugger, you’ll need to edit the CLion Valgrind configuration again and set the vgdb option back to no: --vgdb=no.

Remote communication error

You might encounter the following error when debugging with the GDB Remote Debug configuration:

Valgrind Clion

Usually the problem is that there are more than one instances of Valgrind running and CLion does not know which one it should connect to.

The easiest solution is to stop all CLion processes, use your operating system task manager to kill any running instances of Valgrind and try again. On an x64 linux computer the process will be named memcheck-amd64-.

If you really need to have several instances of Valgrind running at the same time, you can instruct CLion to connect to a particular one by editing the GDB Remote Debug configuration and appending the pid to the ‘target remote’ args command like this:

Note that you will need to edit your configuration and change the pid number every time.

For your convenience, Valgrind prints is pid on the console when started in vgdb mode.


  1. CLion Valgrind memcheck(
  2. Debugging your program using Valgrind gdbserver and GDB(
  3. CLion GDB Remote Debug(
  4. Connecting to a Remote Target(
  5. Valgrind and GDB: Tame the Wild C(