Function report |
Source Code:mm\hmm.c |
Create Date:2022-07-28 16:37:14 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:hmm_vma_handle_pte
Proto:static int hmm_vma_handle_pte(struct mm_walk *walk, unsigned long addr, unsigned long end, pmd_t *pmdp, pte_t *ptep, uint64_t *pfn)
Type:int
Parameter:
Type | Parameter | Name |
---|---|---|
struct mm_walk * | walk | |
unsigned long | addr | |
unsigned long | end | |
pmd_t * | pmdp | |
pte_t * | ptep | |
uint64_t * | pfn |
268 | hmm_vma_walk = private |
276 | fault = write_fault = false |
279 | hmm_pte_need_fault(hmm_vma_walk, orig_pfn, 0, & fault, & write_fault) |
281 | If fault || write_fault Then Go to fault |
283 | Return 0 |
286 | If Not pte_present(pte) Then |
287 | entry = Convert the arch-dependent pte representation of a swp_entry_t into an* arch-independent swp_entry_t. |
289 | If Not non_swap_entry(entry) Then |
290 | cpu_flags = pte_to_hmm_pfn_flags(range, pte) |
291 | hmm_pte_need_fault(hmm_vma_walk, orig_pfn, cpu_flags, & fault, & write_fault) |
293 | If fault || write_fault Then Go to fault |
295 | Return 0 |
302 | If is_device_private_entry(entry) Then |
303 | cpu_flags = flags[ pfn is valid. It has, at least, read permission.] | flags[ private device memory (ZONE_DEVICE)] |
305 | cpu_flags |= If is_write_device_private_entry(entry) Then flags[ CPU page table has write permission set] Else 0 |
307 | hmm_pte_need_fault(hmm_vma_walk, orig_pfn, cpu_flags, & fault, & write_fault) |
309 | If fault || write_fault Then Go to fault |
314 | Return 0 |
317 | If is_migration_entry(entry) Then |
318 | If fault || write_fault Then |
324 | Return 0 |
329 | Return -EFAULT |
330 | Else |
331 | cpu_flags = pte_to_hmm_pfn_flags(range, pte) |
332 | hmm_pte_need_fault(hmm_vma_walk, orig_pfn, cpu_flags, & fault, & write_fault) |
336 | If fault || write_fault Then Go to fault |
339 | If pte_devmap(pte) Then |
340 | pgmap = get_dev_pagemap(pte_pfn(pte), pgmap) |
342 | If Value for the false possibility is greater at compile time(!pgmap) Then Return -EBUSY |
345 | If Not is_zero_pfn(pte_pfn(pte)) Then |
347 | Return -EFAULT |
356 | Return 0 |
358 | fault : |
359 | If pgmap Then |
360 | put_dev_pagemap(pgmap) |
361 | pgmap = NULL |
Name | Describe |
---|---|
hmm_vma_walk_pmd |
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 |