编写自己的 "mixed mode" 调试器时如何与 Visual Studio 本机调试器交互?
How do I interact with Visual Studios native debugger when writing my own "mixed mode" debugger?
过去几天我一直在搜索 google、博客和 MSDN,寻找关于如何在 [=36] 中实现 "interop" 或 "mixed mode" 调试的任何小信息=].
我正在尝试为自定义 VM 实现我自己的调试器(实际上,它被 JIT 编译为本机代码,这意味着我必须在正常本机调试器进入 JIT- ed 代码),但我找不到任何关于如何实际与 VS 的本机调试器交互并执行花式 "native/managed" 的信息,例如 VS 的混合模式调试所实现的转换。
到目前为止,我发现了一些提供有用花絮的东西,但不足以与调试器实际交互。我找到的最好、最有用的文章是:
- Mike Stall 的各种博客文章(主要是 these two)虽然提供了有用的信息和对内部工作原理的一瞥,但它们似乎与 .Net 调试密切相关。
- MSDN 的 Creating a Basic Debugger 很好地概述了 MS 如何实现其调试器以及如何在同一技术堆栈上实现调试器。不幸的是,这并没有真正提供任何关于如何将数据传递给 VS 的本机调试器的真实信息。 (结合 Mike Stall 的博客,似乎两个调试器都在等待相同的事件,那么您实际上如何以有意义的方式将结果拼接在一起?)
- Debugger Engine API(又名 DbgEng)文档。我通过 运行 Dependency Walker 在 VS 的本机调试引擎上找到了这个(NatDbgDE.dll,它似乎导出了我只能在本文档中找到的 DebugCreate 函数,因此它可能是相关的)。不幸的是,我什至通过它进行任何调试都收效甚微,而且似乎没有很好的记录,尽管文档似乎确实表明这是我最终可能想要处理的。它也没有真正说明我如何与另一个调试器协同工作,也没有提到 VS 的调试器,所以无论如何我可能会完全走错路。
如何开始编写可与 VS 的本机调试器协同工作的调试器?
谢谢!
恐怕没有太多关于这个主题的文档。你提到的资源在这一点上都已经很老了。我的建议是与 Visual Studio 的较新调试引擎 (Concord) 集成。从 Visual Studio 2012 年开始,Concord 用作本机调试的调试引擎,并用于 Visual Studio 2013 年以后的所有调试。 Concord 的设计目标之一是简化混合模式调试。它还被设计为易于扩展。
我创建了一些 Concord extensibility documentation that may be of help. It is mainly focused on expression evaluators, but it has some good information for getting started with Concord. Another resource that may be of use is the source code for the Concord-based debugger in Python Tools for Visual Studio。这是与 Concord 集成并允许使用 Python.
进行混合模式调试的混合模式调试器的完整实现
过去几天我一直在搜索 google、博客和 MSDN,寻找关于如何在 [=36] 中实现 "interop" 或 "mixed mode" 调试的任何小信息=].
我正在尝试为自定义 VM 实现我自己的调试器(实际上,它被 JIT 编译为本机代码,这意味着我必须在正常本机调试器进入 JIT- ed 代码),但我找不到任何关于如何实际与 VS 的本机调试器交互并执行花式 "native/managed" 的信息,例如 VS 的混合模式调试所实现的转换。
到目前为止,我发现了一些提供有用花絮的东西,但不足以与调试器实际交互。我找到的最好、最有用的文章是:
- Mike Stall 的各种博客文章(主要是 these two)虽然提供了有用的信息和对内部工作原理的一瞥,但它们似乎与 .Net 调试密切相关。
- MSDN 的 Creating a Basic Debugger 很好地概述了 MS 如何实现其调试器以及如何在同一技术堆栈上实现调试器。不幸的是,这并没有真正提供任何关于如何将数据传递给 VS 的本机调试器的真实信息。 (结合 Mike Stall 的博客,似乎两个调试器都在等待相同的事件,那么您实际上如何以有意义的方式将结果拼接在一起?)
- Debugger Engine API(又名 DbgEng)文档。我通过 运行 Dependency Walker 在 VS 的本机调试引擎上找到了这个(NatDbgDE.dll,它似乎导出了我只能在本文档中找到的 DebugCreate 函数,因此它可能是相关的)。不幸的是,我什至通过它进行任何调试都收效甚微,而且似乎没有很好的记录,尽管文档似乎确实表明这是我最终可能想要处理的。它也没有真正说明我如何与另一个调试器协同工作,也没有提到 VS 的调试器,所以无论如何我可能会完全走错路。
如何开始编写可与 VS 的本机调试器协同工作的调试器?
谢谢!
恐怕没有太多关于这个主题的文档。你提到的资源在这一点上都已经很老了。我的建议是与 Visual Studio 的较新调试引擎 (Concord) 集成。从 Visual Studio 2012 年开始,Concord 用作本机调试的调试引擎,并用于 Visual Studio 2013 年以后的所有调试。 Concord 的设计目标之一是简化混合模式调试。它还被设计为易于扩展。
我创建了一些 Concord extensibility documentation that may be of help. It is mainly focused on expression evaluators, but it has some good information for getting started with Concord. Another resource that may be of use is the source code for the Concord-based debugger in Python Tools for Visual Studio。这是与 Concord 集成并允许使用 Python.
进行混合模式调试的混合模式调试器的完整实现