1381fe1aaSGarrett Wollman /*- 2381fe1aaSGarrett Wollman * Copyright (c) 1993, Garrett A. Wollman. 3381fe1aaSGarrett Wollman * Copyright (c) 1993, University of Vermont and State Agricultural College. 4381fe1aaSGarrett Wollman * All rights reserved. 5381fe1aaSGarrett Wollman * 6381fe1aaSGarrett Wollman * Redistribution and use in source and binary forms, with or without 7381fe1aaSGarrett Wollman * modification, are permitted provided that the following conditions 8381fe1aaSGarrett Wollman * are met: 9381fe1aaSGarrett Wollman * 1. Redistributions of source code must retain the above copyright 10381fe1aaSGarrett Wollman * notice, this list of conditions and the following disclaimer. 11381fe1aaSGarrett Wollman * 2. Redistributions in binary form must reproduce the above copyright 12381fe1aaSGarrett Wollman * notice, this list of conditions and the following disclaimer in the 13381fe1aaSGarrett Wollman * documentation and/or other materials provided with the distribution. 14381fe1aaSGarrett Wollman * 3. Neither the name of the University nor the names of its contributors 15381fe1aaSGarrett Wollman * may be used to endorse or promote products derived from this software 16381fe1aaSGarrett Wollman * without specific prior written permission. 17381fe1aaSGarrett Wollman * 18381fe1aaSGarrett Wollman * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 19381fe1aaSGarrett Wollman * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20381fe1aaSGarrett Wollman * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21381fe1aaSGarrett Wollman * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 22381fe1aaSGarrett Wollman * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23381fe1aaSGarrett Wollman * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24381fe1aaSGarrett Wollman * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25381fe1aaSGarrett Wollman * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26381fe1aaSGarrett Wollman * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27381fe1aaSGarrett Wollman * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28381fe1aaSGarrett Wollman * SUCH DAMAGE. 29381fe1aaSGarrett Wollman * 30c3aac50fSPeter Wemm * $FreeBSD$ 31381fe1aaSGarrett Wollman */ 32381fe1aaSGarrett Wollman 33381fe1aaSGarrett Wollman /* 34381fe1aaSGarrett Wollman * Necessary declarations for the `ddb' kernel debugger. 35381fe1aaSGarrett Wollman */ 36381fe1aaSGarrett Wollman 374753168fSBruce Evans #ifndef _DDB_DDB_H_ 384753168fSBruce Evans #define _DDB_DDB_H_ 39381fe1aaSGarrett Wollman 4026f9a767SRodney W. Grimes #include <machine/db_machdep.h> /* type definitions */ 41381fe1aaSGarrett Wollman 42a2aeb24eSMarcel Moolenaar #ifndef DB_MAXARGS 43a2aeb24eSMarcel Moolenaar #define DB_MAXARGS 10 44a2aeb24eSMarcel Moolenaar #endif 45a2aeb24eSMarcel Moolenaar 46a2aeb24eSMarcel Moolenaar #ifndef DB_CALL 47a2aeb24eSMarcel Moolenaar #define DB_CALL db_fncall_generic 48a2aeb24eSMarcel Moolenaar #else 49a2aeb24eSMarcel Moolenaar int DB_CALL(db_expr_t, db_expr_t *, int, db_expr_t[]); 50a2aeb24eSMarcel Moolenaar #endif 51a2aeb24eSMarcel Moolenaar 52763df836SBruce Evans typedef void db_cmdfcn_t(db_expr_t addr, boolean_t have_addr, db_expr_t count, 53763df836SBruce Evans char *modif); 544753168fSBruce Evans 551e16f609SJohn Baldwin typedef void db_page_calloutfcn_t(void *arg); 561e16f609SJohn Baldwin 576337f4efSBruce Evans #define DB_COMMAND(cmd_name, func_name) \ 58e1e31c0eSJohn Baldwin DB_FUNC(cmd_name, func_name, db_cmd_set, 0, NULL) 596337f4efSBruce Evans #define DB_SHOW_COMMAND(cmd_name, func_name) \ 60e1e31c0eSJohn Baldwin DB_FUNC(cmd_name, func_name, db_show_cmd_set, 0, NULL) 616337f4efSBruce Evans 627102c89aSJustin T. Gibbs #define DB_SET(cmd_name, func_name, set, flag, more) \ 63e1e31c0eSJohn Baldwin static const struct command __CONCAT(cmd_name,_cmd) = { \ 646337f4efSBruce Evans __STRING(cmd_name), \ 656337f4efSBruce Evans func_name, \ 667102c89aSJustin T. Gibbs flag, \ 677102c89aSJustin T. Gibbs more \ 686337f4efSBruce Evans }; \ 69e1e31c0eSJohn Baldwin TEXT_SET(set, __CONCAT(cmd_name,_cmd)) 70e1e31c0eSJohn Baldwin 71e1e31c0eSJohn Baldwin #define DB_FUNC(cmd_name, func_name, set, flag, more) \ 72e1e31c0eSJohn Baldwin static db_cmdfcn_t func_name; \ 73e1e31c0eSJohn Baldwin \ 74e1e31c0eSJohn Baldwin DB_SET(cmd_name, func_name, set, flag, more); \ 756337f4efSBruce Evans \ 766337f4efSBruce Evans static void \ 776337f4efSBruce Evans func_name(addr, have_addr, count, modif) \ 786337f4efSBruce Evans db_expr_t addr; \ 796337f4efSBruce Evans boolean_t have_addr; \ 806337f4efSBruce Evans db_expr_t count; \ 816337f4efSBruce Evans char *modif; 826337f4efSBruce Evans 833da6ef3cSBruce Evans extern db_expr_t db_maxoff; 846337f4efSBruce Evans extern int db_indent; 85381fe1aaSGarrett Wollman extern int db_inst_count; 86381fe1aaSGarrett Wollman extern int db_load_count; 87381fe1aaSGarrett Wollman extern int db_store_count; 883da6ef3cSBruce Evans extern db_expr_t db_radix; 893da6ef3cSBruce Evans extern db_expr_t db_max_width; 903da6ef3cSBruce Evans extern db_expr_t db_tab_stop_width; 91d39d4a6eSJohn Baldwin extern db_expr_t db_lines_per_page; 92381fe1aaSGarrett Wollman 9337224cd3SMarcel Moolenaar struct thread; 946337f4efSBruce Evans struct vm_map; 95381fe1aaSGarrett Wollman 9614e10f99SAlfred Perlstein void db_check_interrupt(void); 9714e10f99SAlfred Perlstein void db_clear_watchpoints(void); 9814e10f99SAlfred Perlstein db_addr_t db_disasm(db_addr_t loc, boolean_t altfmt); 99381fe1aaSGarrett Wollman /* instruction disassembler */ 100bda9921dSMark Murray void db_error(const char *s); 10114e10f99SAlfred Perlstein int db_expression(db_expr_t *valuep); 10214e10f99SAlfred Perlstein int db_get_variable(db_expr_t *valuep); 10314e10f99SAlfred Perlstein void db_iprintf(const char *,...) __printflike(1, 2); 104d605beaaSJohn Baldwin struct proc *db_lookup_proc(db_expr_t addr); 105d605beaaSJohn Baldwin struct thread *db_lookup_thread(db_expr_t addr, boolean_t check_pid); 10614e10f99SAlfred Perlstein struct vm_map *db_map_addr(vm_offset_t); 10714e10f99SAlfred Perlstein boolean_t db_map_current(struct vm_map *); 10814e10f99SAlfred Perlstein boolean_t db_map_equal(struct vm_map *, struct vm_map *); 109216e80c2SMarcel Moolenaar int db_md_set_watchpoint(db_expr_t addr, db_expr_t size); 110216e80c2SMarcel Moolenaar int db_md_clr_watchpoint(db_expr_t addr, db_expr_t size); 111216e80c2SMarcel Moolenaar void db_md_list_watchpoints(void); 11214e10f99SAlfred Perlstein void db_print_loc_and_inst(db_addr_t loc); 11337224cd3SMarcel Moolenaar void db_print_thread(void); 11414e10f99SAlfred Perlstein void db_printf(const char *fmt, ...) __printflike(1, 2); 11537224cd3SMarcel Moolenaar int db_read_bytes(vm_offset_t addr, size_t size, char *data); 1164753168fSBruce Evans /* machine-dependent */ 11714e10f99SAlfred Perlstein int db_readline(char *lstart, int lsize); 11814e10f99SAlfred Perlstein void db_restart_at_pc(boolean_t watchpt); 11937224cd3SMarcel Moolenaar int db_set_variable(db_expr_t value); 12014e10f99SAlfred Perlstein void db_set_watchpoints(void); 1211e16f609SJohn Baldwin void db_setup_paging(db_page_calloutfcn_t *callout, void *arg, 1221e16f609SJohn Baldwin int maxlines); 12314e10f99SAlfred Perlstein void db_skip_to_eol(void); 12414e10f99SAlfred Perlstein boolean_t db_stop_at_pc(boolean_t *is_breakpoint); 1254753168fSBruce Evans #define db_strcpy strcpy 12637224cd3SMarcel Moolenaar void db_trace_self(void); 12737224cd3SMarcel Moolenaar int db_trace_thread(struct thread *, int); 12814e10f99SAlfred Perlstein int db_value_of_name(const char *name, db_expr_t *valuep); 12937224cd3SMarcel Moolenaar int db_write_bytes(vm_offset_t addr, size_t size, char *data); 130381fe1aaSGarrett Wollman 1314753168fSBruce Evans db_cmdfcn_t db_breakpoint_cmd; 1324753168fSBruce Evans db_cmdfcn_t db_continue_cmd; 1334753168fSBruce Evans db_cmdfcn_t db_delete_cmd; 13417bbfb58SBrian S. Dean db_cmdfcn_t db_deletehwatch_cmd; 1354753168fSBruce Evans db_cmdfcn_t db_deletewatch_cmd; 1364753168fSBruce Evans db_cmdfcn_t db_examine_cmd; 13717bbfb58SBrian S. Dean db_cmdfcn_t db_hwatchpoint_cmd; 1384753168fSBruce Evans db_cmdfcn_t db_listbreak_cmd; 1394753168fSBruce Evans db_cmdfcn_t db_print_cmd; 1404753168fSBruce Evans db_cmdfcn_t db_ps; 1414753168fSBruce Evans db_cmdfcn_t db_search_cmd; 1424753168fSBruce Evans db_cmdfcn_t db_set_cmd; 14337224cd3SMarcel Moolenaar db_cmdfcn_t db_set_thread; 1444753168fSBruce Evans db_cmdfcn_t db_show_regs; 14537224cd3SMarcel Moolenaar db_cmdfcn_t db_show_threads; 1464753168fSBruce Evans db_cmdfcn_t db_single_step_cmd; 1474753168fSBruce Evans db_cmdfcn_t db_trace_until_call_cmd; 1484753168fSBruce Evans db_cmdfcn_t db_trace_until_matching_cmd; 1494753168fSBruce Evans db_cmdfcn_t db_watchpoint_cmd; 1504753168fSBruce Evans db_cmdfcn_t db_write_cmd; 151381fe1aaSGarrett Wollman 1521e16f609SJohn Baldwin db_page_calloutfcn_t db_simple_pager; 1531e16f609SJohn Baldwin 1546337f4efSBruce Evans /* 1556337f4efSBruce Evans * Command table. 1566337f4efSBruce Evans */ 157e1e31c0eSJohn Baldwin struct command; 158e1e31c0eSJohn Baldwin 159e1e31c0eSJohn Baldwin struct command_table { 160e1e31c0eSJohn Baldwin struct command *table; 161e1e31c0eSJohn Baldwin struct command **aux_tablep; 162e1e31c0eSJohn Baldwin struct command **aux_tablep_end; 163e1e31c0eSJohn Baldwin }; 164e1e31c0eSJohn Baldwin 1656337f4efSBruce Evans struct command { 1666337f4efSBruce Evans char * name; /* command name */ 1676337f4efSBruce Evans db_cmdfcn_t *fcn; /* function to call */ 1686337f4efSBruce Evans int flag; /* extra info: */ 1696337f4efSBruce Evans #define CS_OWN 0x1 /* non-standard syntax */ 1706337f4efSBruce Evans #define CS_MORE 0x2 /* standard syntax, but may have other words 1716337f4efSBruce Evans * at end */ 1726337f4efSBruce Evans #define CS_SET_DOT 0x100 /* set dot after command */ 173e1e31c0eSJohn Baldwin struct command_table *more; /* another level of command */ 1746337f4efSBruce Evans }; 1756337f4efSBruce Evans 1764753168fSBruce Evans #endif /* !_DDB_DDB_H_ */ 177