我正在尝试映射物理内存的某些区域,然后将其放入结构中。映射正常,分配正常。 (我认为是这样,因为没有段错误。)问题是当我尝试从结构中读取一些值时。
我的结构是这样的:
struct some_struct {
unsigned long a;
unsigned long b;
unsigned long c;
unsigned long d;
unsigned long e;
unsigned long f;
};
然后我映射内存:
void *pc = (void *) mmap(0, PageSize * 2, PROT_READ | PROT_WRITE, MAP_SHARED, fd, addr_start);
不要太仔细地看参数。我 100% 确定这可以正常工作。之后我这样做:
struct some_struct *ptr = ((struct some_struct *)(pc + some_offset));
然后我试试:
printf("DDR[%p] -> 0x%x\n", &(ptr->a));
我得到了成员(member)的地址。它指向内存中的物理地址。但是以下让我出现段错误:
printf("DDR[%p] -> 0x%x\n", &(ptr->a), ptr->a);
我不确定在分配结构时是否必须使用物理地址或虚拟地址。或者我遗漏了一些非常明显的东西。
最佳答案
您的代码不足以提供完整的帮助。
我只能提供您的代码中可能存在的问题:
来自 man mmap
:
1) 如果你想读写,你的代码中应该有open("./file.txt", O_RDWR);
。
The prot argument describes the desired memory protection of the mapping
(and must not conflict with the open mode of the file).
2) 您的偏移量必须
为k*sysconf(_SC_PAGE_SIZE)
。
例如,在我的系统上,页面大小是 4096
。因此,您的 addr_start
必须类似于 4*4096
,但不能类似于 12
或任意数字。
offset must be a multiple of the page size as returned by sysconf(_SC_PAGE_SIZE)
3) 在启用所有警告的情况下编译您的代码,并查看编译器将向您写入什么。如果您使用 gcc
,则添加 -Wall
标志。您的 printf
语句中已经有一个未定义的行为(这已经在评论中提到)并且使用 -Wall
编译器会告诉您它。
4) 如果您仍然希望在没有 -Wall
标志的情况下进行编译,请确保您已将所有需要的 header 包含到您的程序中。我已经包括:
//mmap
#include <sys/mman.h>
//printf
#include <stdio.h>
//open
#include <stdlib.h>
#include <sys/types.h>
#include <fcntl.h>
//sysconf
#include <unistd.h>
希望这会有所帮助。
附言我看到你在我写完这篇文章后就已经解决了你的问题(但我仍然不明白你的问题)。所以我只是留下这个,以防其他填充有类似行为,但问题不同。
关于c - 指向结构的指针。读取成员值的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26460098/