Function report |
Source Code:mm\page_alloc.c |
Create Date:2022-07-28 15:04:46 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:Spill all the per-cpu pages from all CPUs back into the buddy allocator.* When zone parameter is non-NULL, spill just the single zone's pages.* Note that this can be extremely slow as the draining happens in a workqueue.
Proto:void drain_all_pages(struct zone *zone)
Type:void
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct zone * | zone |
| 2894 | If WARN_ON_ONCE(!mm_percpu_wq) Then Return |
| 2903 | If Not zone Then Return |
| 2905 | mutex_lock( & pcpu_drain_mutex) |
| 2914 | for_each_online_cpu(cpu) |
| 2917 | bool has_pcps = false |
| 2919 | If zone Then |
| 2920 | pcp = per_cpu_ptr(pageset, cpu) |
| 2921 | If number of pages in the list Then has_pcps = true |
| 2923 | Else |
| 2924 | do nothing (z) |
| 2925 | pcp = per_cpu_ptr(pageset, cpu) |
| 2926 | If number of pages in the list Then |
| 2927 | has_pcps = true |
| 2928 | Break |
| 2933 | If has_pcps Then pumask_set_cpu - set a cpu in a cpumask*@cpu: cpu number (< nr_cpu_ids)*@dstp: the cpumask pointer |
| 2940 | drain = per_cpu_ptr( & pcpu_drain, cpu) |
| 2943 | INIT_WORK( & work, drain_local_pages_wq) |
| 2946 | for_each_cpu(cpu, & cpus_with_pcps) |
| Name | Describe |
|---|---|
| __alloc_pages_direct_reclaim | The really slow allocator path where we enter direct reclaim |
| madvise_inject_error | Error injection support for memory error handling. |
| shake_page | When a unknown page type is encountered drain as many buffers as possible* in the hope to turn the page into a LRU or free page, which we can handle. |
| read_page_owner | |
| set_migratetype_isolate |
| 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 |