Function report |
Source Code:arch\x86\kernel\traps.c |
Create Date:2022-07-28 07:32:05 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:Our handling of the processor debug registers is non-trivial.* We do not clear them on entry and exit from the kernel. Therefore* it is possible to get a watchpoint trap here from inside the kernel.* However, the code in
Proto:__attribute__((__externally_visible__)) void do_debug(struct pt_regs *regs, long error_code)
Type:void
Parameter:
Type | Parameter | Name |
---|---|---|
struct pt_regs * | regs | |
long | error_code |
715 | tsk = current process |
716 | user_icebp = 0 |
734 | set_debugreg(0, 6) |
748 | dr6 &= ~single-step |
763 | If Not dr6 && ser_mode(regs) determines whether a register set came from user* mode Then user_icebp = 1 |
770 | If kprobe_debug_handler(regs) Then Go to exit |
774 | If notify_die(DIE_DEBUG, "debug", regs, (long) & dr6, error_code, SIGTRAP) == Clean way to return from the notifier and stop further calls. Then Go to exit |
782 | debug_stack_usage_inc() |
787 | If v8086_mode(regs) Then |
788 | handle_vm86_trap((structkernel_vm86_regs * )regs, error_code, X86_TRAP_DB) |
791 | debug_stack_usage_dec() |
792 | Go to exit |
795 | If WARN_ON_ONCE((dr6 & single-step ) && !ser_mode(regs) determines whether a register set came from user* mode) Then |
803 | Set thread flags in other task's structures.* See asm/thread_info.h for TIF_xxxx flags available: |
804 | flags &= ~X86_EFLAGS_TF |
807 | If Debug status used for traps, single steps, etc... & (single-step | DR_TRAP_BITS) || user_icebp Then send_sigtrap(regs, error_code, si_code) |
810 | debug_stack_usage_dec() |
812 | exit : |
Source code conversion tool public plug-in interface | X |
---|---|
Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |