RH_KABI_RESERVE的使用
- struct mm_struct {
- ..........
- #if defined(__GENKSYMS__) || !defined(CONFIG_SPAPR_TCE_IOMMU)
- /* We're adding a list_head, so we need to take two reserved
- * fields, unfortunately there are no handy RH_KABI macros for
- * that case */
- RH_KABI_RESERVE(1)
- RH_KABI_RESERVE(2)
- #else
- struct list_head iommu_group_mem_list;
- #endif
- #ifdef CONFIG_X86_INTEL_MPX
- RH_KABI_USE(3, void __user *bd_addr)
- #else
- /* RHEL7: consumed by x86, avoid re-use by other arches */
- RH_KABI_RESERVE(3)
- #endif
- /* This would be in rss_stat[MM_SHMEMPAGES] if not for kABI */
- RH_KABI_USE(4, atomic_long_t mm_shmempages)
- #if IS_ENABLED(CONFIG_HMM)
- /* HMM need to track few things per mm */
- RH_KABI_USE(5, struct hmm *hmm)
- #else
- RH_KABI_RESERVE(5)
- #endif
- RH_KABI_RESERVE(6)
- RH_KABI_RESERVE(7)
- RH_KABI_RESERVE(8)
- };
在struct mm_struct 或者 task_struct 之类的结构中,我们经常能看到 RH_KABI_RESERVE 这种成员,这种成员其实就是为了增加扩展性所留的一手。
这个可以类比tcp协议头,也有tcp_option,原理也是类似的,那么,怎么使用这些成员呢?
比如我想在task里面,记录一些私有的数据,这个数据由于类型只有 unsigned long 类型,所以这个既可以直接用来记录普通数据,也可以用来存放一个指针,然后再指向一个地址,这样存放的内容就多了。
- #define _RH_KABI_RESERVE(n) unsigned long rh_reserved##n
- #define _RH_KABI_RESERVE_P(n) void (*rh_reserved##n)(void)
- #define RH_KABI_RESERVE(n) _RH_KABI_RESERVE(n);
举个栗子:
- /* This would be in rss_stat[MM_SHMEMPAGES] if not for kABI */
- RH_KABI_USE(4, atomic_long_t mm_shmempages)
没有用的变量,是 RH_KABI_RESERVE,那么已经使用的,则是 RH_KABI_USE ,我们看到 mm_shmempages 使用的是4号位置。
之后,就可以直接对 mm_shmempages 成员进行赋值了。
比如在 mm_init 中正常使用 mm_shmempages
- static struct mm_struct *mm_init(struct mm_struct *mm, struct task_struct *p)
- {
- atomic_set(&mm->mm_users, 1);
- atomic_set(&mm->mm_count, 1);
- init_rwsem(&mm->mmap_sem);
- INIT_LIST_HEAD(&mm->mmlist);
- mm->core_state = NULL;
- atomic_long_set(&mm->nr_ptes, 0);
- memset(&mm->rss_stat, 0, sizeof(mm->rss_stat));
- atomic_long_set(&mm->mm_shmempages, 0);-----------正常当成员使用,因为 RH_KABI_USE 这个宏已经帮我们替换好了。
不过需要注意的是,要及时清理,比如我们使用了task_struct里面的RH_KABI_RESERVE,但是在fork的时候忘了清理该成员,导致了一些问题。
RH_KABI_RESERVE的使用的更多相关文章
随机推荐
- pthread mutex
pthead_mutex_t mutex; 1:create: pthread_mutex_init(pthread_mutex_t* mutex, const pthread_mutexattr_t ...
- Github上关于iOS的各种开源项目集合2(强烈建议大家收藏,查看,总有一款你需要)
资源list:Github上关于大数据的开源项目.论文等合集 Awesome Big Data A curated list of awesome big data frameworks, resou ...
- CS229 7.1应用机器学习中的一些技巧
本文所讲述的是怎么样去在实践中更好的应用机器学习算法,比如如下经验风险最小化问题: 当求解最优的 后,发现他的预测误差非常之大,接下来如何处理来使得当前的误差尽可能的小呢?这里给出以下几个选项,下面 ...
- 关于python中生成器之Send方法
#send主要是用于外部与生成器对象的交互def func1(): # 生成器函数 print("ok1") x = 10 # 函数内局部变量x赋值为10 print(x) x = ...
- es6(14)--iterator for ...of循环
//iterator for ...of循环 { let arr=['hello','world']; let map=arr[Symbol.iterator](); console.log(map. ...
- 导入sql文件报错:1071 Specified key was too long; max key length is 767 bytes
ref: https://stackoverflow.com/questions/1814532/1071-specified-key-was-too-long-max-key-length-is-7 ...
- 安全测试8_Web安全实战1(DVWA部署)
1.渗透神器的打造(火狐浏览器的打造) Firebug HackBar(渗透插件) Tamper Data(抓包.截包.改包等功能) Proxy Switcher(代理设置) 2.PHP环境安装(ph ...
- SVG 学习<六> SVG的transform
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- 【Selenium-WebDriver自学】Selenium-IDE不同的浏览器(八)
==================================================================================================== ...
- 《算法》第四章部分程序 part 19
▶ 书中第四章部分程序,包括在加上自己补充的代码,有边权有向图的邻接矩阵,FloydWarshall 算法可能含负环的有边权有向图任意两点之间的最短路径 ● 有边权有向图的邻接矩阵 package p ...