c - 指向结构的指针。读取成员值的段错误

标签 c linux pointers memory struct

我正在尝试映射物理内存的某些区域,然后将其放入结构中。映射正常,分配正常。 (我认为是这样,因为没有段错误。)问题是当我尝试从结构中读取一些值时。

我的结构是这样的:

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/

相关文章:

c - 通过第三方插件在我的应用程序中实现绘图的更好方法是什么?

c - x86 asm 崩溃的应用程序

linux - 让AppleScript发送电子邮件,然后通过shell脚本重新启动计算机?

c - 遍历C中进程的进程层次结构

python - 让弹出窗口居中于父窗口 - Glade、GTK、Python

c - 如何在 C 中多次调用 sem_open?

c - 将特定结构传递给 C 中的函数

c - C 程序错误 - 解释

c - 指针问题和困惑

c - 波特率为 9600 的串行读写,无奇偶校验,数据位 8 和停止位 2。无法与设备通信