准备写一个EMMC测速程序,在写完后得到Bus Error错误。
错误源代码如下,使用 O_CREAT
参数创建一个新的文件。
#include <stdint.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/mman.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#define __HELP__ \
({\
printf("%s %d %s\n",__FILE__,__LINE__,__func__);\
fflush(stdout);\
})
#define FILESIZE 5 * 1024 * 1024
int main(void)
{
int file = open("/mnt/emmcp0/tmp/wt.txt", O_RDWR|O_CREAT);
printf("file = %d\n", file);
char* base = mmap(NULL,
FILESIZE, PROT_READ|PROT_WRITE, MAP_SHARED, file, 0);
printf("base = %#x\n", base);
char* poffset = base;
int i = 0;
__HELP__;
while (1) {
if (i == 10) i = 0;
__HELP__;
if (poffset - base >= FILESIZE) return 0;
__HELP__;
*poffset++ = i++;
__HELP__;
}
__HELP__;
ftruncate(file, FILESIZE);
munmap(base, FILESIZE);
return 0;
}
程序在 *poffset++ = i++;
处发生Bus Error错误。
解决方案,在内存映射前,将文件大小修改一下,不能以空文件进行mmap映射。修改后如下:
#include <stdint.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/mman.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#define FILESIZE 5 * 1024 * 1024
int main(void)
{
int file = open("/mnt/emmcp0/tmp/wt.txt", O_RDWR|O_CREAT);
/** @important
* 在这里先将文件的大小修改一下,
*/
ftruncate(file, FILESIZE);
char* base = mmap(NULL,
FILESIZE, PROT_READ|PROT_WRITE, MAP_SHARED, file, 0);
printf("base = %#x\n", base);
char* poffset = base;
int i = 0;
while (1) {
if (i == 10) i = 0;
if (poffset - base >= FILESIZE) return 0;
*poffset++ = i++;
}
munmap(base, FILESIZE);
return 0;
}