未初始化的值是由库代码上的堆栈分配错误创建的

时间:2018-06-17 19:29:33

标签: c++ valgrind ioctl

您好我正在修复我的valgrind错误,它们是:

==11925== ERROR SUMMARY: 9 errors from 1 contexts (suppressed: 0 from 0)
==11925== 
==11925== 9 errors in context 1 of 1:
==11925== Syscall param ioctl(generic) points to uninitialised byte(s)
==11925==    at 0xF8B7F47: ioctl (syscall-template.S:84)
==11925==    by 0x1F770DAD: drmIoctl (in /opt/amdgpu/lib/x86_64-linux-gnu/libdrm.so.2.4.0)
==11925==    by 0x1F7756E8: drmCommandWriteRead (in /opt/amdgpu/lib/x86_64-linux-gnu/libdrm.so.2.4.0)
==11925==    by 0x3332C6AC: amdgpu_create_bo_from_user_mem (in /opt/amdgpu/lib/x86_64-linux-gnu/libdrm_amdgpu.so.1.0.0)
==11925==    by 0x32A479F2: ??? (in /usr/lib/x86_64-linux-gnu/gallium-pipe/pipe_radeonsi.so)
==11925==    by 0x32A6E6B3: ??? (in /usr/lib/x86_64-linux-gnu/gallium-pipe/pipe_radeonsi.so)
==11925==    by 0x2D8E8BD6: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==    by 0x2D8E05D4: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==    by 0x2D8DE2D4: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==    by 0x2D8DD2E7: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==    by 0x2D8DD940: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==    by 0x2D8D8875: ??? (in /usr/lib/x86_64-linux-gnu/libMesaOpenCL.so.1.0.0)
==11925==  Address 0xffeffed64 is on thread 1's stack
==11925==  in frame #3, created by amdgpu_create_bo_from_user_mem (???:)
==11925==  Uninitialised value was created by a stack allocation
==11925==    at 0x329770B0: ??? (in /usr/lib/x86_64-linux-gnu/gallium-pipe/pipe_radeonsi.so)

在我的程序中,我与错误代码中提到的文件无关。我已经阅读了很多关于这个问题的帖子,但就我而言,提到的代码行是甚至不在我的代码中(我想它在我使用的某个库中)。

我感谢任何帮助!

1 个答案:

答案 0 :(得分:4)

将未初始化的缓冲区传递给ioctl是很常见的。

在valgrind中甚至有一个选项可以忽略它们:

--sim-hints=lax-ioctls

请参阅文档http://valgrind.org/docs/manual/manual-core.html

  

lax-ioctls:对ioctl处理非常松懈;唯一的假设是尺寸是正确的。写入时不需要初始化完整缓冲区。如果没有这个,使用一些带有大量奇怪的ioctl命令的设备驱动程序变得非常烦人。

简而言之,您的错误(很可能)是误报。