~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Wine Cross Reference
wine/programs/winedbg/be_cpu.h

Version: ~ [ wine-1.1.3 ] ~ [ wine-1.1.2 ] ~ [ wine-1.1.1 ] ~ [ wine-1.1.0 ] ~ [ wine-1.0 ] ~ [ wine-1.0-rc5 ] ~ [ wine-1.0-rc4 ] ~ [ wine-1.0-rc3 ] ~ [ wine-1.0-rc2 ] ~ [ wine-1.0-rc1 ] ~ [ wine-0.9.61 ] ~ [ wine-0.9.60 ] ~ [ wine-0.9.59 ] ~ [ wine-0.9.58 ] ~ [ wine-0.9.57 ] ~ [ wine-0.9.56 ] ~ [ wine-0.9.55 ] ~ [ wine-0.9.54 ] ~ [ wine-0.9.53 ] ~ [ wine-0.9.52 ] ~ [ wine-0.9.51 ] ~ [ wine-0.9.50 ] ~ [ wine-0.9.49 ] ~ [ wine-0.9.48 ] ~ [ wine-0.9.47 ] ~ [ wine-0.9.46 ] ~ [ wine-0.9.45 ] ~ [ wine-0.9.44 ] ~ [ wine-0.9.43 ] ~ [ wine-0.9.42 ] ~ [ wine-0.9.41 ] ~ [ wine-0.9.40 ] ~ [ wine-0.9.39 ] ~ [ wine-0.9.38 ] ~ [ wine-0.9.37 ] ~ [ wine-0.9.36 ] ~ [ wine-0.9.35 ] ~ [ wine-0.9.34 ] ~ [ wine-0.9.33 ] ~ [ wine-0.9.32 ] ~ [ wine-0.9.31 ] ~ [ wine-0.9.30 ] ~ [ wine-0.9.29 ] ~ [ wine-0.9.28 ] ~ [ wine-0.9.27 ] ~ [ wine-0.9.26 ] ~ [ wine-0.9.25 ] ~ [ wine-0.9.24 ] ~ [ wine-0.9.23 ] ~ [ wine-0.9.22 ] ~ [ wine-0.9.21 ] ~ [ wine-0.9.20 ] ~ [ wine-0.9.19 ] ~ [ wine-0.9.18 ] ~ [ wine-0.9.17 ] ~ [ wine-0.9.16 ] ~ [ wine-0.9.15 ] ~ [ wine-0.9.14 ] ~ [ wine-0.9.13 ] ~ [ wine-0.9.12 ] ~ [ wine-0.9.11 ] ~ [ wine-0.9.10 ] ~ [ wine-0.9.9 ] ~ [ wine-0.9.8 ] ~ [ wine-0.9.7 ] ~ [ wine-0.9.6 ] ~ [ wine-0.9.5 ] ~ [ wine-0.9.4 ] ~ [ wine-0.9.3 ] ~ [ wine-0.9.2 ] ~ [ wine-0.9.1 ] ~ [ wine-0.9 ] ~ [ wine20050930 ] ~ [ wine20050830 ] ~ [ wine20050725 ] ~ [ wine20050628 ] ~ [ wine20050524 ] ~ [ wine20050419 ] ~ [ wine20050310 ] ~ [ wine20050211 ] ~ [ wine20050111 ] ~ [ wine20041201 ] ~ [ wine20041019 ] ~ [ wine20040914 ] ~ [ wine20040813 ] ~ [ wine20040716 ] ~ [ wine20040615 ] ~ [ wine20040505 ] ~ [ wine20040408 ] ~ [ wine20040309 ] ~ [ wine20040213 ] ~ [ wine20040121 ] ~ [ wine20031212 ] ~ [ wine20031118 ] ~ [ wine20031016 ] ~ [ wine20030911 ] ~ [ wine20030813 ] ~ [ wine20030709 ] ~ [ wine20030618 ] ~ [ wine20030508 ] ~ [ wine20030408 ] ~ [ wine20030318 ] ~ [ wine20030219 ] ~ [ wine20030115 ] ~ [ wine20021219 ] ~ [ wine20021125 ] ~ [ wine20021031 ] ~ [ wine20021007 ] ~ [ wine20020904 ] ~ [ wine20020804 ] ~ [ wine20020710 ] ~ [ wine20020605 ] ~ [ wine20020509 ] ~ [ wine20020411 ] ~ [ wine20020310 ] ~ [ wine20020228 ] ~ [ wine20011226 ] ~ [ wine20011108 ] ~ [ wine20011004 ] ~ [ wine20010824 ] ~ [ wine20010731 ] ~ [ wine20010629 ] ~ [ wine20010510 ] ~ [ wine20010418 ] ~ [ wine20010326 ] ~ [ wine20010305 ] ~ [ wine20010216 ] ~ [ wine20010112 ] ~ [ wine20001222 ] ~ [ wine20001202 ] ~ [ wine20001026 ] ~ [ wine20001002 ] ~ [ wine20000909 ] ~ [ wine20000821 ] ~ [ wine20000801 ] ~ [ wine20000716 ] ~ [ wine20000326 ] ~ [ wine20000227 ] ~ [ wine20000130 ] ~ [ wine20000109 ] ~

  1 /*
  2  * Debugger CPU backend definitions
  3  *
  4  * Copyright 2004 Eric Pouech
  5  *
  6  * This library is free software; you can redistribute it and/or
  7  * modify it under the terms of the GNU Lesser General Public
  8  * License as published by the Free Software Foundation; either
  9  * version 2.1 of the License, or (at your option) any later version.
 10  *
 11  * This library is distributed in the hope that it will be useful,
 12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 14  * Lesser General Public License for more details.
 15  *
 16  * You should have received a copy of the GNU Lesser General Public
 17  * License along with this library; if not, write to the Free Software
 18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 19  */
 20 
 21 enum be_cpu_addr {be_cpu_addr_pc, be_cpu_addr_stack, be_cpu_addr_frame};
 22 enum be_xpoint_type {be_xpoint_break, be_xpoint_watch_exec, be_xpoint_watch_read,
 23                      be_xpoint_watch_write};
 24 struct backend_cpu
 25 {
 26     /* ------------------------------------------------------------------------------
 27      * address manipulation
 28      * ------------------------------------------------------------------------------ */
 29     /* Linearizes an address. Only CPUs with segmented address model need this.
 30      * Otherwise, implementation is straightforward (be_cpu_linearize will do)
 31      */
 32     void*               (*linearize)(HANDLE hThread, const ADDRESS64*);
 33     /* Fills in an ADDRESS64 structure from a segment & an offset. CPUs without
 34      * segment address model should use 0 as seg. Required method to fill
 35      * in an ADDRESS64 (except an linear one).
 36      * Non segmented CPU shall use be_cpu_build_addr
 37      */
 38     unsigned            (*build_addr)(HANDLE hThread, const CONTEXT* ctx, 
 39                                       ADDRESS64* addr, unsigned seg,
 40                                       unsigned long offset);
 41     /* Retrieves in addr an address related to the context (program counter, stack
 42      * pointer, frame pointer)
 43      */
 44     unsigned            (*get_addr)(HANDLE hThread, const CONTEXT* ctx, 
 45                                     enum be_cpu_addr, ADDRESS64* addr);
 46 
 47     /* returns which kind of information a given register number refers to */
 48     unsigned            (*get_register_info)(int regno, enum be_cpu_addr* kind);
 49 
 50     /* -------------------------------------------------------------------------------
 51      * context manipulation 
 52      * ------------------------------------------------------------------------------- */
 53     /* Enables/disables CPU single step mode (depending on enable) */
 54     void                (*single_step)(CONTEXT* ctx, unsigned enable);
 55     /* Dumps out the content of the context */
 56     void                (*print_context)(HANDLE hThread, const CONTEXT* ctx, int all_regs);
 57     /* Prints information about segments. Non segmented CPU should leave this
 58      * function empty
 59      */
 60     void                (*print_segment_info)(HANDLE hThread, const CONTEXT* ctx);
 61     /* Do the initialization so that the debugger has internal variables linked
 62      * to the context's registers
 63      */
 64     const struct dbg_internal_var*
 65                         (*init_registers)(CONTEXT* ctx);
 66     /* -------------------------------------------------------------------------------
 67      * code inspection 
 68      * -------------------------------------------------------------------------------*/
 69     /* Check whether the instruction at addr is an insn to step over
 70      * (like function call, interruption...)
 71      */
 72     unsigned            (*is_step_over_insn)(const void* addr);
 73     /* Check whether instruction at 'addr' is the return from a function call */
 74     unsigned            (*is_function_return)(const void* addr);
 75     /* Check whether instruction at 'addr' is the CPU break instruction. On i386, 
 76      * it's INT3 (0xCC)
 77      */
 78     unsigned            (*is_break_insn)(const void*);
 79     /* Check whether instruction at 'addr' is a function call */
 80     unsigned            (*is_function_call)(const void* insn, ADDRESS64* callee);
 81     /* Ask for disassembling one instruction. If display is true, assembly code
 82      * will be printed. In all cases, 'addr' is advanced at next instruction
 83      */
 84     void                (*disasm_one_insn)(ADDRESS64* addr, int display);
 85     /* -------------------------------------------------------------------------------
 86      * break points / watchpoints handling 
 87      * -------------------------------------------------------------------------------*/
 88     /* Inserts an Xpoint in the CPU context and/or debuggee address space */
 89     unsigned            (*insert_Xpoint)(HANDLE hProcess, const struct be_process_io* pio,
 90                                          CONTEXT* ctx, enum be_xpoint_type type,
 91                                          void* addr, unsigned long* val, unsigned size);
 92     /* Removes an Xpoint in the CPU context and/or debuggee address space */
 93     unsigned            (*remove_Xpoint)(HANDLE hProcess, const struct be_process_io* pio,
 94                                          CONTEXT* ctx, enum be_xpoint_type type,
 95                                          void* addr, unsigned long val, unsigned size);
 96     /* Checks whether a given watchpoint has been triggered */
 97     unsigned            (*is_watchpoint_set)(const CONTEXT* ctx, unsigned idx);
 98     /* Clears the watchpoint indicator */
 99     void                (*clear_watchpoint)(CONTEXT* ctx, unsigned idx);
100     /* After a break instruction is executed, in the corresponding exception handler,
101      * some CPUs report the address of the insn after the break insn, some others 
102      * report the address of the break insn itself.
103      * This function lets adjust the context PC to reflect this behavior.
104      */
105     int                 (*adjust_pc_for_break)(CONTEXT* ctx, BOOL way);
106     /* -------------------------------------------------------------------------------
107      * basic type read/write 
108      * -------------------------------------------------------------------------------*/
109     /* Reads an integer from memory and stores it inside a long long int */
110     int                 (*fetch_integer)(const struct dbg_lvalue* lvalue, unsigned size, unsigned is_signed, LONGLONG*);
111     /* Reads a real from memory and stores it inside a long double */
112     int                 (*fetch_float)(const struct dbg_lvalue* lvalue, unsigned size, long double*);
113 };
114 
115 extern struct backend_cpu*      be_cpu;
116 
117 /* some handy functions for non segmented CPUs */
118 void*    be_cpu_linearize(HANDLE hThread, const ADDRESS64*);
119 unsigned be_cpu_build_addr(HANDLE hThread, const CONTEXT* ctx, ADDRESS64* addr, 
120                            unsigned seg, unsigned long offset);
121 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

This page was automatically generated by the LXR engine.
Visit the LXR main site for more information.