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

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

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

××××××××××××××××××××××××××××××××××××××××××××××

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

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

作用:前者用来访问物理IO设备,比如X用来访问显卡的物理内存,或嵌入式中访问GPIO。用法一般就是open,然后mmap,接着可以使用map之后的地址来访问物理内存。这其实就是实现用户空间驱动的一种方法。

后者一般可以用来查看kernel的变量,或者用作rootkit之类的。参考1和2描述了用来查看kernel变量这

在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之后的内存内容了。

linux mem设备是什么,linux下/dev/mem分析相关推荐

  1. linux黑洞设备的路径,linux dev 常见特殊设备介绍与应用(loop,null,zero,full,random)

    linux是文件型系统,所有硬件如软件都会在对于的目录下面有相应的文件表示.对于dev这个目录,我们知道它下面的文件,表示的是linux的设备.在windows系统中,设备大家很好理解,象硬盘,磁盘指 ...

  2. linux查找设备所在分片,Linux设备驱动统一模型解析

    soc节点指定了<0x0 0xe0000000 0x00100000>:此属性值指定对于1024KB范围的地址空间,在物理0x0处寻址的子节点映射到物理0xe0000000的父地址.通过这 ...

  3. linux黑洞设备的路径,linux基本指令

    1.如何查看当前进程,如何强制退出,如何查看当前路径? ps,ctrl+c/ctrl+z(ctrl+c强制中断程序的执行,ctrl+z是将任务中断,中断后还可被重启),pwd 2. 怎么清屏?怎么退出 ...

  4. linux 统一设备模型 pci,linux设备模型____宏观印象

    linux设备模型____宏观印象 最近一个机会需要研究一个marvell芯片的设备的驱动,涉及驱动和一些用户态相关部分,正好学习一下驱动和sysfs,本文先是原理,后面的文章是详细描述.本文依托的是 ...

  5. linux raw设备格式化,SUSE Linux 10配置裸设备(raw devices)

    SUSE Linux 10配置裸设备(raw devices) 裸设备,是没有经过格式化的分区或磁盘,也叫裸分区(原始分区),不被Unix通过文件系统来读取的特殊字符设备.它由应用程序负责对它进行读写 ...

  6. linux裸设备大小,SUSE Linux 十 配置裸设备(raw devices)

    SUSE Linux 10 配置裸设备(raw devices) 裸设备,是没有经过格式化的分区或磁盘,也叫裸分区(原始分区),不被Unix通过文件系统来读取的特殊字符设备.它由应用程序负责对 它进行 ...

  7. linux hub设备,USB在Linux里的结构框架是什么样的?USB Core和Hub是什么?

    USB博大精深不是一篇文章就能够解释清楚的.想要深入研究USB的话,USB协议(外加Host和OTG协议)是必要的知识,另外,国内有本<>也写的很好很详细(点击阅读原文,21ic嵌入式论坛 ...

  8. linux 统一设备模型 pci,Linux设备驱动模型摘抄

    Linux设备驱动模型摘抄Linux设备驱动模型摘抄Linux设备驱动模型摘抄Linux设备驱动模型摘抄Linux设备驱动模型摘抄 Linux设备驱动模型摘抄(1) Linux统一设备模型 简介 Li ...

  9. linux 声卡设备文件夹,Linux ALSA声卡驱动之三:PCM设备的创建

    4. 设备文件节点的建立(dev/snd/pcmCxxDxxp.pcmCxxDxxc)本文引用地址:http://www.eepw.com.cn/article/201612/341593.htm 4 ...

最新文章

  1. 注释转换——(小项目)
  2. hdu 5188 dfs+二分
  3. cocos2dx 3.2之Lua打飞机项目
  4. 《A Novel Pipeline Approach for Efficient Big Data Broadcasting》阅读报告
  5. 全局稳定性收敛平衡点为0吗_该平衡点处的小扰动稳定性判据是什?
  6. 转:Kafka事务使用和编程示例/实例
  7. 如何用余弦定理来进行文本相似度的度量
  8. “云原生”为何而生?
  9. oracle 数据库-数据字典一
  10. Centos 命令行添加VLAN TAG
  11. 2019秋季10月新番动漫推荐
  12. element 日期选择器el-date-picker 月份/日期范围控制
  13. C++练习题:计算standard_deviation
  14. 【专题】详解Python中的反射机制
  15. linux搭建本地YUM源配置详细步骤
  16. MS5607 气压计调试记录
  17. C语言实现QQ聊天室小项目 [完整源码]
  18. 开学季·东莞理工学院
  19. 李毅中:加快产业结构调整 促进工业转型升级
  20. 微信小程序语音识别、语音合成(微信同声传译)使用代码实例

热门文章

  1. shiro利用mysql动态授权_SpringBoot+Shiro学习之数据库动态权限管理和Redis缓存
  2. mysql多个外键删除设置_Mysql在删除集上使用多个外键创建表
  3. java复习系列[2] - Java多线程
  4. memcache面试
  5. SQL SERVER性能优化综述(转载)
  6. 洛谷P4092树——并查集
  7. C# Base64编码
  8. jdk w7环境变量配置
  9. HDU-4631 Sad Love Story 平面最近点对
  10. CDNDrive 第一个版本发布 布客新知第二次备份完成