/dev/mem: 物理内存的全镜像。可以用来访问物理内存。

/dev/kmem: kernel看到的虚拟内存的全镜像。可以用来访问kernel的内容。

/dev/mem 用来访问物理IO设备比如X用来访问显卡的物理内存或嵌入式中访问GPIO。用

法一般就是open然后mmap接着可以使用map之后的地址来访问物理内存。这其实就是实现

用户空间驱动的一种方法。

/dev/kmem 一般可以用来查看kernel的变量或者用作rootkit之类的。 通过/dev/mem设备文件和mmap系统调用可以将线性地址描述的物理内存映射到进程

的地址空间然后就可以直接访问这段内存了。  比如标准VGA 16色模式的实模式地址是A000:0000而线性地址则是A0000。设定显

存大小为0x10000则可以如下操作      mem_fd  = open( "/dev/mem", O_RDWR );

vga_mem = mmap( 0, 0x10000, PROT_READ | PROT_WRITE, MAP_SHARED, mem_fd, 0xA0000 );

close( mem_fd );  然后直接对vga_mem进行访问就可以了。当然如果是操作VGA显卡还要获得I/O

端口的访问权限以便进行直接的I/O操作用来设置模式/调色板/选择位面等等  在工控领域中还有一种常用的方法用来在内核和应用程序之间高效传递数据:  1) 假定系统有64M物理内存则可以通过lilo通知内核只使用63M而保留1M物理内    存作为数据交换使用(使用 mem=63M 标记)。

2) 然后打开/dev/mem设备并将63M开始的1M地址空间映射到进程的地址空间。 使用/dev/kmem查看kernel变量 从lwn.net学到的

实例代码如下

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <stdarg.h>

#include <fcntl.h>

#include <unistd.h>

#include <errno.h> #include <sys/types.h>

#include <sys/stat.h>

#include <sys/poll.h>

#include <sys/mman.h> int page_size;

#define PAGE_SIZE page_size

#define PAGE_MASK (~(PAGE_SIZE-1)) void get_var (unsigned long addr) {

off_t ptr = addr & ~(PAGE_MASK);

off_t offset = addr & PAGE_MASK;

int i = 0;

char *map;

static int kfd = -1;         kfd = open("/dev/kmem",O_RDONLY);

if (kfd < 0) {

perror("open");                 exit(0);

}         map = mmap(NULL,PAGE_SIZE,PROT_READ,MAP_SHARED,kfd,offset);         if (map == MAP_FAILED) {

perror("mmap");

exit(-1);

}

/* 假定这里是字符串 */

printf("%s\n",map+ptr);         return;

} int main(int argc, char **argv) {

FILE *fp;

char addr_str[11]="0x";

char var[51];

unsigned long addr;

char ch;

int r;

if (argc != 2) {

fprintf(stderr,"usage: %s System.map\n",argv[0]);

exit(-1);

}         if ((fp = fopen(argv[1],"r")) == NULL) {

perror("fopen");

exit(-1);

}         do {

r = fscanf(fp,"%8s %c %50s\n",&addr_str[2],&ch,var);

if (strcmp(var,"modprobe_path")==0)

break;

} while(r > 0);

if (r < 0) {

printf("could not find modprobe_path\n");

exit(-1);

}

page_size = getpagesize();

addr = strtoul(addr_str,NULL,16);

printf("found modprobe_path at (%s) %08lx\n",addr_str,addr);

get_var(addr);

} 运行 # ./tmap /boot/System.map

found modprobe_path at (0xc03aa900) c03aa900 /sbin/modprobe

区别

1. /dev/mem: 物理内存的全镜像。可以用来访问物理内存。

2. /dev/kmem: kernel看到的虚拟内存的全镜像。可以用来访问kernel的

内容。

作用

1. 前者用来访问物理IO设备比如X用来访问显卡的物理内存或嵌入式

中访问GPIO。用法一般就是open然后mmap接着可以使用map之后的

地址来访问物理内存。这其实就是实现用户空间驱动的一种方法。

2. 后者一般可以用来查看kernel的变量或者用作rootkit之类的。参考

1和2描述了用来查看kernel变量这个问题。

参考

1. http://lwn.net/Articles/147902/

2. http://lkml.org/lkml/2005/8/11/301

LINUX

在2.4可以直接打开/dev/mem然后读取。

在2.6直接打开/dev/mem后只可以读取前0x101000部分的内容(ubuntu)。

大约是1MB加4KB。读取后面的内容将出现"open not permitted"错误。

解决的方法是使用mmap()。routine如下

f = open("/dev/mem", O_RDONLY);

my_mem = mmap (0, 0x1000, PROT_READ, MAP_SHARED, f, 0x34f000);

if (my_mem == MAP_FAILED)

printf("map failed %s\n",strerror(errno));

通过my_mem就可以得到0x101000之后的内存内容了

arm_linux_device_mem内存映射的更多相关文章

  1. 内存映射文件MemoryMappedFile使用

    参考资料: http://blog.csdn.net/bitfan/article/details/4438458 所谓内存映射文件,其实就是在内存中开辟出一块存放数据的专用区域,这区域往往与硬盘上特 ...

  2. JAVA NIO FileChannel 内存映射文件

      文件通道总是阻塞式的. 文件通道不能创建,只能通过(RandomAccessFile.FileInputStream.FileOutputStream)getChannel()获得,具有与File ...

  3. Python之mmap内存映射模块(大文本处理)说明

    背景: 通常在UNIX下面处理文本文件的方法是sed.awk等shell命令,对于处理大文件受CPU,IO等因素影响,对服务器也有一定的压力.关于sed的说明可以看了解sed的工作原理,本文将介绍通过 ...

  4. 使用ZwMapViewOfSection创建内存映射文件总结

    标 题: [原创]使用ZwMapViewOfSection创建内存映射文件总结 作 者: 小覃 时 间: 2012-06-15,02:28:36 链 接: http://bbs.pediy.com/s ...

  5. C#大文件读取和查询--内存映射

    笔者最近需要快速查询日志文件,文件大小在4G以上. 需求如下: 1.读取4G左右大小的文件中的指定行,程序运行占用内存不超过500M. 2.希望查询1G以内容,能控制在20s左右. 刚开始觉得这个应该 ...

  6. 用C#实现的内存映射

    当文件过大时,无法一次性载入内存时,就需要分次,分段的载入文件 主要是用了以下的WinAPI LPVOID MapViewOfFile(HANDLE hFileMappingObject, DWORD ...

  7. 【转】C#大文件读取和查询--内存映射

    笔者最近需要快速查询日志文件,文件大小在4G以上. 需求如下: 1.读取4G左右大小的文件中的指定行,程序运行占用内存不超过500M. 2.希望查询1G以内容,能控制在20s左右. 刚开始觉得这个应该 ...

  8. Atitit.病毒木马的快速扩散机制原理nio 内存映射MappedByteBuffer

    Atitit.病毒木马的快速扩散机制原理nio 内存映射MappedByteBuffer 1. Java NIO(New Input/Output)1 1.1. 变更通知(因为每个事件都需要一个监听者 ...

  9. Java中用内存映射处理大文件

    在处理大文件时,如果利用普通的FileInputStream 或者FileOutputStream 抑或RandomAccessFile 来进行频繁的读写操作,都将导致进程因频繁读写外存而降低速度.如 ...

随机推荐

  1. .Net 更容易的使用配置文件 SuperConfig

    一.原始配置文件的问题 我们在做开发时,不管是B/S还是C/S,现在几乎所有的项目都会碰到使用配置文件,简单点的如链接字符串.上传路径啊,一些API的接口地址等等.复杂点就更多了,如ActiveMQ的 ...

  2. px、pt、em、rem 的区别

    px(pixel) 像素,是屏幕上显示数据的最基本的点,表示相对大小(不同分辨率上px显示不同) pt(point) 印刷行业常用的单位(磅),等于1/72英寸,表示绝对长度 em em是相对长度单位 ...

  3. JSP与HTML及前后分离

    JSP是什么 首先要知道JSP的本质其实是个Servlet,index.jsp在访问的时候首先会自动将该页面翻译生一个index_jsp.java文件,即Servlet代码. 打开这个类你会发现这个类 ...

  4. word文字覆盖问题

    我们在编写word文档时,偶尔会遇到这个问题: 在一个段落中的某个位置修改文字时,直接就把后面的字体给覆盖了,导致后面的句子也不完整了. 解决经过: 之前遇到这种情况,非常恼火,直接新建一个word文 ...

  5. python 列表操作方法详解

    列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表是一个数据的集合,集合内可以放任何数据类型,可对集合方便的增删改查操作.Python已经内置确定序列的长度以及确定最大和最 ...

  6. BZOJ 3530: [Sdoi2014]数数 [AC自动机 数位DP]

    3530: [Sdoi2014]数数 题意:\(\le N\)的不含模式串的数字有多少个,\(n=|N| \le 1200\) 考虑数位DP 对于长度\(\le n\)的,普通套路DP\(g[i][j ...

  7. URL中特殊符号的处理

    问题描述 我们在对接第三方系统的时候通常需要get或post来传输数据,但此时如果参数中存在&% #*!包括空格等特殊符号的时候就无法正常请求具体表现在参数获取不正确或者获取不到参数,甚至有时 ...

  8. 网络编程之socketserver

    网络编程之socketserver """ socketserver.py 中的5个基础类 +------------+ | BaseServer | +-------- ...

  9. windows搭建web服务器

    1.安装web管理工具 控制面板--->程序和功能--->打开或关闭功能 2.将internet信息服务中的所有选项全部勾上,并点击确定. 3.打开浏览器,输入http://localho ...

  10. Gentoo(贱兔)Linux安装笔记

      网上对于Gentoo Linux 的教程少之又少,所以这里我将自己的安装记录贴出来 希望对正在研究Gentoo 的小伙伴们有帮助! 1.确认连接到互联网,使用net-setup工具配置网络 roo ...