Function report |
Source Code:fs\coredump.c |
Create Date:2022-07-28 20:30:54 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:do_coredump
Proto:void do_coredump(const kernel_siginfo_t *siginfo)
Type:void
Parameter:
| Type | Parameter | Name |
|---|---|---|
| const kernel_siginfo_t * | siginfo |
| 573 | retval = 0 |
| 575 | size_t * argv = NULL |
| 576 | argc = 0 |
| 579 | bool need_suid_safe = false |
| 580 | bool core_dumped = false |
| 581 | core_dump_count = Atomic operations that C can't guarantee us. Useful for* resource counting etc..(0) |
| 594 | audit_core_dumps(si_signo) |
| 602 | cred = prepare_creds - Prepare a new set of credentials for modification* Prepare a new set of task credentials for modification |
| 614 | need_suid_safe = true |
| 617 | retval = coredump_wait(si_signo, & core_state) |
| 618 | If retval < 0 Then Go to fail_creds |
| 623 | ispipe = rmat_corename will inspect the pattern parameter, and output a* name into corename, which must have space for at least* CORENAME_MAX_SIZE bytes plus one byte for the zero terminator. |
| 625 | If ispipe Then |
| 631 | If ispipe < 0 Then |
| 634 | Go to fail_unlock |
| 637 | If limit == 1 Then |
| 657 | Go to fail_unlock |
| 659 | limit = RLIM_INFINITY |
| 661 | dump_count = atomic_inc_return( & core_dump_count) |
| 662 | If core_pipe_limit && core_pipe_limit < dump_count Then |
| 666 | Go to fail_dropcount |
| 669 | helper_argv = kmalloc_array - allocate memory for an array.*@n: number of elements.*@size: element size.*@flags: the type of memory to allocate (see kmalloc). |
| 671 | If Not helper_argv Then |
| 674 | Go to fail_dropcount |
| 678 | helper_argv[argi] = NULL |
| 688 | kfree(helper_argv) |
| 689 | If retval Then |
| 694 | Else |
| 696 | open_flags = O_CREAT | O_RDWR | O_NOFOLLOW | O_LARGEFILE | O_EXCL |
| 699 | If limit < minimal dump size Then Go to fail_unlock |
| 702 | If need_suid_safe && corename[0] != '/' Then |
| 707 | Go to fail_unlock |
| 715 | If Not need_suid_safe Then |
| 731 | If need_suid_safe Then |
| 744 | get_fs_root( Filesystem information: , & root) |
| 745 | task_unlock( & Set up the first task table, touch at your own risk!. Base=0,* limit=0x1fffff (=2MB)) |
| 746 | file = file_open_root(dentry, mnt, corename, open_flags, 0600) |
| 749 | Else |
| 752 | If IS_ERR(file) Then Go to fail_unlock |
| 755 | inode = file_inode(file) |
| 756 | If i_nlink > 1 Then Go to close_fail |
| 758 | If d_unhashed - is dentry hashed*@dentry: entry to check* Returns true if the dentry passed is not currently hashed. Then Go to close_fail |
| 764 | If Not S_ISREG(i_mode) Then Go to close_fail |
| 772 | If Not uid_eq(i_uid, current_fsuid()) Then Go to close_fail |
| 774 | If (i_mode & 0677) != 0600 Then Go to close_fail |
| 776 | If Not (f_mode & Has write method(s) ) Then Go to close_fail |
| 778 | If do_truncate(dentry, 0, 0, file) Then Go to close_fail |
| 783 | retval = Helper to unshare the files of the current task.* We don't want to expose copy_files internals to* the exec layer of the kernel. |
| 784 | If retval Then Go to close_fail |
| 786 | If displaced Then put_files_struct(displaced) |
| 788 | If Not dump_interrupted() Then |
| 793 | If ispipe && core_pipe_limit Then wait_for_dump_helpers(file) |
| 795 | close_fail : |
| 798 | fail_dropcount : |
| 799 | If ispipe Then atomic_dec( & core_dump_count) |
| 801 | fail_unlock : |
| 804 | coredump_finish(mm, core_dumped) |
| 806 | fail_creds : |
| 808 | fail : |
| 809 | Return |
| Name | Describe |
|---|---|
| get_signal |
| 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 |