函数逻辑报告 |
Source Code:mm\hugetlb.c |
Create Date:2022-07-27 16:56:07 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:Examine the existing reserve map and determine how many* huge pages in the specified range [f, t) are NOT currently* represented. This routine is called before a subsequent* call to region_add that will actually modify the reserve
函数原型:static long region_chg(struct resv_map *resv, long f, long t)
返回类型:long
参数:
类型 | 参数 | 名称 |
---|---|---|
struct resv_map * | resv | |
long | f | |
long | t |
372 | chg等于0 |
374 | 加自旋锁 |
375 | retry_locked : |
376 | adds_in_progress自加 |
382 | 如果adds_in_progress大于region_cache_count则 |
385 | VM_BUG_ON(adds_in_progress - region_cache_count > 1) |
387 | adds_in_progress自减 |
388 | 自旋锁解锁 |
390 | trg等于kmalloc(trg的长度, GFP_KERNEL) |
394 | 加自旋锁 |
395 | 添加链表项 |
396 | region_cache_count自加 |
397 | 转到:retry_locked |
400 | chg等于Must be called with resv->lock held. Calling this with count_only == true* will count the number of pages to be added but will not modify the linked* list. |
402 | 自旋锁解锁 |
403 | 返回:chg |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |