Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 15 Sep 2004 20:09:17 GMT
From:      John Baldwin <jhb@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 61556 for review
Message-ID:  <200409152009.i8FK9HfO099015@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=61556

Change 61556 by jhb@jhb_slimer on 2004/09/15 20:08:44

	Add paging support to all the stack tracing functions.  (i.e. you
	can make it go line at a time or page at a time or quit at any
	time).

Affected files ...

.. //depot/projects/smpng/sys/alpha/alpha/db_trace.c#12 edit
.. //depot/projects/smpng/sys/amd64/amd64/db_trace.c#7 edit
.. //depot/projects/smpng/sys/arm/arm/db_trace.c#4 edit
.. //depot/projects/smpng/sys/i386/i386/db_trace.c#17 edit
.. //depot/projects/smpng/sys/ia64/ia64/db_trace.c#16 edit
.. //depot/projects/smpng/sys/powerpc/powerpc/db_trace.c#6 edit
.. //depot/projects/smpng/sys/sparc64/sparc64/db_trace.c#19 edit

Differences ...

==== //depot/projects/smpng/sys/alpha/alpha/db_trace.c#12 (text+ko) ====

@@ -213,14 +213,16 @@
 	db_expr_t diff;
 	db_addr_t symval;
 	u_long last_ipl, tfps;
-	int i;
+	int i, quit;
 
 	if (count == -1)
 		count = 1024;
 
 	last_ipl = ~0L;
 	tf = NULL;
-	while (count--) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (count-- && !quit) {
 		sym = db_search_symbol(pc, DB_STGY_ANY, &diff);
 		if (sym == DB_SYM_NULL)
 			return (ENOENT);

==== //depot/projects/smpng/sys/amd64/amd64/db_trace.c#7 (text+ko) ====

@@ -373,14 +373,16 @@
 	long *argp;
 	db_expr_t offset;
 	c_db_sym_t sym;
-	int narg;
+	int narg, quit;
 	boolean_t first;
 
 	if (count == -1)
 		count = 1024;
 
 	first = TRUE;
-	while (count--) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (count-- && !quit) {
 		sym = db_search_symbol(pc, DB_STGY_ANY, &offset);
 		db_symbol_values(sym, &name, NULL);
 

==== //depot/projects/smpng/sys/arm/arm/db_trace.c#4 (text+ko) ====

@@ -102,7 +102,7 @@
 	db_expr_t offset;
 	boolean_t	kernel_only = TRUE;
 	boolean_t	trace_thread = FALSE;
-	int	scp_offset;
+	int	scp_offset, quit;
 
 	if (kdb_frame == NULL && !have_addr)
 		return;
@@ -142,7 +142,9 @@
 	lastframe = NULL;
 	scp_offset = -(get_pc_str_offset() >> 2);
 
-	while (count-- && frame != NULL) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (count-- && frame != NULL && !quit) {
 		db_addr_t	scp;
 		u_int32_t	savecode;
 		int		r;

==== //depot/projects/smpng/sys/i386/i386/db_trace.c#17 (text+ko) ====

@@ -379,14 +379,16 @@
 	int *argp;
 	db_expr_t offset;
 	c_db_sym_t sym;
-	int narg;
+	int narg, quit;
 	boolean_t first;
 
 	if (count == -1)
 		count = 1024;
 
 	first = TRUE;
-	while (count--) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (count-- && !quit) {
 		sym = db_search_symbol(pc, DB_STGY_ANY, &offset);
 		db_symbol_values(sym, &name, NULL);
 

==== //depot/projects/smpng/sys/ia64/ia64/db_trace.c#16 (text+ko) ====

@@ -57,10 +57,12 @@
 	db_expr_t offset;
 	uint64_t bsp, cfm, ip, pfs, reg, sp;
 	c_db_sym_t sym;
-	int args, error, i;
+	int args, error, i, quit;
 
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
 	error = unw_create_from_pcb(&rs, pcb);
-	while (!error && count--) {
+	while (!error && count-- && !quit) {
 		error = unw_get_cfm(&rs, &cfm);
 		if (!error)
 			error = unw_get_bsp(&rs, &bsp);

==== //depot/projects/smpng/sys/powerpc/powerpc/db_trace.c#6 (text+ko) ====

@@ -129,6 +129,7 @@
 	const char *symname;
 	boolean_t kernel_only = TRUE;
 	boolean_t full = FALSE;
+	int quit;
 
 #if 0
 	{
@@ -148,7 +149,9 @@
 
 	stackframe = fp;
 
-	for (;;) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (!quit) {
 		if (stackframe < PAGE_SIZE)
 			break;
 

==== //depot/projects/smpng/sys/sparc64/sparc64/db_trace.c#19 (text+ko) ====

@@ -96,7 +96,7 @@
  * User stack trace (debugging aid).
  */
 static void
-db_utrace(struct thread *td, struct trapframe *tf, int count)
+db_utrace(struct thread *td, struct trapframe *tf, int count, int *quitp)
 {
 	struct pcb *pcb;
 	db_addr_t sp, rsp, o7, pc;
@@ -108,7 +108,7 @@
 	    FALSE);
 	pc = db_get_value((db_addr_t)&tf->tf_tpc, sizeof(tf->tf_tpc), FALSE);
 	db_printf("user trace: trap %%o7=%#lx\n", o7);
-	while (count-- && sp != 0) {
+	while (count-- && sp != 0 && !*quitp) {
 		db_printf("pc %#lx, sp %#lx\n", pc, sp);
 		/* First, check whether the frame is in the pcb. */
 		found = 0;
@@ -134,7 +134,7 @@
 }
 
 static int
-db_print_trap(struct thread *td, struct trapframe *tf, int count)
+db_print_trap(struct thread *td, struct trapframe *tf, int count, int *quitp)
 {
 	struct proc *p;
 	const char *symname;
@@ -212,7 +212,7 @@
 		db_printf("userland() at ");
 		db_printsym(tpc, DB_STGY_PROC);
 		db_printf("\n");
-		db_utrace(td, tf, count);
+		db_utrace(td, tf, count, quitp);
 	}
 	return (user);
 }
@@ -229,6 +229,7 @@
 	db_addr_t pc;
 	int trap;
 	int user;
+	int quit;
 
 	if (count == -1)
 		count = 1024;
@@ -236,7 +237,9 @@
 	trap = 0;
 	user = 0;
 	npc = 0;
-	while (count-- && !user) {
+	quit = 0;
+	db_setup_paging(db_simple_pager, &quit, DB_LINES_PER_PAGE);
+	while (count-- && !user && !quit) {
 		pc = (db_addr_t)db_get_value((db_addr_t)&fp->fr_pc,
 		    sizeof(fp->fr_pc), FALSE);
 		if (trap) {
@@ -260,7 +263,7 @@
 			tf = (struct trapframe *)(fp + 1);
 			npc = db_get_value((db_addr_t)&tf->tf_tpc,
 			    sizeof(tf->tf_tpc), FALSE);
-			user = db_print_trap(td, tf, count);
+			user = db_print_trap(td, tf, count, &quit);
 			trap = 1;
 		} else {
 			db_printf("%s() at ", name);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200409152009.i8FK9HfO099015>