|
@@ -47,6 +47,7 @@
|
|
* to test the HW NMI watchdog
|
|
* to test the HW NMI watchdog
|
|
* F## = Break at do_fork for ## iterations
|
|
* F## = Break at do_fork for ## iterations
|
|
* S## = Break at sys_open for ## iterations
|
|
* S## = Break at sys_open for ## iterations
|
|
|
|
+ * I## = Run the single step test ## iterations
|
|
*
|
|
*
|
|
* NOTE: that the do_fork and sys_open tests are mutually exclusive.
|
|
* NOTE: that the do_fork and sys_open tests are mutually exclusive.
|
|
*
|
|
*
|
|
@@ -375,7 +376,7 @@ static void emul_sstep_get(char *arg)
|
|
break;
|
|
break;
|
|
case 1:
|
|
case 1:
|
|
/* set breakpoint */
|
|
/* set breakpoint */
|
|
- break_helper("Z0", 0, sstep_addr);
|
|
|
|
|
|
+ break_helper("Z0", NULL, sstep_addr);
|
|
break;
|
|
break;
|
|
case 2:
|
|
case 2:
|
|
/* Continue */
|
|
/* Continue */
|
|
@@ -383,7 +384,7 @@ static void emul_sstep_get(char *arg)
|
|
break;
|
|
break;
|
|
case 3:
|
|
case 3:
|
|
/* Clear breakpoint */
|
|
/* Clear breakpoint */
|
|
- break_helper("z0", 0, sstep_addr);
|
|
|
|
|
|
+ break_helper("z0", NULL, sstep_addr);
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
eprintk("kgdbts: ERROR failed sstep get emulation\n");
|
|
eprintk("kgdbts: ERROR failed sstep get emulation\n");
|
|
@@ -465,11 +466,11 @@ static struct test_struct sw_breakpoint_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "kgdbts_break_test", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "g", "kgdbts_break_test", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs },
|
|
{ "write", "OK", write_regs },
|
|
{ "kgdbts_break_test", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "kgdbts_break_test", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "D", "OK" }, /* Detach */
|
|
{ "D", "OK" }, /* Detach */
|
|
- { "D", "OK", 0, got_break }, /* If the test worked we made it here */
|
|
|
|
|
|
+ { "D", "OK", NULL, got_break }, /* On success we made it here */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -499,14 +500,14 @@ static struct test_struct singlestep_break_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "kgdbts_break_test", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "g", "kgdbts_break_test", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "kgdbts_break_test", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "kgdbts_break_test", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
- { "g", "kgdbts_break_test", 0, check_single_step },
|
|
|
|
|
|
+ { "g", "kgdbts_break_test", NULL, check_single_step },
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "kgdbts_break_test", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "kgdbts_break_test", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "g", "kgdbts_break_test", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "D", "OK" }, /* Remove all breakpoints and continues */
|
|
{ "D", "OK" }, /* Remove all breakpoints and continues */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
@@ -520,14 +521,14 @@ static struct test_struct do_fork_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "do_fork", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "do_fork", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "do_fork", 0, check_and_rewind_pc }, /* check location */
|
|
|
|
|
|
+ { "g", "do_fork", NULL, check_and_rewind_pc }, /* check location */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "do_fork", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "do_fork", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
- { "g", "do_fork", 0, check_single_step },
|
|
|
|
|
|
+ { "g", "do_fork", NULL, check_single_step },
|
|
{ "do_fork", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "do_fork", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "7", "T0*", skip_back_repeat_test }, /* Loop based on repeat_test */
|
|
{ "7", "T0*", skip_back_repeat_test }, /* Loop based on repeat_test */
|
|
- { "D", "OK", 0, final_ack_set }, /* detach and unregister I/O */
|
|
|
|
|
|
+ { "D", "OK", NULL, final_ack_set }, /* detach and unregister I/O */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -538,14 +539,14 @@ static struct test_struct sys_open_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "sys_open", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "sys_open", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "sys_open", 0, check_and_rewind_pc }, /* check location */
|
|
|
|
|
|
+ { "g", "sys_open", NULL, check_and_rewind_pc }, /* check location */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "write", "OK", write_regs }, /* Write registers */
|
|
{ "sys_open", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "sys_open", "OK", sw_rem_break }, /*remove breakpoint */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
{ "s", "T0*", emul_sstep_get, emul_sstep_put }, /* Single step */
|
|
- { "g", "sys_open", 0, check_single_step },
|
|
|
|
|
|
+ { "g", "sys_open", NULL, check_single_step },
|
|
{ "sys_open", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "sys_open", "OK", sw_break, }, /* set sw breakpoint */
|
|
{ "7", "T0*", skip_back_repeat_test }, /* Loop based on repeat_test */
|
|
{ "7", "T0*", skip_back_repeat_test }, /* Loop based on repeat_test */
|
|
- { "D", "OK", 0, final_ack_set }, /* detach and unregister I/O */
|
|
|
|
|
|
+ { "D", "OK", NULL, final_ack_set }, /* detach and unregister I/O */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -556,11 +557,11 @@ static struct test_struct hw_breakpoint_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "kgdbts_break_test", "OK", hw_break, }, /* set hw breakpoint */
|
|
{ "kgdbts_break_test", "OK", hw_break, }, /* set hw breakpoint */
|
|
{ "c", "T0*", }, /* Continue */
|
|
{ "c", "T0*", }, /* Continue */
|
|
- { "g", "kgdbts_break_test", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "g", "kgdbts_break_test", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs },
|
|
{ "write", "OK", write_regs },
|
|
{ "kgdbts_break_test", "OK", hw_rem_break }, /*remove breakpoint */
|
|
{ "kgdbts_break_test", "OK", hw_rem_break }, /*remove breakpoint */
|
|
{ "D", "OK" }, /* Detach */
|
|
{ "D", "OK" }, /* Detach */
|
|
- { "D", "OK", 0, got_break }, /* If the test worked we made it here */
|
|
|
|
|
|
+ { "D", "OK", NULL, got_break }, /* On success we made it here */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -570,12 +571,12 @@ static struct test_struct hw_breakpoint_test[] = {
|
|
static struct test_struct hw_write_break_test[] = {
|
|
static struct test_struct hw_write_break_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "hw_break_val", "OK", hw_write_break, }, /* set hw breakpoint */
|
|
{ "hw_break_val", "OK", hw_write_break, }, /* set hw breakpoint */
|
|
- { "c", "T0*", 0, got_break }, /* Continue */
|
|
|
|
- { "g", "silent", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "c", "T0*", NULL, got_break }, /* Continue */
|
|
|
|
+ { "g", "silent", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs },
|
|
{ "write", "OK", write_regs },
|
|
{ "hw_break_val", "OK", hw_rem_write_break }, /*remove breakpoint */
|
|
{ "hw_break_val", "OK", hw_rem_write_break }, /*remove breakpoint */
|
|
{ "D", "OK" }, /* Detach */
|
|
{ "D", "OK" }, /* Detach */
|
|
- { "D", "OK", 0, got_break }, /* If the test worked we made it here */
|
|
|
|
|
|
+ { "D", "OK", NULL, got_break }, /* On success we made it here */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -585,12 +586,12 @@ static struct test_struct hw_write_break_test[] = {
|
|
static struct test_struct hw_access_break_test[] = {
|
|
static struct test_struct hw_access_break_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "hw_break_val", "OK", hw_access_break, }, /* set hw breakpoint */
|
|
{ "hw_break_val", "OK", hw_access_break, }, /* set hw breakpoint */
|
|
- { "c", "T0*", 0, got_break }, /* Continue */
|
|
|
|
- { "g", "silent", 0, check_and_rewind_pc },
|
|
|
|
|
|
+ { "c", "T0*", NULL, got_break }, /* Continue */
|
|
|
|
+ { "g", "silent", NULL, check_and_rewind_pc },
|
|
{ "write", "OK", write_regs },
|
|
{ "write", "OK", write_regs },
|
|
{ "hw_break_val", "OK", hw_rem_access_break }, /*remove breakpoint */
|
|
{ "hw_break_val", "OK", hw_rem_access_break }, /*remove breakpoint */
|
|
{ "D", "OK" }, /* Detach */
|
|
{ "D", "OK" }, /* Detach */
|
|
- { "D", "OK", 0, got_break }, /* If the test worked we made it here */
|
|
|
|
|
|
+ { "D", "OK", NULL, got_break }, /* On success we made it here */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -599,9 +600,9 @@ static struct test_struct hw_access_break_test[] = {
|
|
*/
|
|
*/
|
|
static struct test_struct nmi_sleep_test[] = {
|
|
static struct test_struct nmi_sleep_test[] = {
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
{ "?", "S0*" }, /* Clear break points */
|
|
- { "c", "T0*", 0, got_break }, /* Continue */
|
|
|
|
|
|
+ { "c", "T0*", NULL, got_break }, /* Continue */
|
|
{ "D", "OK" }, /* Detach */
|
|
{ "D", "OK" }, /* Detach */
|
|
- { "D", "OK", 0, got_break }, /* If the test worked we made it here */
|
|
|
|
|
|
+ { "D", "OK", NULL, got_break }, /* On success we made it here */
|
|
{ "", "" },
|
|
{ "", "" },
|
|
};
|
|
};
|
|
|
|
|
|
@@ -874,18 +875,23 @@ static void kgdbts_run_tests(void)
|
|
{
|
|
{
|
|
char *ptr;
|
|
char *ptr;
|
|
int fork_test = 0;
|
|
int fork_test = 0;
|
|
- int sys_open_test = 0;
|
|
|
|
|
|
+ int do_sys_open_test = 0;
|
|
|
|
+ int sstep_test = 1000;
|
|
int nmi_sleep = 0;
|
|
int nmi_sleep = 0;
|
|
|
|
+ int i;
|
|
|
|
|
|
ptr = strstr(config, "F");
|
|
ptr = strstr(config, "F");
|
|
if (ptr)
|
|
if (ptr)
|
|
- fork_test = simple_strtol(ptr+1, NULL, 10);
|
|
|
|
|
|
+ fork_test = simple_strtol(ptr + 1, NULL, 10);
|
|
ptr = strstr(config, "S");
|
|
ptr = strstr(config, "S");
|
|
if (ptr)
|
|
if (ptr)
|
|
- sys_open_test = simple_strtol(ptr+1, NULL, 10);
|
|
|
|
|
|
+ do_sys_open_test = simple_strtol(ptr + 1, NULL, 10);
|
|
ptr = strstr(config, "N");
|
|
ptr = strstr(config, "N");
|
|
if (ptr)
|
|
if (ptr)
|
|
nmi_sleep = simple_strtol(ptr+1, NULL, 10);
|
|
nmi_sleep = simple_strtol(ptr+1, NULL, 10);
|
|
|
|
+ ptr = strstr(config, "I");
|
|
|
|
+ if (ptr)
|
|
|
|
+ sstep_test = simple_strtol(ptr+1, NULL, 10);
|
|
|
|
|
|
/* required internal KGDB tests */
|
|
/* required internal KGDB tests */
|
|
v1printk("kgdbts:RUN plant and detach test\n");
|
|
v1printk("kgdbts:RUN plant and detach test\n");
|
|
@@ -894,8 +900,13 @@ static void kgdbts_run_tests(void)
|
|
run_breakpoint_test(0);
|
|
run_breakpoint_test(0);
|
|
v1printk("kgdbts:RUN bad memory access test\n");
|
|
v1printk("kgdbts:RUN bad memory access test\n");
|
|
run_bad_read_test();
|
|
run_bad_read_test();
|
|
- v1printk("kgdbts:RUN singlestep breakpoint test\n");
|
|
|
|
- run_singlestep_break_test();
|
|
|
|
|
|
+ v1printk("kgdbts:RUN singlestep test %i iterations\n", sstep_test);
|
|
|
|
+ for (i = 0; i < sstep_test; i++) {
|
|
|
|
+ run_singlestep_break_test();
|
|
|
|
+ if (i % 100 == 0)
|
|
|
|
+ v1printk("kgdbts:RUN singlestep [%i/%i]\n",
|
|
|
|
+ i, sstep_test);
|
|
|
|
+ }
|
|
|
|
|
|
/* ===Optional tests=== */
|
|
/* ===Optional tests=== */
|
|
|
|
|
|
@@ -922,7 +933,7 @@ static void kgdbts_run_tests(void)
|
|
repeat_test = fork_test;
|
|
repeat_test = fork_test;
|
|
printk(KERN_INFO "kgdbts:RUN do_fork for %i breakpoints\n",
|
|
printk(KERN_INFO "kgdbts:RUN do_fork for %i breakpoints\n",
|
|
repeat_test);
|
|
repeat_test);
|
|
- kthread_run(kgdbts_unreg_thread, 0, "kgdbts_unreg");
|
|
|
|
|
|
+ kthread_run(kgdbts_unreg_thread, NULL, "kgdbts_unreg");
|
|
run_do_fork_test();
|
|
run_do_fork_test();
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
@@ -931,11 +942,11 @@ static void kgdbts_run_tests(void)
|
|
* executed because a kernel thread will be spawned at the very
|
|
* executed because a kernel thread will be spawned at the very
|
|
* end to unregister the debug hooks.
|
|
* end to unregister the debug hooks.
|
|
*/
|
|
*/
|
|
- if (sys_open_test) {
|
|
|
|
- repeat_test = sys_open_test;
|
|
|
|
|
|
+ if (do_sys_open_test) {
|
|
|
|
+ repeat_test = do_sys_open_test;
|
|
printk(KERN_INFO "kgdbts:RUN sys_open for %i breakpoints\n",
|
|
printk(KERN_INFO "kgdbts:RUN sys_open for %i breakpoints\n",
|
|
repeat_test);
|
|
repeat_test);
|
|
- kthread_run(kgdbts_unreg_thread, 0, "kgdbts_unreg");
|
|
|
|
|
|
+ kthread_run(kgdbts_unreg_thread, NULL, "kgdbts_unreg");
|
|
run_sys_open_test();
|
|
run_sys_open_test();
|
|
return;
|
|
return;
|
|
}
|
|
}
|