RTEMS-5
Annotated Report
Wed Aug 8 20:54:31 2018
40007b00 <rtems_stack_checker_begin_extension>:
static inline uint32_t _Per_CPU_Get_index( const Per_CPU_Control *cpu )
{
const Per_CPU_Control_envelope *per_cpu_envelope =
( const Per_CPU_Control_envelope * ) cpu;
return ( uint32_t ) ( per_cpu_envelope - &_Per_CPU_Information[ 0 ] );
40007b00: 07 33 33 33 sethi %hi(0xcccccc00), %g3
<== NOT EXECUTED
40007b04: 86 10 e0 cd or %g3, 0xcd, %g3 ! cccccccd <RAM_END+0x8c8ccccd>
<== NOT EXECUTED
40007b08: 03 10 02 44 sethi %hi(0x40091000), %g1
<== NOT EXECUTED
if ( stack->area == NULL ) {
40007b0c: 05 10 02 36 sethi %hi(0x4008d800), %g2
<== NOT EXECUTED
40007b10: 82 10 62 40 or %g1, 0x240, %g1
<== NOT EXECUTED
40007b14: 84 10 a2 7c or %g2, 0x27c, %g2
<== NOT EXECUTED
40007b18: 82 21 80 01 sub %g6, %g1, %g1
<== NOT EXECUTED
40007b1c: 83 38 60 04 sra %g1, 4, %g1
<== NOT EXECUTED
40007b20: 82 58 40 03 smul %g1, %g3, %g1
<== NOT EXECUTED
40007b24: 83 28 60 03 sll %g1, 3, %g1
<== NOT EXECUTED
40007b28: 86 00 80 01 add %g2, %g1, %g3
<== NOT EXECUTED
40007b2c: da 00 e0 04 ld [ %g3 + 4 ], %o5
<== NOT EXECUTED
40007b30: 80 a3 60 00 cmp %o5, 0
<== NOT EXECUTED
40007b34: 22 80 00 04 be,a 40007b44 <rtems_stack_checker_begin_extension+0x44>
<== NOT EXECUTED
40007b38: d0 01 a0 08 ld [ %g6 + 8 ], %o0
<== NOT EXECUTED
}
40007b3c: 81 c3 e0 08 retl
<== NOT EXECUTED
40007b40: 01 00 00 00 nop
<== NOT EXECUTED
stack->area = cpu_self->interrupt_stack_low;
40007b44: d0 20 e0 04 st %o0, [ %g3 + 4 ]
<== NOT EXECUTED
Stack_check_Dope_stack( stack );
40007b48: 92 10 20 a5 mov 0xa5, %o1
<== NOT EXECUTED
stack->size = (size_t) ( (char *) cpu_self->interrupt_stack_high -
40007b4c: c8 01 a0 0c ld [ %g6 + 0xc ], %g4
<== NOT EXECUTED
40007b50: 88 21 00 08 sub %g4, %o0, %g4
<== NOT EXECUTED
Stack_check_Dope_stack( stack );
40007b54: 94 10 00 04 mov %g4, %o2
<== NOT EXECUTED
stack->size = (size_t) ( (char *) cpu_self->interrupt_stack_high -
40007b58: c8 20 80 01 st %g4, [ %g2 + %g1 ]
<== NOT EXECUTED
Stack_check_Dope_stack( stack );
40007b5c: 82 13 c0 00 mov %o7, %g1
<== NOT EXECUTED
40007b60: 40 01 65 a6 call 400611f8 <memset>
<== NOT EXECUTED
40007b64: 9e 10 40 00 mov %g1, %o7
<== NOT EXECUTED
40007c70 <rtems_stack_checker_report_usage_with_plugin>:
*/
void rtems_stack_checker_report_usage_with_plugin(
const rtems_printer* printer
)
{
40007c70: 9d e3 bf a0 save %sp, -96, %sp
<== NOT EXECUTED
uint32_t cpu_max;
uint32_t cpu_index;
rtems_printf(
40007c74: 13 10 01 f2 sethi %hi(0x4007c800), %o1
<== NOT EXECUTED
40007c78: 90 10 00 18 mov %i0, %o0
<== NOT EXECUTED
40007c7c: 40 00 12 57 call 4000c5d8 <rtems_printf>
<== NOT EXECUTED
40007c80: 92 12 62 f8 or %o1, 0x2f8, %o1
<== NOT EXECUTED
" STACK USAGE BY THREAD\n"
"ID NAME LOW HIGH CURRENT AVAIL USED\n"
);
/* iterate over all threads and dump the usage */
rtems_task_iterate(
40007c84: 92 10 00 18 mov %i0, %o1
<== NOT EXECUTED
40007c88: 11 10 00 1e sethi %hi(0x40007800), %o0
<== NOT EXECUTED
40007c8c: 40 00 47 4a call 400199b4 <rtems_task_iterate>
<== NOT EXECUTED
40007c90: 90 12 22 84 or %o0, 0x284, %o0 ! 40007a84 <Stack_check_Dump_threads_usage>
<== NOT EXECUTED
Stack_check_Dump_threads_usage,
RTEMS_DECONST( rtems_printer *, printer )
);
cpu_max = rtems_get_processor_count();
40007c94: 40 00 46 30 call 40019554 <rtems_get_processor_count>
<== NOT EXECUTED
40007c98: 01 00 00 00 nop
<== NOT EXECUTED
for ( cpu_index = 0; cpu_index < cpu_max; ++cpu_index ) {
40007c9c: b4 92 20 00 orcc %o0, 0, %i2
<== NOT EXECUTED
40007ca0: 02 80 00 10 be 40007ce0 <rtems_stack_checker_report_usage_with_plugin+0x70>
<== NOT EXECUTED
40007ca4: 39 10 02 36 sethi %hi(0x4008d800), %i4
<== NOT EXECUTED
Stack_check_Dump_stack_usage(
40007ca8: 37 10 01 f2 sethi %hi(0x4007c800), %i3
<== NOT EXECUTED
40007cac: b8 17 22 7c or %i4, 0x27c, %i4
<== NOT EXECUTED
for ( cpu_index = 0; cpu_index < cpu_max; ++cpu_index ) {
40007cb0: ba 10 20 00 clr %i5
<== NOT EXECUTED
Stack_check_Dump_stack_usage(
40007cb4: b6 16 e3 80 or %i3, 0x380, %i3
<== NOT EXECUTED
40007cb8: 96 10 00 1d mov %i5, %o3
<== NOT EXECUTED
40007cbc: 90 10 00 1c mov %i4, %o0
<== NOT EXECUTED
40007cc0: 98 10 00 18 mov %i0, %o4
<== NOT EXECUTED
40007cc4: 94 10 00 1b mov %i3, %o2
<== NOT EXECUTED
40007cc8: 7f ff ff 29 call 4000796c <Stack_check_Dump_stack_usage>
<== NOT EXECUTED
40007ccc: 92 10 20 00 clr %o1
<== NOT EXECUTED
for ( cpu_index = 0; cpu_index < cpu_max; ++cpu_index ) {
40007cd0: ba 07 60 01 inc %i5
<== NOT EXECUTED
40007cd4: 80 a6 80 1d cmp %i2, %i5
<== NOT EXECUTED
40007cd8: 12 bf ff f8 bne 40007cb8 <rtems_stack_checker_report_usage_with_plugin+0x48>
<== NOT EXECUTED
40007cdc: b8 07 20 08 add %i4, 8, %i4
<== NOT EXECUTED
&Stack_check_Interrupt_stack[ cpu_index ],
cpu_index,
printer
);
}
}
40007ce0: 81 c7 e0 08 ret
<== NOT EXECUTED
40007ce4: 81 e8 00 00 restore
<== NOT EXECUTED
40007b68 <rtems_stack_checker_switch_extension>:
{
40007b68: 9d e3 bf 80 save %sp, -128, %sp
<== NOT EXECUTED
if ( sp < the_stack->area ) {
40007b6c: fa 06 20 d0 ld [ %i0 + 0xd0 ], %i5
<== NOT EXECUTED
40007b70: b8 07 60 08 add %i5, 8, %i4
<== NOT EXECUTED
40007b74: 13 10 01 f2 sethi %hi(0x4007c800), %o1
<== NOT EXECUTED
40007b78: 94 10 20 10 mov 0x10, %o2
<== NOT EXECUTED
40007b7c: 90 10 00 1c mov %i4, %o0
<== NOT EXECUTED
40007b80: 80 a7 80 1d cmp %fp, %i5
<== NOT EXECUTED
40007b84: 0a 80 00 0e bcs 40007bbc <rtems_stack_checker_switch_extension+0x54>
<== NOT EXECUTED
40007b88: 92 12 63 90 or %o1, 0x390, %o1
<== NOT EXECUTED
40007b8c: 40 01 64 e8 call 40060f2c <memcmp>
<== NOT EXECUTED
40007b90: 01 00 00 00 nop
<== NOT EXECUTED
if ( sp > (the_stack->area + the_stack->size) ) {
40007b94: c2 06 20 cc ld [ %i0 + 0xcc ], %g1
<== NOT EXECUTED
40007b98: 82 07 40 01 add %i5, %g1, %g1
<== NOT EXECUTED
40007b9c: 80 a7 80 01 cmp %fp, %g1
<== NOT EXECUTED
40007ba0: 18 80 00 0a bgu 40007bc8 <rtems_stack_checker_switch_extension+0x60>
<== NOT EXECUTED
40007ba4: b6 10 00 08 mov %o0, %i3
<== NOT EXECUTED
if ( !sp_ok || !pattern_ok ) {
40007ba8: 80 a2 20 00 cmp %o0, 0
<== NOT EXECUTED
40007bac: 12 80 00 08 bne 40007bcc <rtems_stack_checker_switch_extension+0x64>
<== NOT EXECUTED
40007bb0: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
}
40007bb4: 81 c7 e0 08 ret
<== NOT EXECUTED
40007bb8: 81 e8 00 00 restore
<== NOT EXECUTED
40007bbc: 40 01 64 dc call 40060f2c <memcmp>
<== NOT EXECUTED
40007bc0: 01 00 00 00 nop
<== NOT EXECUTED
40007bc4: b6 10 00 08 mov %o0, %i3
<== NOT EXECUTED
printk("BLOWN STACK!!!\n");
40007bc8: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007bcc: 40 00 12 60 call 4000c54c <printk>
<== NOT EXECUTED
40007bd0: 90 12 22 18 or %o0, 0x218, %o0 ! 4007ca18 <rtems_blkdev_imfs_node+0x80>
<== NOT EXECUTED
printk("task control block: 0x%08" PRIxPTR "\n", (intptr_t) running);
40007bd4: 92 10 00 18 mov %i0, %o1
<== NOT EXECUTED
40007bd8: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007bdc: 40 00 12 5c call 4000c54c <printk>
<== NOT EXECUTED
40007be0: 90 12 22 28 or %o0, 0x228, %o0 ! 4007ca28 <rtems_blkdev_imfs_node+0x90>
<== NOT EXECUTED
printk("task ID: 0x%08lx\n", (unsigned long) running->Object.id);
40007be4: d2 06 20 08 ld [ %i0 + 8 ], %o1
<== NOT EXECUTED
40007be8: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007bec: 40 00 12 58 call 4000c54c <printk>
<== NOT EXECUTED
40007bf0: 90 12 22 48 or %o0, 0x248, %o0 ! 4007ca48 <rtems_blkdev_imfs_node+0xb0>
<== NOT EXECUTED
printk(
40007bf4: d2 06 20 0c ld [ %i0 + 0xc ], %o1
<== NOT EXECUTED
40007bf8: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007bfc: 40 00 12 54 call 4000c54c <printk>
<== NOT EXECUTED
40007c00: 90 12 22 60 or %o0, 0x260, %o0 ! 4007ca60 <rtems_blkdev_imfs_node+0xc8>
<== NOT EXECUTED
_Thread_Get_name(running, name, sizeof(name));
40007c04: 94 10 20 20 mov 0x20, %o2
<== NOT EXECUTED
40007c08: 92 07 bf e0 add %fp, -32, %o1
<== NOT EXECUTED
40007c0c: 40 00 59 58 call 4001e16c <_Thread_Get_name>
<== NOT EXECUTED
40007c10: 90 10 00 18 mov %i0, %o0
<== NOT EXECUTED
printk("task name string: %s\n", name);
40007c14: 92 07 bf e0 add %fp, -32, %o1
<== NOT EXECUTED
40007c18: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007c1c: 40 00 12 4c call 4000c54c <printk>
<== NOT EXECUTED
40007c20: 90 12 22 78 or %o0, 0x278, %o0 ! 4007ca78 <rtems_blkdev_imfs_node+0xe0>
<== NOT EXECUTED
(unsigned long) stack->size,
40007c24: d2 06 20 cc ld [ %i0 + 0xcc ], %o1
<== NOT EXECUTED
(intptr_t) stack->area,
40007c28: d4 06 20 d0 ld [ %i0 + 0xd0 ], %o2
<== NOT EXECUTED
printk(
40007c2c: 96 02 80 09 add %o2, %o1, %o3
<== NOT EXECUTED
40007c30: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007c34: 40 00 12 46 call 4000c54c <printk>
<== NOT EXECUTED
40007c38: 90 12 22 90 or %o0, 0x290, %o0 ! 4007ca90 <rtems_blkdev_imfs_node+0xf8>
<== NOT EXECUTED
if (!pattern_ok) {
40007c3c: 80 a6 e0 00 cmp %i3, 0
<== NOT EXECUTED
40007c40: 12 80 00 05 bne 40007c54 <rtems_stack_checker_switch_extension+0xec>
<== NOT EXECUTED
40007c44: 96 07 60 18 add %i5, 0x18, %o3
<== NOT EXECUTED
40007c48: d2 06 20 0c ld [ %i0 + 0xc ], %o1
<== NOT EXECUTED
40007c4c: 40 00 4b 13 call 4001a898 <_Terminate>
<== NOT EXECUTED
40007c50: 90 10 20 08 mov 8, %o0
<== NOT EXECUTED
printk(
40007c54: 94 10 00 1c mov %i4, %o2
<== NOT EXECUTED
40007c58: 92 10 20 10 mov 0x10, %o1
<== NOT EXECUTED
40007c5c: 11 10 01 f2 sethi %hi(0x4007c800), %o0
<== NOT EXECUTED
40007c60: 40 00 12 3b call 4000c54c <printk>
<== NOT EXECUTED
40007c64: 90 12 22 c0 or %o0, 0x2c0, %o0 ! 4007cac0 <rtems_blkdev_imfs_node+0x128>
<== NOT EXECUTED
40007c68: 10 bf ff f9 b 40007c4c <rtems_stack_checker_switch_extension+0xe4>
<== NOT EXECUTED
40007c6c: d2 06 20 0c ld [ %i0 + 0xc ], %o1
<== NOT EXECUTED