我正在为运行Linux2.6.37的ARM设备开发。我正在尝试尽快切换IO引脚。我制作了一个小内核模块和一个用户空间应用程序。我尝试了两件事:使用ioremap直接从内核空间操作GPIO控制寄存器。mmap()GPIO控制寄存器,无需缓存并从用户空间使用它们。这两种方法都有效,但第二种方法比第一种方法慢3倍左右(在示波器上观察到)。我想我禁用了所有缓存机制。当然,我想获得两个世界中最好的:用户空间的灵active和易于开发以及内核空间的速度。有人知道为什么mmap()可能比ioremap()慢吗?这是我的代码:内核模块代码staticintti81xx_usmap_mmap(struc
我正在为运行Linux2.6.37的ARM设备开发。我正在尝试尽快切换IO引脚。我制作了一个小内核模块和一个用户空间应用程序。我尝试了两件事:使用ioremap直接从内核空间操作GPIO控制寄存器。mmap()GPIO控制寄存器,无需缓存并从用户空间使用它们。这两种方法都有效,但第二种方法比第一种方法慢3倍左右(在示波器上观察到)。我想我禁用了所有缓存机制。当然,我想获得两个世界中最好的:用户空间的灵active和易于开发以及内核空间的速度。有人知道为什么mmap()可能比ioremap()慢吗?这是我的代码:内核模块代码staticintti81xx_usmap_mmap(struc
有人知道为什么mmap()返回MAP_FAILED而不是NULL吗?在大多数系统上,MAP_FAILED似乎是(void*)-1。为什么mmap()不直接使用NULL呢?我知道地址0x0在技术上是一个有效的内存页面,而(void*)-1永远不会是一个有效的页面。然而我的猜测是mmap()实际上永远不会返回页面0x0。例如,在Windows上,VirtualAlloc()在出错时返回NULL。假设mmap()永远不会返回0x0是否安全?据推测,对mmap()的成功调用应该将可用内存返回给调用者。地址0x0永远不可用,因此它永远不会在成功时返回。在这种情况下,使用0x0作为失败标记似乎是明
有人知道为什么mmap()返回MAP_FAILED而不是NULL吗?在大多数系统上,MAP_FAILED似乎是(void*)-1。为什么mmap()不直接使用NULL呢?我知道地址0x0在技术上是一个有效的内存页面,而(void*)-1永远不会是一个有效的页面。然而我的猜测是mmap()实际上永远不会返回页面0x0。例如,在Windows上,VirtualAlloc()在出错时返回NULL。假设mmap()永远不会返回0x0是否安全?据推测,对mmap()的成功调用应该将可用内存返回给调用者。地址0x0永远不可用,因此它永远不会在成功时返回。在这种情况下,使用0x0作为失败标记似乎是明
(正确的代码在“更新5”中)在此示例C代码中,我尝试映射从0x100000000到0x200000000的内存范围:#include#include#include#includeintmain(void){uint64_t*rr_addr=0;uint64_ti=17179869184;printf("\nsizeof(size_t):%llu\n",sizeof(size_t));printf("(uint64_t)0x100000000:%llx\n",(uint64_t)0x100000000);printf("1L在不同的系统(Linux、gcc)上,我得到不同的结果:结果1
(正确的代码在“更新5”中)在此示例C代码中,我尝试映射从0x100000000到0x200000000的内存范围:#include#include#include#includeintmain(void){uint64_t*rr_addr=0;uint64_ti=17179869184;printf("\nsizeof(size_t):%llu\n",sizeof(size_t));printf("(uint64_t)0x100000000:%llx\n",(uint64_t)0x100000000);printf("1L在不同的系统(Linux、gcc)上,我得到不同的结果:结果1
为了好玩而使用mmap,我有以下代码:(..snip..)fd=open("/home/me/straight_a.txt",O_RDONLY);if(fd==-1){perror("open");exit(1);}m=mmap(NULL,4096,PROT_READ|PROT_WRITE,MAP_FILE|MAP_PRIVATE,fd,0);if(m==MAP_FAILED){perror("mmap");exit(1);}printf("mis%p\n",m);printf("*m=%c\n",*m);printf("*(m+1)=%c\n",*(m+1));(..snip..)这
为了好玩而使用mmap,我有以下代码:(..snip..)fd=open("/home/me/straight_a.txt",O_RDONLY);if(fd==-1){perror("open");exit(1);}m=mmap(NULL,4096,PROT_READ|PROT_WRITE,MAP_FILE|MAP_PRIVATE,fd,0);if(m==MAP_FAILED){perror("mmap");exit(1);}printf("mis%p\n",m);printf("*m=%c\n",*m);printf("*(m+1)=%c\n",*(m+1));(..snip..)这
假设我使用/dev/zero为mmap分配了一个大内存(40MB),如下所示。fd=open("/dev/zero",O_RDWR);a=mmap(0,4096e4,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_FILE,fd,0);我的理解是,当页面被带入物理内存时,内核会将内存初始化为零(我想现代Linux内核使用Demandpaging)。因此,例如,当第一页被触及并因此被带入物理内存时,内核会将其所有4096字节初始化为零,然后当第二页被触及时,它会执行相同的操作,依此类推。我的理解正确吗? 最佳答案
假设我使用/dev/zero为mmap分配了一个大内存(40MB),如下所示。fd=open("/dev/zero",O_RDWR);a=mmap(0,4096e4,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_FILE,fd,0);我的理解是,当页面被带入物理内存时,内核会将内存初始化为零(我想现代Linux内核使用Demandpaging)。因此,例如,当第一页被触及并因此被带入物理内存时,内核会将其所有4096字节初始化为零,然后当第二页被触及时,它会执行相同的操作,依此类推。我的理解正确吗? 最佳答案