VirtualBox

source: vbox/trunk/src/VBox/Debugger/DBGCInternal.h@ 31635

Last change on this file since 31635 was 31530, checked in by vboxsync, 14 years ago

Debugger: Updated the file headers.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 15.0 KB
Line 
1/* $Id: DBGCInternal.h 31530 2010-08-10 12:24:45Z vboxsync $ */
2/** @file
3 * DBGC - Debugger Console, Internal Header File.
4 */
5
6/*
7 * Copyright (C) 2006-2010 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18
19#ifndef ___Debugger_DBGCInternal_h
20#define ___Debugger_DBGCInternal_h
21
22
23/*******************************************************************************
24* Header Files *
25*******************************************************************************/
26#include <VBox/dbg.h>
27
28
29/*******************************************************************************
30* Defined Constants And Macros *
31*******************************************************************************/
32/* to err.h! */
33#define VERR_DBGC_QUIT (-11999)
34#define VERR_PARSE_FIRST (-11000)
35#define VERR_PARSE_TOO_FEW_ARGUMENTS (VERR_PARSE_FIRST - 0)
36#define VERR_PARSE_TOO_MANY_ARGUMENTS (VERR_PARSE_FIRST - 1)
37#define VERR_PARSE_ARGUMENT_OVERFLOW (VERR_PARSE_FIRST - 2)
38#define VERR_PARSE_ARGUMENT_TYPE_MISMATCH (VERR_PARSE_FIRST - 3)
39#define VERR_PARSE_NO_RANGE_ALLOWED (VERR_PARSE_FIRST - 4)
40#define VERR_PARSE_UNBALANCED_QUOTE (VERR_PARSE_FIRST - 5)
41#define VERR_PARSE_UNBALANCED_PARENTHESIS (VERR_PARSE_FIRST - 6)
42#define VERR_PARSE_EMPTY_ARGUMENT (VERR_PARSE_FIRST - 7)
43#define VERR_PARSE_UNEXPECTED_OPERATOR (VERR_PARSE_FIRST - 8)
44#define VERR_PARSE_INVALID_NUMBER (VERR_PARSE_FIRST - 9)
45#define VERR_PARSE_NUMBER_TOO_BIG (VERR_PARSE_FIRST - 10)
46#define VERR_PARSE_INVALID_OPERATION (VERR_PARSE_FIRST - 11)
47#define VERR_PARSE_FUNCTION_NOT_FOUND (VERR_PARSE_FIRST - 12)
48#define VERR_PARSE_NOT_A_FUNCTION (VERR_PARSE_FIRST - 13)
49#define VERR_PARSE_NO_MEMORY (VERR_PARSE_FIRST - 14)
50#define VERR_PARSE_INCORRECT_ARG_TYPE (VERR_PARSE_FIRST - 15)
51#define VERR_PARSE_VARIABLE_NOT_FOUND (VERR_PARSE_FIRST - 16)
52#define VERR_PARSE_CONVERSION_FAILED (VERR_PARSE_FIRST - 17)
53#define VERR_PARSE_NOT_IMPLEMENTED (VERR_PARSE_FIRST - 18)
54#define VERR_PARSE_BAD_RESULT_TYPE (VERR_PARSE_FIRST - 19)
55#define VERR_PARSE_WRITEONLY_SYMBOL (VERR_PARSE_FIRST - 20)
56#define VERR_PARSE_NO_ARGUMENT_MATCH (VERR_PARSE_FIRST - 21)
57#define VINF_PARSE_COMMAND_NOT_FOUND (VERR_PARSE_FIRST - 22)
58#define VINF_PARSE_INVALD_COMMAND_NAME (VERR_PARSE_FIRST - 23)
59#define VERR_PARSE_LAST (VERR_PARSE_FIRST - 30)
60
61#define VWRN_DBGC_CMD_PENDING 12000
62#define VWRN_DBGC_ALREADY_REGISTERED 12001
63#define VERR_DBGC_COMMANDS_NOT_REGISTERED (-12002)
64#define VERR_DBGC_BP_NOT_FOUND (-12003)
65#define VERR_DBGC_BP_EXISTS (-12004)
66#define VINF_DBGC_BP_NO_COMMAND 12005
67#define VERR_DBGC_COMMAND_FAILED (-12006)
68
69
70/*******************************************************************************
71* Structures and Typedefs *
72*******************************************************************************/
73
74/**
75 * Debugger console per breakpoint data.
76 */
77typedef struct DBGCBP
78{
79 /** Pointer to the next breakpoint in the list. */
80 struct DBGCBP *pNext;
81 /** The breakpoint identifier. */
82 RTUINT iBp;
83 /** The size of the command. */
84 size_t cchCmd;
85 /** The command to execute when the breakpoint is hit. */
86 char szCmd[1];
87} DBGCBP;
88/** Pointer to a breakpoint. */
89typedef DBGCBP *PDBGCBP;
90
91
92/**
93 * Named variable.
94 *
95 * Always allocated from heap in one signle block.
96 */
97typedef struct DBGCNAMEDVAR
98{
99 /** The variable. */
100 DBGCVAR Var;
101 /** Its name. */
102 char szName[1];
103} DBGCNAMEDVAR;
104/** Pointer to named variable. */
105typedef DBGCNAMEDVAR *PDBGCNAMEDVAR;
106
107
108/** The max length of a plug-in name, zero terminator included. */
109#define DBGCPLUGIN_MAX_NAME 32
110
111/**
112 * Plug-in tracking record.
113 */
114typedef struct DBGCPLUGIN
115{
116 /** Pointer to the next plug-in. */
117 struct DBGCPLUGIN *pNext;
118 /** The loader handle. */
119 RTLDRMOD hLdrMod;
120 /** The plug-in entry point. */
121 PFNDBGCPLUGIN pfnEntry;
122 /** The plug-in name (variable length). */
123 char szName[DBGCPLUGIN_MAX_NAME];
124} DBGCPLUGIN;
125/** Pointer to plug-in tracking record. */
126typedef DBGCPLUGIN *PDBGCPLUGIN;
127
128
129/**
130 * Debugger console status
131 */
132typedef enum DBGCSTATUS
133{
134 /** Normal status, .*/
135 DBGC_HALTED
136
137} DBGCSTATUS;
138
139
140/**
141 * Debugger console instance data.
142 */
143typedef struct DBGC
144{
145 /** Command helpers. */
146 DBGCCMDHLP CmdHlp;
147 /** Pointer to backend callback structure. */
148 PDBGCBACK pBack;
149
150 /** Pointer to the current VM. */
151 PVM pVM;
152 /** The current virtual CPU id. */
153 VMCPUID idCpu;
154 /** The current address space handle. */
155 RTDBGAS hDbgAs;
156 /** The current debugger emulation. */
157 const char *pszEmulation;
158 /** Pointer to the command and functions for the current debugger emulation. */
159 PCDBGCCMD paEmulationCmds;
160 /** The number of commands paEmulationCmds points to. */
161 unsigned cEmulationCmds;
162 /** Log indicator. (If set we're writing the log to the console.) */
163 bool fLog;
164
165 /** Indicates whether we're in guest (true) or hypervisor (false) register context. */
166 bool fRegCtxGuest;
167 /** Indicates whether the register are terse or sparse. */
168 bool fRegTerse;
169
170 /** Current dissassembler position. */
171 DBGCVAR DisasmPos;
172 /** Current source position. (flat GC) */
173 DBGCVAR SourcePos;
174 /** Current memory dump position. */
175 DBGCVAR DumpPos;
176 /** Size of the previous dump element. */
177 unsigned cbDumpElement;
178
179 /** Number of variables in papVars. */
180 unsigned cVars;
181 /** Array of global variables.
182 * Global variables can be referenced using the $ operator and set
183 * and unset using command with those names. */
184 PDBGCNAMEDVAR *papVars;
185
186 /** The list of plug-in. (singly linked) */
187 PDBGCPLUGIN pPlugInHead;
188
189 /** The list of breakpoints. (singly linked) */
190 PDBGCBP pFirstBp;
191
192 /** Save search pattern. */
193 uint8_t abSearch[256];
194 /** The length of the search pattern. */
195 uint32_t cbSearch;
196 /** The search unit */
197 uint32_t cbSearchUnit;
198 /** The max hits. */
199 uint64_t cMaxSearchHits;
200 /** The address to resume searching from. */
201 DBGFADDRESS SearchAddr;
202 /** What's left of the original search range. */
203 RTGCUINTPTR cbSearchRange;
204
205 /** @name Parsing and Execution
206 * @{ */
207
208 /** Input buffer. */
209 char achInput[2048];
210 /** To ease debugging. */
211 unsigned uInputZero;
212 /** Write index in the input buffer. */
213 unsigned iWrite;
214 /** Read index in the input buffer. */
215 unsigned iRead;
216 /** The number of lines in the buffer. */
217 unsigned cInputLines;
218 /** Indicates that we have a buffer overflow condition.
219 * This means that input is ignored up to the next newline. */
220 bool fInputOverflow;
221 /** Indicates whether or we're ready for input. */
222 bool fReady;
223 /** Scratch buffer position. */
224 char *pszScratch;
225 /** Scratch buffer. */
226 char achScratch[16384];
227 /** Argument array position. */
228 unsigned iArg;
229 /** Array of argument variables. */
230 DBGCVAR aArgs[100];
231
232 /** rc from the last dbgcHlpPrintfV(). */
233 int rcOutput;
234 /** rc from the last command. */
235 int rcCmd;
236 /** @} */
237} DBGC;
238/** Pointer to debugger console instance data. */
239typedef DBGC *PDBGC;
240
241/** Converts a Command Helper pointer to a pointer to DBGC instance data. */
242#define DBGC_CMDHLP2DBGC(pCmdHlp) ( (PDBGC)((uintptr_t)(pCmdHlp) - RT_OFFSETOF(DBGC, CmdHlp)) )
243
244
245/**
246 * Chunk of external commands.
247 */
248typedef struct DBGCEXTCMDS
249{
250 /** Number of commands descriptors. */
251 unsigned cCmds;
252 /** Pointer to array of command descriptors. */
253 PCDBGCCMD paCmds;
254 /** Pointer to the next chunk. */
255 struct DBGCEXTCMDS *pNext;
256} DBGCEXTCMDS;
257/** Pointer to chunk of external commands. */
258typedef DBGCEXTCMDS *PDBGCEXTCMDS;
259
260
261
262/**
263 * Unary operator handler function.
264 *
265 * @returns 0 on success.
266 * @returns VBox evaluation / parsing error code on failure.
267 * The caller does the bitching.
268 * @param pDbgc Debugger console instance data.
269 * @param pArg The argument.
270 * @param pResult Where to store the result.
271 */
272typedef DECLCALLBACK(int) FNDBGCOPUNARY(PDBGC pDbgc, PCDBGCVAR pArg, PDBGCVAR pResult);
273/** Pointer to a unary operator handler function. */
274typedef FNDBGCOPUNARY *PFNDBGCOPUNARY;
275
276
277/**
278 * Binary operator handler function.
279 *
280 * @returns 0 on success.
281 * @returns VBox evaluation / parsing error code on failure.
282 * The caller does the bitching.
283 * @param pDbgc Debugger console instance data.
284 * @param pArg1 The first argument.
285 * @param pArg2 The 2nd argument.
286 * @param pResult Where to store the result.
287 */
288typedef DECLCALLBACK(int) FNDBGCOPBINARY(PDBGC pDbgc, PCDBGCVAR pArg1, PCDBGCVAR pArg2, PDBGCVAR pResult);
289/** Pointer to a binary operator handler function. */
290typedef FNDBGCOPBINARY *PFNDBGCOPBINARY;
291
292
293/**
294 * Operator descriptor.
295 */
296typedef struct DBGCOP
297{
298 /** Operator mnemonic. */
299 char szName[4];
300 /** Length of name. */
301 const unsigned cchName;
302 /** Whether or not this is a binary operator.
303 * Unary operators are evaluated right-to-left while binary are left-to-right. */
304 bool fBinary;
305 /** Precedence level. */
306 unsigned iPrecedence;
307 /** Unary operator handler. */
308 PFNDBGCOPUNARY pfnHandlerUnary;
309 /** Binary operator handler. */
310 PFNDBGCOPBINARY pfnHandlerBinary;
311 /** Operator description. */
312 const char *pszDescription;
313} DBGCOP;
314/** Pointer to an operator descriptor. */
315typedef DBGCOP *PDBGCOP;
316/** Pointer to a const operator descriptor. */
317typedef const DBGCOP *PCDBGCOP;
318
319
320
321/** Pointer to symbol descriptor. */
322typedef struct DBGCSYM *PDBGCSYM;
323/** Pointer to const symbol descriptor. */
324typedef const struct DBGCSYM *PCDBGCSYM;
325
326/**
327 * Get builtin symbol.
328 *
329 * @returns 0 on success.
330 * @returns VBox evaluation / parsing error code on failure.
331 * The caller does the bitching.
332 * @param pSymDesc Pointer to the symbol descriptor.
333 * @param pCmdHlp Pointer to the command callback structure.
334 * @param enmType The result type.
335 * @param pResult Where to store the result.
336 */
337typedef DECLCALLBACK(int) FNDBGCSYMGET(PCDBGCSYM pSymDesc, PDBGCCMDHLP pCmdHlp, DBGCVARTYPE enmType, PDBGCVAR pResult);
338/** Pointer to get function for a builtin symbol. */
339typedef FNDBGCSYMGET *PFNDBGCSYMGET;
340
341/**
342 * Set builtin symbol.
343 *
344 * @returns 0 on success.
345 * @returns VBox evaluation / parsing error code on failure.
346 * The caller does the bitching.
347 * @param pSymDesc Pointer to the symbol descriptor.
348 * @param pCmdHlp Pointer to the command callback structure.
349 * @param pValue The value to assign the symbol.
350 */
351typedef DECLCALLBACK(int) FNDBGCSYMSET(PCDBGCSYM pSymDesc, PDBGCCMDHLP pCmdHlp, PCDBGCVAR pValue);
352/** Pointer to set function for a builtin symbol. */
353typedef FNDBGCSYMSET *PFNDBGCSYMSET;
354
355
356/**
357 * Symbol description (for builtin symbols).
358 */
359typedef struct DBGCSYM
360{
361 /** Symbol name. */
362 const char *pszName;
363 /** Get function. */
364 PFNDBGCSYMGET pfnGet;
365 /** Set function. (NULL if readonly) */
366 PFNDBGCSYMSET pfnSet;
367 /** User data. */
368 unsigned uUser;
369} DBGCSYM;
370
371
372/*******************************************************************************
373* Internal Functions *
374*******************************************************************************/
375int dbgcBpAdd(PDBGC pDbgc, RTUINT iBp, const char *pszCmd);
376int dbgcBpUpdate(PDBGC pDbgc, RTUINT iBp, const char *pszCmd);
377int dbgcBpDelete(PDBGC pDbgc, RTUINT iBp);
378PDBGCBP dbgcBpGet(PDBGC pDbgc, RTUINT iBp);
379int dbgcBpExec(PDBGC pDbgc, RTUINT iBp);
380
381void dbgcVarInit(PDBGCVAR pVar);
382void dbgcVarSetGCFlat(PDBGCVAR pVar, RTGCPTR GCFlat);
383void dbgcVarSetGCFlatByteRange(PDBGCVAR pVar, RTGCPTR GCFlat, uint64_t cb);
384void dbgcVarSetU64(PDBGCVAR pVar, uint64_t u64);
385void dbgcVarSetVar(PDBGCVAR pVar, PCDBGCVAR pVar2);
386void dbgcVarSetDbgfAddr(PDBGCVAR pVar, PCDBGFADDRESS pAddress);
387void dbgcVarSetNoRange(PDBGCVAR pVar);
388void dbgcVarSetByteRange(PDBGCVAR pVar, uint64_t cb);
389int dbgcVarToDbgfAddr(PDBGC pDbgc, PCDBGCVAR pVar, PDBGFADDRESS pAddress);
390
391int dbgcEvalSub(PDBGC pDbgc, char *pszExpr, size_t cchExpr, PDBGCVAR pResult);
392int dbgcProcessCommand(PDBGC pDbgc, char *pszCmd, size_t cchCmd, bool fNoExecute);
393
394int dbgcSymbolGet(PDBGC pDbgc, const char *pszSymbol, DBGCVARTYPE enmType, PDBGCVAR pResult);
395PCDBGCSYM dbgcLookupRegisterSymbol(PDBGC pDbgc, const char *pszSymbol);
396PCDBGCOP dbgcOperatorLookup(PDBGC pDbgc, const char *pszExpr, bool fPreferBinary, char chPrev);
397PCDBGCCMD dbgcRoutineLookup(PDBGC pDbgc, const char *pachName, size_t cchName, bool fExternal);
398
399DECLCALLBACK(int) dbgcOpAddrFlat(PDBGC pDbgc, PCDBGCVAR pArg, PDBGCVAR pResult);
400DECLCALLBACK(int) dbgcOpAddrHost(PDBGC pDbgc, PCDBGCVAR pArg, PDBGCVAR pResult);
401DECLCALLBACK(int) dbgcOpAddrPhys(PDBGC pDbgc, PCDBGCVAR pArg, PDBGCVAR pResult);
402DECLCALLBACK(int) dbgcOpAddrHostPhys(PDBGC pDbgc, PCDBGCVAR pArg, PDBGCVAR pResult);
403
404void dbgcInitCmdHlp(PDBGC pDbgc);
405
406void dbgcPlugInAutoLoad(PDBGC pDbgc);
407void dbgcPlugInUnloadAll(PDBGC pDbgc);
408
409/* For tstDBGCParser: */
410int dbgcCreate(PDBGC *ppDbgc, PDBGCBACK pBack, unsigned fFlags);
411int dbgcRun(PDBGC pDbgc);
412int dbgcProcessInput(PDBGC pDbgc, bool fNoExecute);
413void dbgcDestroy(PDBGC pDbgc);
414
415
416/*******************************************************************************
417* Global Variables *
418*******************************************************************************/
419extern const DBGCCMD g_aCmds[];
420extern const unsigned g_cCmds;
421extern const DBGCCMD g_aCmdsCodeView[];
422extern const unsigned g_cCmdsCodeView;
423extern const DBGCOP g_aOps[];
424extern const unsigned g_cOps;
425
426
427#endif
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette