mmap说明

    如果同时指定了MAP_FIXED标志并且将起始地址start设置为0,则mmap调用的结果会是什么?
    答:在sys_mmap系统调用中并没有看到对这种情况的排斥,可以暂时先理解成不同的架构对应不同的情况,这种情况是否允许在各个架构上的实现是不同的,而sys_mmap作为一个和平台无关的系统调用这里并不会对这种情况进行排斥;
而在实际的具体的平台的操作时,比如x86下,当你的addr没有指向适当的mmap区域而且又设置了MAP_FIXED的标志,这是返回的结果为-1,也就是失败;应该这样说,api(库函数)是对系统调用的封装,所以说
我认为对于后面这种情况的判断应该是在库函数中而系统调用外判断的,即mmap是一个库函数,而sys_mmap确是一个系统调用,系统调用中不判断,但是库函数中会判断;
</pre><pre name="code" class="cpp">

#include <stdio.h> 
#include <fcntl.h>
#include <string.h>
#include <sys/mman.h>
#include <sys/stat.h>
#define FILE_LENGTH 0x400

int main(int argc, char *argv[])
{
   int fd;
   void *map_memory;

   /* Open a file to be mapped. */
   fd = open("/tmp/shared_file", O_RDWR | O_CREAT, S_IRUSR | S_IWUSR);
  // lseek(fd, FILE_LENGTH-1, SEEK_SET);
   //write(fd, "", 1);
   //lseek(fd, 0, SEEK_SET);

   /* Create map memory. */
   map_memory = mmap(0x9999, 10, PROT_WRITE, MAP_SHARED, fd, 0);  //从0x后返回第一个合适的地址;
 //  map_memory = mmap(0x9999, 10, PROT_WRITE, MAP_SHARED!MAP_FIXED, fd, 0);  如果指定MAP_FIXED的标志,则addr指定为0x10000(65536,即2的16次方)后的值都是可以的;小于该值产生断错误;
    close(fd);

   /* Write to mapped memory. */
   if (strlen(argv[1]) < FILE_LENGTH)
      sprintf((char *)map_memory, "%s", argv[1]);   //sprintf的返回值是第二个参数的格式字符串的长度
    //printf("%d",map_memory);                       //第一个参数为char型指针,指向将要写入的字符串的缓冲区。
  sleep(100);
   return 0;
}//运行的时候先使用gcc mmap.c;再使用./a.out hello&(&表示后台运行);然后用cat/proc/14667/maps

上面的结果是在ubuntu下运行的结果;可以看到当指定MAP_FIXED标志从addr小于0x10000的地方映射都会出错,就是因为低端的一段区域不能作为映射区;



参考链接:http://blog.csdn.net/denny_233/article/details/7549561

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值