我创建了一个简单的memtest程序。
但是,当我尝试运行它(当然使用 sudo)时,它会在以下行崩溃:
main -> test_all -> test_running -> for (j=0; j<=memsize; j++) p[j]=1-value;//(第一次赋值操作)
并且它没有指定错误。我正在考虑两种可能性:
1)错误的内存范围,应该选择另一个(哪个?
2)我的代码有问题(在哪里?
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define MEM_start 0xFD002000
#define MEM_end 0xFDFFFFFF
#define MEM_size 16769023
int test_running(int value) {
int i, j;
int flag=0;
int *p = (int *)MEM_start;
int memsize = (int)MEM_size;
for (i=0; i<=memsize; i++) {
for (j=0; j<=memsize; j++) p[j]=1-value;
p[i]=value;
if (p[i]!=value) { printf("Error at address: %pn", &p[i]); flag++; }
for (j=0; j<=memsize; j++) {
if ((j!=i)&&(p[j]==value)) {
printf("Error at address: %pn", &p[j]);
flag++;
}
}
}
return flag;
}
int test_chess() {
int i;
int flag=0;
int *p = (int *)MEM_start;
int memsize = (int)MEM_size;
for (i=0; i<=memsize; i++) p[i]=i%2;
for (i=0; i<=memsize; i++) if (p[i]!=i%2) { printf("Error at address: %pn", &p[i]); flag++; }
for (i=0; i<=memsize; i++) p[i]=(i+1)%2;
for (i=0; i<=memsize; i++) if (p[i]!=(i+1)%2) { printf("Error at address: %pn", &p[i]); flag++; }
return flag;
}
int test_random() {
int i, j;
int flag=0;
int *p = (int *)MEM_start;
int memsize = (int)MEM_size;
int buffer[32];
int buffer_size=32;
for (i=0; i<=memsize; i=i+buffer_size) {
for (j=0; j<=buffer_size; j++) buffer[j]=(0==(rand()%2));
for (j=0; j<=buffer_size; j++) p[i+j]=buffer[j];
for (j=0; j<=buffer_size; j++) if (p[i+j]!=buffer[i]) { printf("Error at address: %pn", &p[i+j]); flag++; }
}
return flag;
}
int test_all() {
int test=0;
int flag;
flag=test_running(1);
if (flag) { test++; printf("Running 1 - FAILn"); }
else printf("Running 1 - SUCCESSn");
flag=test_running(0);
if (flag) { test++; printf("Running 0 - FAIL"); }
else printf("Running 0 - SUCCESSn");
flag=test_chess();
if (flag) { test++; printf("Chess - FAILn"); }
else printf("Chess - SUCCESSn");
flag=test_chess();
if (flag) { test++; printf("Random - FAILn"); }
else printf("Random - SUCCESSn");
if (test!=0) { printf("SOME TESTS FAILED: %i", test); return 1; }
else { printf("ALL TESTS PASSED!!!"); return 0; }
}
int main() {
srand(time(NULL));
test_all();
return 0;
}
更新:以下链接非常有用:1) FixUnix:写入已知物理地址的设备
2)DesignSomething:从用户空间读取/写入物理地址的简单代码
您尝试读取/写入的地址0xFD002000
未映射到您的进程中。它对您的进程访问它无效。这就是为什么您在首次访问它时遇到分段错误的原因。
另外,请注意(在Windows,linux,Mac等主流桌面操作系统中),进程中的地址是虚拟地址,而不是实际的物理地址。更多信息请访问虚拟地址空间
使用malloc
或new
- 这取决于您使用的是 C 还是 C++。
还要避免石膏 - 它们通常意味着你做错了什么。