Function report |
Source Code:mm\percpu.c |
Create Date:2022-07-28 14:27:19 |
Last Modify:2022-05-23 13:52:24 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:pcpu_alloc - the percpu allocator*@size: size of area to allocate in bytes*@align: alignment of area (max PAGE_SIZE)*@reserved: allocate from the reserved chunk if available*@gfp: allocation flags* Allocate percpu area of @size bytes aligned at @align
Proto:static void __percpu *pcpu_alloc(size_t size, size_t align, bool reserved, gfp_t gfp)
Type:void
Parameter:
Type | Parameter | Name |
---|---|---|
size_t | size | |
size_t | align | |
bool | reserved | |
gfp_t | gfp |
1591 | is_atomic = (gfp & GFP_KERNEL) != GFP_KERNEL |
1593 | warn_limit = 10 |
1607 | If Value for the false possibility is greater at compile time(align < PCPU_MIN_ALLOC_SIZE) Then align = PCPU_MIN_ALLOC_SIZE |
1610 | size = @a is a power of 2 value (size, PCPU_MIN_ALLOC_SIZE) |
1618 | Return NULL |
1621 | If Not is_atomic Then |
1627 | If gfp & __GFP_NOFAIL Then mutex_lock( & pcpu_alloc_mutex) |
1629 | Else if mutex_lock_killable( & pcpu_alloc_mutex) Then Return NULL |
1633 | spin_lock_irqsave( & pcpu_lock, flags) |
1637 | chunk = Optional reserved chunk. This chunk reserves part of the first* chunk and serves it for reserved allocations. When the reserved* region doesn't exist, the following variable is NULL. |
1640 | If off < 0 Then |
1641 | err = "alloc from reserved chunk failed" |
1642 | Go to fail_unlock |
1646 | If off >= 0 Then Go to area_found |
1649 | err = "alloc from reserved chunk failed" |
1650 | Go to fail_unlock |
1653 | restart : |
1655 | When slot < pcpu_nr_slots cycle |
1659 | If off < 0 Then |
1660 | If slot < chunks in slots below this are subject to being sidelined on failed alloc Then pcpu_chunk_move(chunk, 0) |
1662 | Continue |
1666 | If off >= 0 Then Go to area_found |
1672 | spin_unlock_irqrestore( & pcpu_lock, flags) |
1679 | If is_atomic Then |
1685 | chunk = pcpu_create_chunk(pcpu_gfp) |
1686 | If Not chunk Then |
1691 | spin_lock_irqsave( & pcpu_lock, flags) |
1693 | Else |
1694 | spin_lock_irqsave( & pcpu_lock, flags) |
1697 | Go to restart |
1699 | area_found : |
1700 | pcpu_stats_area_alloc(chunk, size) |
1701 | spin_unlock_irqrestore( & pcpu_lock, flags) |
1704 | If Not is_atomic Then |
1707 | page_start = PFN_DOWN(off) |
1712 | WARN_ON( no [de]population allowed ) |
1716 | spin_lock_irqsave( & pcpu_lock, flags) |
1717 | If ret Then |
1719 | err = "failed to populate" |
1720 | Go to fail_unlock |
1723 | spin_unlock_irqrestore( & pcpu_lock, flags) |
1729 | If The number of empty populated pages, protected by pcpu_lock. The* reserved chunk doesn't contribute to the count. < PCPU_EMPTY_POP_PAGES_LOW Then pcpu_schedule_balance_work() |
1733 | for_each_possible_cpu(cpu) |
1737 | kmemleak_alloc_percpu(ptr, size, gfp) |
1739 | trace_percpu_alloc_percpu(reserved, is_atomic, size, align, base address of this chunk , off, ptr) |
1742 | Return ptr |
1744 | fail_unlock : |
1745 | spin_unlock_irqrestore( & pcpu_lock, flags) |
1746 | fail : |
1749 | If Not is_atomic && do_warn && warn_limit Then |
1752 | dump_stack() |
1753 | If Not --warn_limit Then pr_info("limit reached, disable warning\n") |
1756 | If is_atomic Then |
1758 | pcpu_atomic_alloc_failed = true |
1759 | pcpu_schedule_balance_work() |
1760 | Else |
1763 | Return NULL |
Name | Describe |
---|---|
__alloc_percpu_gfp | __alloc_percpu_gfp - allocate dynamic percpu area*@size: size of area to allocate in bytes*@align: alignment of area (max PAGE_SIZE)*@gfp: allocation flags* Allocate zero-filled percpu area of @size bytes aligned at @align |
__alloc_percpu | allocate one copy of the object for every present |
__alloc_reserved_percpu | __alloc_reserved_percpu - allocate reserved percpu area*@size: size of area to allocate in bytes*@align: alignment of area (max PAGE_SIZE)* Allocate zero-filled percpu area of @size bytes aligned at @align* from reserved percpu area if arch has set it up; |
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 |