Function report | 
Source Code:mm\page_alloc.c | 
Create Date:2022-07-28 15:03:23 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| home page | Tree | 
| Annotation kernel can get tool activity | Download SCCT | Chinese | 
Name:Freeing function for a buddy system allocator
Proto:static inline void __free_one_page(struct page *page, unsigned long pfn, struct zone *zone, unsigned int order, int migratetype)
Type:void
Parameter:
| Type | Parameter | Name | 
|---|---|---|
| struct page * | page | |
| unsigned long | pfn | |
| struct zone * | zone | |
| unsigned int | order | |
| int | migratetype | 
| 910 | VM_BUG_ON(!zone_is_initialized(zone)) | 
| 911 | VM_BUG_ON_PAGE( Atomic flags, some possibly * updated asynchronously & Flags checked when a page is prepped for return by the page allocator, page) | 
| 913 | VM_BUG_ON(migratetype == - 1) | 
| 914 | If Value is more likely to compile time(!is_migrate_isolate(migratetype)) Then __mod_zone_freepage_state(zone, 1 << order, migratetype) | 
| 917 | VM_BUG_ON_PAGE(pfn & ((1 << order) - 1), page) | 
| 918 | VM_BUG_ON_PAGE(bad_range(zone, page), page) | 
| 920 | continue_merging : | 
| 922 | If compaction_capture(capc, page, order, migratetype) Then | 
| 923 | __mod_zone_freepage_state(zone, - (1 << order), migratetype) | 
| 925 | Return | 
| 927 | buddy_pfn = Locate the struct page for both the matching buddy in our* pair (buddy1) and the combined O(n+1) page they form (page) | 
| 930 | If Not pfn_valid_within(buddy_pfn) Then Go to done_merging | 
| 938 | If page_is_guard(buddy) Then clear_page_guard(zone, buddy, order, migratetype) | 
| 940 | Else del_page_from_free_area(buddy, & Write-intensive fields used from the page allocator [order]) | 
| 942 | combined_pfn = buddy_pfn & pfn | 
| 943 | page = page + combined_pfn - pfn | 
| 944 | pfn = combined_pfn | 
| 945 | order++ | 
| 947 | If max_order < Free memory management - zoned buddy allocator. Then | 
| 959 | buddy_pfn = Locate the struct page for both the matching buddy in our* pair (buddy1) and the combined O(n+1) page they form (page) | 
| 963 | If migratetype != buddy_mt && (is_migrate_isolate(migratetype) || is_migrate_isolate(buddy_mt)) Then Go to done_merging | 
| 968 | max_order++ | 
| 969 | Go to continue_merging | 
| 972 | done_merging : | 
| 973 | set_page_order(page, order) | 
| 983 | If order < Free memory management - zoned buddy allocator. - 2 && pfn_valid_within(buddy_pfn) && Not is_shuffle_order(order) Then | 
| 986 | combined_pfn = buddy_pfn & pfn | 
| 987 | higher_page = page + combined_pfn - pfn | 
| 988 | buddy_pfn = Locate the struct page for both the matching buddy in our* pair (buddy1) and the combined O(n+1) page they form (page) | 
| 989 | higher_buddy = higher_page + buddy_pfn - combined_pfn | 
| 994 | Return | 
| 998 | If is_shuffle_order(order) Then add_to_free_area_random(page, & Write-intensive fields used from the page allocator [order], migratetype) | 
| 1001 | Else Used for pages not on another list | 
| Name | Describe | 
|---|---|
| free_pcppages_bulk | Frees a number of pages from the PCP lists* Assumes all pages on list are in same zone, and of same order.* count is the number of pages to free.* If the zone was previously in an "all pages pinned" state then look to | 
| free_one_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  |