Watch a memory location/install 'data breakpoint' from code?

前端 未结 5 1068
迷失自我
迷失自我 2020-12-21 04:37

We have a memory overwrite problem. At some point, during the course of our program, a memory location is being overwritten and causing our program to crash. the problem hap

相关标签:
5条回答
  • 2020-12-21 04:53

    assuming you're using windows use windbg to debug your program and check out the ba command-this will break when the memory is accessed.

    0 讨论(0)
  • 2020-12-21 04:54

    You can still generate debug symbols for a "release" piece of code. This can still be run through a debugger just like you would in "debug" mode.

    I recently did something similiar with one of our release drivers so that we could run it through vtune. For the Microsfot LINK, I added the -DEBUG flag, for Microsoft CC I added -Zi. Everything works fine. MSKB link

    You might find this link useful.

    0 讨论(0)
  • 2020-12-21 05:09

    If you can control the location of the variable then you can allocate it on a dedicated page and set the permissions of the page to allow reads only using VirtualProtect (on Windows ... not sure for Linux).

    This way you will get an access violation when someone tries to write to it. With an exception translator function you could treat this as a callback.

    Even if you can't move the variable directly (eg. it is a class member), maybe you could add sufficient padding around the variable to ensure it is on a dedicated page and use the same approach.

    0 讨论(0)
  • 2020-12-21 05:11

    Debugging APIs are platform-specific, but they do exist. Windows and UNIX APIs can be found online.

    0 讨论(0)
  • 2020-12-21 05:17

    There are tools for this - like heap agent and boundschecker and many others that will discover overwrites. Basically you need some sentinels at the end of your memory allocations and they need to be checked.

    0 讨论(0)
提交回复
热议问题