Function report |
Source Code:fs\userfaultfd.c |
Create Date:2022-07-28 20:20:33 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:The locking rules involved in returning VM_FAULT_RETRY depending on* FAULT_FLAG_ALLOW_RETRY, FAULT_FLAG_RETRY_NOWAIT and* FAULT_FLAG_KILLABLE are not straightforward
Proto:vm_fault_t handle_userfault(struct vm_fault *vmf, unsigned long reason)
Type:vm_fault_t
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct vm_fault * | vmf | |
| unsigned long | reason |
| 357 | ret = VM_FAULT_SIGBUS |
| 372 | If flags & (Getting shut down | Dumped core ) Then Go to out |
| 387 | VM_BUG_ON(reason & ~(missing pages tracking | wrprotect pages tracking )) |
| 388 | VM_BUG_ON(!(reason & missing pages tracking ) ^ !!(reason & wrprotect pages tracking )) |
| 390 | If atures requested from the userspace & UFFD_FEATURE_SIGBUS Then Go to out |
| 415 | ret = VM_FAULT_NOPAGE |
| 416 | Go to out |
| 444 | Go to out |
| 451 | ret = VM_FAULT_RETRY |
| 452 | If flags & Don't drop mmap_sem and wait when retrying Then Go to out |
| 459 | private = current process |
| 463 | waken = false |
| 468 | blocking_state = If return_to_userland Then TASK_INTERRUPTIBLE Else Convenience macros for the sake of set_current_state: |
| 471 | spin_lock_irq( & lock) |
| 483 | spin_unlock_irq( & lock) |
| 488 | Else must_wait = Same functionality as userfaultfd_must_wait below with modifications for* hugepmd ranges. |
| 494 | If Value is more likely to compile time(must_wait && !READ_ONCE(leased ) && (return_to_userland ? !signal_pending(current process) : !fatal_signal_pending(current process))) Then |
| 498 | schedule() |
| 499 | ret |= VM_FAULT_MAJOR |
| 516 | If READ_ONCE(waken) || READ_ONCE(leased ) || If return_to_userland Then signal_pending(current process) Else fatal_signal_pending(current process) Then Break |
| 521 | schedule() |
| 527 | If return_to_userland Then |
| 528 | If signal_pending(current process) && Not fatal_signal_pending(current process) Then |
| 546 | lock for reading |
| 547 | ret = VM_FAULT_NOPAGE |
| 580 | out : |
| 581 | Return ret |
| Name | Describe |
|---|---|
| do_anonymous_page | We enter with non-exclusive mmap_sem (to exclude vma changes,* but allow concurrent faults), and pte mapped but not yet locked.* We return with mmap_sem still held, but pte unmapped and unlocked. |
| hugetlb_no_page | |
| __do_huge_pmd_anonymous_page | |
| do_huge_pmd_anonymous_page |
| 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 |