在linux下,分配RAMBlock时可以将内存块映射到文件中,详细内容可见file_ram_alloc函数,下面是该函数的主要部分:
ram_addr_t memory,
const char *path)
{
char *filename;
void *area;
int fd;
unsigned long hpagesize;
hpagesize = gethugepagesize(path);
if (asprintf(&filename, "%s/qemu_back_mem.XXXXXX", path) == -1) {
return NULL;
}
/*由于mkstemp函数创建的临时文件不能自动删除,所以执行完mkstemp函数后要调用unlink函数,unlink函数删除文件的目录入口,但临时文件还可以通过文件描述符进行访问,直到最后一个打开的进程关闭文件操作符,或者程序退出后临时文件被自动彻底地删除。*/
fd = mkstemp(filename);
unlink(filename);
free(filename);
memory = (memory+hpagesize-1) & ~(hpagesize-1);
if (ftruncate(fd, memory))
perror("ftruncate");
//mmap将一个文件或者其它对象映射进内存,MAP_PRIVATE表示建立一个写入时拷贝的私有映射。内存区域的写入不会影响到原文件。
area = mmap(0, memory, PROT_READ | PROT_WRITE, MAP_PRIVATE, fd, 0);
block->fd = fd;
return area;
}
//查询文件系统相关的信息 返回系统经过优化的传输块大小
static long gethugepagesize(const char *path)
{
struct statfs fs;
int ret;
do {
ret = statfs(path, &fs);
} while (ret != 0 && errno == EINTR);
if (ret != 0) {
perror(path);
return 0;
}
if (fs.f_type != HUGETLBFS_MAGIC)
fprintf(stderr, "Warning: path not on HugeTLBFS: %s\n", path);
return fs.f_bsize;
}