Page MenuHomeFreeBSD

i386: stop guessing the address of the trap frame in ddb backtrace.
ClosedPublic

Authored by kib on Nov 11 2019, 10:35 PM.
Tags
None
Referenced Files
Unknown Object (File)
Oct 23 2024, 10:37 AM
Unknown Object (File)
Oct 23 2024, 10:37 AM
Unknown Object (File)
Oct 23 2024, 10:37 AM
Unknown Object (File)
Oct 23 2024, 10:37 AM
Unknown Object (File)
Oct 23 2024, 10:19 AM
Unknown Object (File)
Oct 6 2024, 7:45 PM
Unknown Object (File)
Sep 5 2024, 5:32 PM
Unknown Object (File)
Aug 17 2024, 11:15 PM
Subscribers

Details

Summary

Save the address of the trap frame in %ebp on kernel entry. This automatically provides it in struct i386_frame.f_frame to unwinder.

While there, more accurately handle the terminating frames,

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 27460

Event Timeline

Looks good to me in general.

sys/i386/i386/db_trace.c
383

This comment is a little bit hard to read.
Maybe start with "This can be the case for" or something like that.

384

After the change, "--- trap" won't be printed in this case, but probably that's okay?

412

The new long condition is a little bit harder to parse than the previous code.
Maybe keep the switch statement but modify the if statement, so that the userland condition falls through to SYSCALL case.

switch (frame_type) {
case TRAP:
case INTERRUPT:
        if ((tf->tf_eflags & PSL_VM) == 0 &&
            (tf->tf_cs & SEL_RPL_MASK) == 0)
                break;
        /* FALLTHROUGH */
case SYSCALL:
        ebp = 0;
        eip = 0;
        break;
}
This revision is now accepted and ready to land.Nov 12 2019, 12:10 PM
kib marked 2 inline comments as done.Nov 12 2019, 3:29 PM
kib added inline comments.
sys/i386/i386/db_trace.c
384

But that is the part of the improvement IMO. The kthread does not have trap frame on top of the stack.

I can add a frame type for fork_trampoline() just to print e.g. 'kthread start', but could as well leave it as is. It is really the last frame.

kib marked an inline comment as done.

Handle avg' suggestions.

Improve comment.
Restore switch(), but use TRAPF_USERMODE().
Print something after last frame of kthread.

This revision now requires review to proceed.Nov 12 2019, 3:30 PM

Looks great!

sys/i386/i386/db_trace.c
384

Yes, I agree, that's okay.

This revision is now accepted and ready to land.Nov 12 2019, 3:46 PM