函数逻辑报告 |
Source Code:mm\slub.c |
Create Date:2022-07-27 17:21:28 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:allocate_slab
函数原型:static struct page *allocate_slab(struct kmem_cache *s, gfp_t flags, int node)
返回类型:struct page
参数:
类型 | 参数 | 名称 |
---|---|---|
struct kmem_cache * | s | |
gfp_t | flags | |
int | node |
1626 | flags与等于gfp_allowed_mask |
1628 | 如果gfpflags_allow_blocking(flags)则开中断() |
1638 | 如果alloc_gfp按位与Caller can reclaim 且oo_order(oo)大于oo_order(min)则alloc_gfp等于alloc_gfp按位或__GFP_NOMEMALLOC的值按位与__GFP_RECLAIM按位或__GFP_NOFAIL的值的反 |
1642 | 如果此条件成立可能性小(为编译器优化)(!page)则 |
1650 | 如果此条件成立可能性小(为编译器优化)(!page)则转到:out |
1655 | objects等于oo_objects(oo) |
1657 | 用于SLUB分配器,指向slab的指针等于s |
1658 | __SetPageSlab(page) |
1659 | 如果Return true only if the page has been allocated with* ALLOC_NO_WATERMARKS and the low watermark was not* met implying that the system is under some pressure.则SetPageSlabPfmemalloc(page) |
1662 | kasan_poison_slab(page) |
1664 | start等于page_address(page) |
1666 | setup_page_debug(s, page, start) |
1668 | shuffle等于shuffle_freelist(s, page) |
1670 | 如果非shuffle则 |
1671 | start等于fixup_red_left(s, start) |
1672 | start等于setup_object(s, page, start) |
1673 | first free object 等于start |
1676 | next等于setup_object(s, page, next) |
1677 | set_freepointer(s, p, next) |
1680 | set_freepointer(s, p, NULL) |
1684 | frozen等于1 |
1686 | out : |
1687 | 如果gfpflags_allow_blocking(flags)则禁止中断() |
1689 | 如果非page则返回:NULL |
1692 | inc_slabs_node(s, page_to_nid(page), objects) |
1694 | 返回:page |
名称 | 描述 |
---|---|
new_slab |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |