- 论坛徽章:
- 0
|
现在 有 3个不连续的 物理页, 假设 页祯号分别是1,3,5
我现在想在 内核里 把 这 3个页代表 的 系统 内寸映设到 用戶空 见 应 该怎么 作呢 ?
我的 想法: (物理页是我用 kzalloc分配的, 然后向这几个 页写入特証数据.,用戶 mmap后 然后 读出来 比照)
内核中我现在是这样的
xxx_map(struct file *file, struct vm_area_struct *vma)
{
start = vma->vm_start;
while(size>0)
{
pfn = __pa(my_mem[idx++]) >> PAGE_SHIFT;
if (remap_pfn_range(vma,start,pfn,PAGE_SIZE,PAGE_SHARED)){
dbg("remap page range failed\n");
return -ENXIO;
}
start+= PAGE_SIZE;
size = (size>PAGE_SIZE)? size-PAGE_SIZE: 0;
}
}
但是 我用戶空见 测式程序是这 样 的
ret = mmap(NULL,4096*3,PROT_READ | PROT_WRITE,MAP_SHARED,fd,0);
if(ret == MAP_FAILED){
fprintf(stderr,"$$$$$$$$$$$$$$$$$$ we map failed!\n");
exit(-1);
}
ub.start = ret;
wbyte = 1;
p = (unsigned long *)ub.start;
fprintf(stderr,"first page------------------> p=%X\n",p);
for(idx = 0; idx < 62; idx++){
fprintf(stderr,"%X,",*p++);
if(wbyte++%30 == 0)
fprintf(stderr,"\n");
}
wbyte = 1;
p = (unsigned long *)(&ub.start[4096]);
fprintf(stderr,"second page------------------> p=%X\n",p);
for(idx = 0; idx < 62; idx++){
fprintf(stderr,"%X,",*p++);
if(wbyte++%30 == 0)
fprintf(stderr,"\n");
}
wbyte = 1;
p = (unsigned long *)(&ub.start[2*4096]);
fprintf(stderr,"third page------------------> p=%X\n",p);
for(idx = 0; idx < 62; idx++){
fprintf(stderr,"%X,",*p++);
if(wbyte++%30 == 0)
fprintf(stderr,"\n");
}
测试结果就 地一 个 页的 内容 是 正确的 , 2,3页错误 , 不知道为什么 ?? |
|