page_to_pfn小问题,谢谢
#define __pfn_to_page(pfn) (mem_map + (pfn))#define __page_to_pfn(page) ((unsigned long)((page) - mem_map))
第一个我宏我看明白了,就是mem_map + pfn*sizeof(mem_map) 得到数组中的PAGE地址,也就是 &mem_map
第二个,怎么想不明白呢,不应该是((unsigned long)((page) - mem_map)) / sizeof(mem_map) 得到相应的PFN吗,谢谢回复! #define __pfn_to_page(pfn) (mem_map + ((pfn) - ARCH_PFN_OFFSET))
#define __page_to_pfn(page) ((unsigned long)((page) - mem_map) + ARCH_PFN_OFFSET)
为什么没人回复啊,这是原定义,我把ARCH_PFN_OFFSET写成0了, 写个测试代码试试就知道了~ 回复 1# wzw200
两个指向struct page的指针相减。
回复 4# xs3c
在吗,相减,不是 PFN啊,相减对吗,想不通 wzw200 发表于 2014-05-21 13:34 static/image/common/back.gif
回复 4# xs3c
mem_map中放的是指针,不是结构体 由 page_to_pfn和pfn_to_page 的总结
2010-06-28 18:15
PFN => Page Frame Number 页帧号
在内核源代码中 找出如下代码。
#define PHYS_PFN_OFFSET (CONFIG_PHYS_OFFSET >> PAGE_SHIFT)
#define pfn_to_page(pfn) (mem_map + ((pfn) - PHYS_PFN_OFFSET))
#define page_to_pfn(page) ((unsigned long)((page) - mem_map) + PHYS_PFN_OFFSET)
这涉及到一个结构体加减的问题。
不思考一会还真看不太清楚(基本功啊,汗)。
如下规则:
1:两同类型结构体相减,得到的是两结地址之间可以有多少个对象。
一般情况是大地址减去一个小地址以得到两同类型指针之间的对象个数,但也可以小地址减大地址,只不过得出的一负数(这里小地址大地址是指同一数组中的前与后对象)。当然也可以不是一个数组中的两人对象去相减,但这样的结果我就是不知道是什么,我得出的结果始终是0。
2:结构体加上一个常数,得到的是相当于在当前结构体为基地址的数组的第常数个对象的地址。
3:结构体减去一个常数,得到的是相当于在当前结构体为参照数组中向前第常数个对象的地址。
4:两个结构指针相加,会提示[ error: invalid operands to binary + (have ‘struct X *’ and ‘struct X *’) ]这是无意义的操作,标准C不支持的操作。
#define page_to_pfn(page) ((unsigned long)((page) - mem_map) + PHYS_PFN_OFFSET)
根据给出页地址求出对应的页帧号。两个结构相减,得出的是丙都之间的对象个数,加上起始帧号偏移,即给出页地址的相对绝对页号。
#define pfn_to_page(pfn) (mem_map + ((pfn) - PHYS_PFN_OFFSET))
根据给出的页帧号计算出对应的页帧号。页基地址加上页帧号是相对偏移的页地址,减去一个偏移页帧号即页对象对应的地址。
我试试吧,刚查到的,C的 基本功啊,很少用这个功能 回复 6# humjb_1983
mem_map 应该是page的数组
typedef struct abc
{
int a;
}ABC;
int main()
{
ABC tp;
printf("qqqqqqqqq:%d\n",&tp-&tp);
return 0;
}
哎,发现自己什么都不会 回复 9# wzw200
慢慢看就好了。
页:
[1]
2