Debugger.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. #pragma once
  2. #include "DebugCommon.h"
  3. #include "Compiler/MemReporter.h"
  4. #include "BeefySysLib/util/HashSet.h"
  5. #include <vector>
  6. NS_BF_BEGIN
  7. class DebugManager;
  8. class BfAutoComplete;
  9. enum DbgHitCountBreakKind : int8
  10. {
  11. DbgHitCountBreakKind_None,
  12. DbgHitCountBreakKind_Equals,
  13. DbgHitCountBreakKind_GreaterEquals,
  14. DbgHitCountBreakKind_Multiple
  15. };
  16. class Breakpoint
  17. {
  18. public:
  19. String mFilePath;
  20. int mRequestedLineNum;
  21. int mLineNum;
  22. int mColumn;
  23. int mInstrOffset;
  24. int mPendingHotBindIdx;
  25. int mHitCount;
  26. int mTargetHitCount;
  27. DbgHitCountBreakKind mHitCountBreakKind;
  28. String mLogging;
  29. bool mBreakAfterLogging;
  30. intptr mThreadId;
  31. String mSymbolName;
  32. Breakpoint* mHead;
  33. Breakpoint* mLinkedSibling; // For things like templates with multiple imps on same source line
  34. bool mIsLinkedSibling; // Not in breakpoint list
  35. public:
  36. Breakpoint()
  37. {
  38. mRequestedLineNum = -1;
  39. mLineNum = -1;
  40. mColumn = -1;
  41. mInstrOffset = 0;
  42. mPendingHotBindIdx = -1;
  43. mHitCount = 0;
  44. mTargetHitCount = 0;
  45. mHitCountBreakKind = DbgHitCountBreakKind_None;
  46. mThreadId = -1;
  47. mHead = NULL;
  48. mLinkedSibling = NULL;
  49. mIsLinkedSibling = false;
  50. mBreakAfterLogging = false;
  51. }
  52. virtual uintptr GetAddr() = 0;
  53. virtual bool IsMemoryBreakpointBound() = 0;
  54. };
  55. enum DwDisplayType : int8
  56. {
  57. DwDisplayType_NotSpecified,
  58. DwDisplayType_Decimal,
  59. DwDisplayType_HexLower,
  60. DwDisplayType_HexUpper,
  61. DwDisplayType_Char,
  62. DwDisplayType_Ascii,
  63. DwDisplayType_Utf8,
  64. DwDisplayType_Utf16,
  65. DwDisplayType_Utf32,
  66. };
  67. enum DwIntDisplayType : int8
  68. {
  69. DwIntDisplayType_Default,
  70. DwIntDisplayType_Decimal,
  71. DwIntDisplayType_HexadecimalUpper,
  72. DwIntDisplayType_Binary,
  73. DwIntDisplayType_Octal,
  74. DwIntDisplayType_HexadecimalLower,
  75. };
  76. enum DwMmDisplayType : int8
  77. {
  78. DwMmDisplayType_Default,
  79. DwMmDisplayType_Byte,
  80. DwMmDisplayType_Short,
  81. DwMmDisplayType_Int,
  82. DwMmDisplayType_Long,
  83. DwMmDisplayType_Float,
  84. DwMmDisplayType_Double
  85. };
  86. enum DwEvalExpressionFlags : int16
  87. {
  88. DwEvalExpressionFlag_None = 0,
  89. DwEvalExpressionFlag_FullPrecision = 0x01,
  90. DwEvalExpressionFlag_ValidateOnly = 0x02,
  91. DwEvalExpressionFlag_DeselectCallStackIdx = 0x04,
  92. DwEvalExpressionFlag_AllowSideEffects = 0x08,
  93. DwEvalExpressionFlag_AllowCalls = 0x10,
  94. DwEvalExpressionFlag_MemoryAddress = 0x20,
  95. DwEvalExpressionFlag_MemoryWatch = 0x40,
  96. DwEvalExpressionFlag_Symbol = 0x80,
  97. DwEvalExpressionFlag_StepIntoCalls = 0x100,
  98. };
  99. struct DwDisplayInfo
  100. {
  101. DwIntDisplayType mIntDisplayType;
  102. DwMmDisplayType mMmDisplayType;
  103. DwDisplayInfo()
  104. {
  105. mIntDisplayType = DwIntDisplayType_Default;
  106. mMmDisplayType = DwMmDisplayType_Default;
  107. }
  108. };
  109. enum RunState
  110. {
  111. RunState_NotStarted,
  112. RunState_Running,
  113. RunState_Running_ToTempBreakpoint,
  114. RunState_Paused,
  115. RunState_Breakpoint,
  116. RunState_DebugEval,
  117. RunState_DebugEval_Done,
  118. RunState_HotStep,
  119. RunState_Exception,
  120. RunState_Terminating,
  121. RunState_Terminated,
  122. RunState_SearchingSymSrv,
  123. RunState_HotResolve
  124. };
  125. enum DebuggerResult
  126. {
  127. DebuggerResult_Ok,
  128. DebuggerResult_UnknownError,
  129. DebuggerResult_CannotOpen,
  130. DebuggerResult_WrongBitSize,
  131. };
  132. enum BfDbgAttachFlags : uint8
  133. {
  134. BfDbgAttachFlag_None = 0,
  135. BfDbgAttachFlag_ShutdownOnExit = 1
  136. };
  137. enum BfSymSrvFlags : uint8
  138. {
  139. BfSymSrvFlag_None = 0,
  140. BfSymSrvFlag_Disable = 1,
  141. BfSymSrvFlag_TempCache = 2, // For testing - set up clean temporary cache
  142. };
  143. enum DbgHotResolveFlags : uint8
  144. {
  145. DbgHotResolveFlag_None = 0,
  146. DbgHotResolveFlag_ActiveMethods = 1,
  147. DbgHotResolveFlag_Allocations = 2,
  148. };
  149. enum DbgMemoryFlags : uint8
  150. {
  151. DbgMemoryFlags_None = 0,
  152. DbgMemoryFlags_Read = 1,
  153. DbgMemoryFlags_Write = 2,
  154. DbgMemoryFlags_Execute = 4
  155. };
  156. class DbgModuleMemoryCache
  157. {
  158. public:
  159. public:
  160. uintptr mAddr;
  161. int mSize;
  162. int mBlockSize;
  163. uint8** mBlocks;
  164. DbgMemoryFlags* mFlags;
  165. int mBlockCount;
  166. bool mOwns;
  167. public:
  168. DbgModuleMemoryCache(uintptr addr, int size);
  169. //DbgModuleMemoryCache(uintptr addr, uint8* data, int size, bool makeCopy);
  170. ~DbgModuleMemoryCache();
  171. DbgMemoryFlags Read(uintptr addr, uint8* data, int size);
  172. void ReportMemory(MemReporter* memReporter);
  173. };
  174. class DbgHotResolveData
  175. {
  176. public:
  177. Array<uint8> mTypeData;
  178. Beefy::HashSet<String> mBeefCallStackEntries;
  179. };
  180. class Profiler;
  181. class Debugger
  182. {
  183. public:
  184. DebugManager* mDebugManager;
  185. RunState mRunState;
  186. DbgHotResolveData* mHotResolveData;
  187. bool mHadImageFindError;
  188. public:
  189. Debugger()
  190. {
  191. mDebugManager = NULL;
  192. mRunState = RunState_NotStarted;
  193. mHotResolveData = NULL;
  194. mHadImageFindError = false;
  195. }
  196. virtual ~Debugger() { delete mHotResolveData; }
  197. virtual void OutputMessage(const StringImpl& msg) = 0;
  198. virtual void OutputRawMessage(const StringImpl& msg) = 0;
  199. virtual int GetAddrSize() = 0;
  200. virtual bool CanOpen(const StringImpl& fileName, DebuggerResult* outResult) = 0;
  201. virtual void OpenFile(const StringImpl& fileName, const StringImpl& args, const StringImpl& workingDir, const Array<uint8>& envBlock) = 0;
  202. virtual bool Attach(int processId, BfDbgAttachFlags attachFlags) = 0;
  203. virtual void Run() = 0;
  204. virtual void HotLoad(const Array<String>& objectFiles, int hotIdx) = 0;
  205. virtual void InitiateHotResolve(DbgHotResolveFlags flags) = 0;
  206. virtual void Update() = 0;
  207. virtual void ContinueDebugEvent() = 0;
  208. virtual void ForegroundTarget() = 0;
  209. virtual Breakpoint* CreateBreakpoint(const StringImpl& fileName, int lineNum, int wantColumn, int instrOffset) = 0;
  210. virtual Breakpoint* CreateMemoryBreakpoint(intptr addr, int byteCount) = 0;
  211. virtual Breakpoint* CreateSymbolBreakpoint(const StringImpl& symbolName) = 0;
  212. virtual Breakpoint* CreateAddressBreakpoint(intptr address) = 0;
  213. virtual void CheckBreakpoint(Breakpoint* breakpoint) = 0;
  214. virtual void HotBindBreakpoint(Breakpoint* wdBreakpoint, int lineNum, int hotIdx) = 0;
  215. virtual void DeleteBreakpoint(Breakpoint* wdBreakpoint) = 0;
  216. virtual void DetachBreakpoint(Breakpoint* wdBreakpoint) = 0;
  217. virtual void MoveBreakpoint(Breakpoint* wdBreakpoint, int lineNum, int wantColumn, bool rebindNow) = 0;
  218. virtual void MoveMemoryBreakpoint(Breakpoint* wdBreakpoint, intptr addr, int byteCount) = 0;
  219. virtual void DisableBreakpoint(Breakpoint* wdBreakpoint) = 0;
  220. virtual void SetBreakpointCondition(Breakpoint* wdBreakpoint, const StringImpl& condition) = 0;
  221. virtual void SetBreakpointLogging(Breakpoint* wdBreakpoint, const StringImpl& logging, bool breakAfterLogging) = 0;
  222. virtual Breakpoint* FindBreakpointAt(intptr address) = 0;
  223. virtual Breakpoint* GetActiveBreakpoint() = 0;
  224. virtual void BreakAll() = 0;
  225. virtual bool TryRunContinue() = 0;
  226. virtual void StepInto(bool inAssembly) = 0;
  227. virtual void StepIntoSpecific(intptr addr) = 0;
  228. virtual void StepOver(bool inAssembly) = 0;
  229. virtual void StepOut(bool inAssembly) = 0;
  230. virtual void SetNextStatement(bool inAssembly, const StringImpl& fileName, int64 lineNumOrAsmAddr, int wantColumn) = 0;
  231. //virtual DbgTypedValue GetRegister(const StringImpl& regName, CPURegisters* registers, Array<RegForm>* regForms = NULL) = 0;
  232. virtual String Evaluate(const StringImpl& expr, int callStackIdx, int cursorPos, int language, DwEvalExpressionFlags expressionFlags) = 0;
  233. virtual String EvaluateContinue() = 0;
  234. virtual void EvaluateContinueKeep() = 0;
  235. virtual String EvaluateToAddress(const StringImpl& expr, int callStackIdx, int cursorPos) = 0;
  236. virtual String EvaluateAtAddress(const StringImpl& expr, intptr atAddr, int cursorPos) = 0;
  237. virtual String GetCollectionContinuation(const StringImpl& continuationData, int callStackIdx, int count) = 0;
  238. virtual String GetAutoExpressions(int callStackIdx, uint64 memoryRangeStart, uint64 memoryRangeLen) = 0;
  239. virtual String GetAutoLocals(int callStackIdx, bool showRegs) = 0;
  240. virtual String CompactChildExpression(const StringImpl& expr, const StringImpl& parentExpr, int callStackIdx) = 0;
  241. virtual String GetThreadInfo() = 0;
  242. virtual void SetActiveThread(int threadId) = 0;
  243. virtual int GetActiveThread() = 0;
  244. virtual void FreezeThread(int threadId) = 0;
  245. virtual void ThawThread(int threadId) = 0;
  246. virtual bool IsActiveThreadWaiting() = 0;
  247. virtual void ClearCallStack() = 0;
  248. virtual void UpdateCallStack(bool slowEarlyOut = true) = 0;
  249. virtual int GetCallStackCount() = 0;
  250. virtual int GetRequestedStackFrameIdx() = 0;
  251. virtual int GetBreakStackFrameIdx() = 0;
  252. virtual bool ReadMemory(intptr address, uint64 length, void* dest, bool local = false) = 0;
  253. virtual bool WriteMemory(intptr address, void* src, uint64 length) = 0;
  254. virtual DbgMemoryFlags GetMemoryFlags(intptr address) = 0;
  255. virtual void UpdateRegisterUsage(int stackFrameIdx) = 0;
  256. virtual void UpdateCallStackMethod(int stackFrameIdx) = 0;
  257. virtual void GetCodeAddrInfo(intptr addr, String* outFile, int* outHotIdx, int* outDefLineStart, int* outDefLineEnd, int* outLine, int* outColumn) = 0;
  258. virtual void GetStackAllocInfo(intptr addr, int* outThreadId, int* outStackIdx) = 0;
  259. virtual String GetStackFrameInfo(int stackFrameIdx, intptr* addr, String* outFile, int32* outHotIdx, int32* outDefLineStart, int32* outDefLineEnd, int32* outLine, int32* outColumn, int32* outLanguage, int32* outStackSize, int8* outFlags) = 0;
  260. virtual String Callstack_GetStackFrameOldFileInfo(int stackFrameIdx) = 0;
  261. virtual int GetJmpState(int stackFrameIdx) = 0;
  262. virtual intptr GetStackFrameCalleeAddr(int stackFrameIdx) = 0;
  263. virtual String GetStackMethodOwner(int stackFrameIdx, int& language) = 0;
  264. virtual String FindCodeAddresses(const StringImpl& fileName, int line, int column, bool allowAutoResolve) = 0;
  265. virtual String GetAddressSourceLocation(intptr address) = 0;
  266. virtual String GetAddressSymbolName(intptr address, bool demangle) = 0;
  267. virtual String DisassembleAtRaw(intptr address) = 0;
  268. virtual String DisassembleAt(intptr address) = 0;
  269. virtual String FindLineCallAddresses(intptr address) = 0;
  270. virtual String GetCurrentException() = 0;
  271. virtual String GetModulesInfo() = 0;
  272. virtual void SetAliasPath(const StringImpl& origPath, const StringImpl& localPath) = 0;
  273. virtual void CancelSymSrv() = 0;
  274. virtual bool HasPendingDebugLoads() = 0;
  275. virtual int LoadDebugInfoForModule(const StringImpl& moduleName) = 0;
  276. virtual int LoadDebugInfoForModule(const StringImpl& moduleName, const StringImpl& debugFileName) = 0;
  277. virtual void StopDebugging() = 0;
  278. virtual void Terminate() = 0;
  279. virtual void Detach() = 0;
  280. virtual Profiler* StartProfiling() = 0;
  281. virtual Profiler* PopProfiler() = 0; // Profiler requested by target program
  282. virtual void ReportMemory(MemReporter* memReporter) = 0;
  283. virtual bool IsOnDemandDebugger() = 0;
  284. };
  285. class Profiler
  286. {
  287. public:
  288. String mDescription;
  289. int mSamplesPerSecond;
  290. intptr mTargetThreadId;
  291. public:
  292. Profiler()
  293. {
  294. mSamplesPerSecond = -1;
  295. mTargetThreadId = 0;
  296. }
  297. virtual ~Profiler() {}
  298. virtual void Start() = 0;
  299. virtual void Stop() = 0;
  300. virtual void Clear() = 0;
  301. virtual bool IsSampling() = 0;
  302. virtual String GetOverview() = 0;
  303. virtual String GetThreadList() = 0;
  304. virtual String GetCallTree(int threadId, bool reverse) = 0;
  305. };
  306. NS_BF_END