Linux下用memory方式访问PCIE空间

测试环境:Ubuntu 14.04LTS

在Windows下,我们 用RW everything很容易可以看到PCIE所有的config space,但是我们最近想在Linux下dump PCIE config space,首先我们尝试用IO read的方式,

也就是通常我们会用CF8和CFC的方式,但是很遗憾这种方式只能读出来256个字节,那么后面的0x100~0x1FF怎么去读,就是下面我们要解决的问题。

1,首先我们需要获取PCIE在memory中的映射地址,我们看ACPI的手册,会发现有一个MCFG的东西,官方解释如下:

“MCFG” PCI Express memory mapped configuration space base address Description Table

PCI Firmware Specification, Revision 3.0

See the ACPI Link Document under the heading "PCI Sig".

也就是说MCFG里面有保存PCIE的基地址,这个的获取方式,可以利用acpidump这个工具,如果没有的话,需要先安装

sudo apt-get install acpidump

成功之后,我们键入acpidump,会dump出来很多register的值,慢慢下拉我们会找到如下的

从PCI Firmware Specification Revision 3.0上面可以看到,MCFG的定义:

看到失眠的Configuration space base address allocation structure,偏移地址是44,也就是0x2c,然后再参考Table4-3:

再回到acpidump读出来的MCFG,PCIE的基地址就是F0000000,这个值不是固定的,在其他的机子上会有不同。

2,为了验证上面的基地址就是PCIE的,我们需要写一个简单的程序,试试看。

[email protected]:/mnt/hgfs/LinuxTools/PCITools/pci_dump$ sudo ./pci_dump -m

The offset address value is 0xf0000000

The value at 0xf0000000 is 0x71908086

好的,我们读出来memory address f0000000的低2个字节是8086,所以基地址肯定没有问题,之后就可以根据PCIE spec上的协议,组合PCIE 的Bus,Device,Function和Register的值来获取对应地址的值了。

如果不放心上面的验证,也可以通过lspci这个tool去读下bus 0, device 0,funtion 0,register 0的值,进一步验证下。

时间: 2024-10-21 20:51:50

Linux下用memory方式访问PCIE空间的相关文章

linux下c/c++方式访问curl的帮助手册

自:http://blog.chinaunix.net/u1/47395/showart_1768832.html 有个业务需求需要通过curl 代理的方式来访问外网 百度了一把,测试可以正常使用.记录下来方便后续查找 example:   1. http://curl.haxx.se/libcurl/c/example.html  2. http://www.libcurl.org/book:  1. http://www.linuxdevcenter.com/pub/a/linux/2005

Linux下Oracle启动、建立表空间、用户、授权、数据库导入导出

1.1进入到sqlplus启动实例 [[email protected] ~]$ su - oracle                                 --“切换到oracle用户”[[email protected] ~]$ lsnrctl start                               --“打开监听”[[email protected] ~]$ sqlplus /nolog                                --“进入到

Linux 下IO端口编程访问

以前写的一篇笔记,偶尔翻出来了,放在这里做个纪念 Linux 下IO端口编程访问 这里记录的方法是在用户态访问IO端口,不涉及驱动程序的编写. 首先要包含头文件 /usr/include/asm/io.h ioperm() 在 unistd.h 中声明.用来打开对IO端口的访问权限,要求程序执行时必须有root 权限.只可以打开0x00到0x3ff 这一地址段的IO端口. ioperm( from, num, turn_on) 比如: #include<asm/io.h> #include&l

在Linux下的中断方式读取按键驱动程序

// 在Linux下的中断方式读取按键驱动程序 //包含外部中断 休眠 加入poll机制 // 采用异步通知的方式 // 驱动程序发 ---> app接收 (通过kill_fasync()发送) // 为了使设备支持异步通知机制,驱动程序中涉及以下3项工作: // 1. 支持F_SETOWN命令,能在这个控制命令处理中设置filp->f_owner为对应进程ID. // 不过此项工作已由内核完成,设备驱动无须处理. // 2. 支持F_SETFL命令的处理,每当FASYNC标志改变时,驱动程序

在Linux下以pptp方式拨入VPN网络

如果你需要在Linux中拨入虚拟网管(http://www.vpnlife.com)中,那就需要安装Linux下相应VPN的客户端,本文将介绍以pptp方式拨入虚拟网管的VPN的方法. 本操作均在文本终端下完成,不涉及图形操作,本文假设你对Linux命令有一定的了解,这里不对所出现的命令进行解释.以下操作均在root用户下操作完成,并假设你的Linux系统已经安装了编译环境.1.下载pptp客户端wget http://nchc.dl.sourceforge.net/sourceforge/pp

Linux 下三种方式设置环境变量

1.在Windows 系统下,很多软件安装都需要配置环境变量,比如 安装 jdk ,如果不配置环境变量,在非软件安装的目录下运行javac 命令,将会报告找不到文件,类似的错误. 2.那么什么是环境变量?简单说,就是指定一个目录,运行软件的时候,相关的程序将会按照该目录寻找相关文件. 设置变量对于一般人最实用的功能就是: 不用拷贝某些dll文件到系统目录中了,而path 这一系统变量就是系统搜索dll文件的一系列路径 在Linux系统下,如果你下载并安装应用程序,很有可能在键入它的名称的时候出现

linux下通过软连接实现访问项目路径外面的资源

在javaweb项目开发中,图片上传是个比较常见的场景.一般都是在项目路径下建个文件夹,然后上传到该文件夹下:这样这个图片就可以和静态资源一样被直接访问.这样的好处就是访问这图片特别方便:缺点是重新部署时要手动把图片备份,不然图片就丢失了. 今天通过在网上查阅一些资料,找到了如下2个方案: (1)配置tomcat虚拟目录 该方案的好处是虚拟目录下的文件也可以类似于静态资源一样这样访问 美中不足的是上传图片还需要上传到虚拟目录的绝对路径,在网上没看到怎么获取虚拟目录的绝对路径的方法:个人想到的解决

10种linux下磁盘快照方式恢复系统

导读 大家都知道windows系统有一个磁盘快照的功能,在windows2003中系统恢复开始依赖于一个叫做硬盘快照服务(Volume Snapshot Service)的服务,他能够自动创建系统快照--包括正在使用的文件--然后将这些文件转换为可恢复的节点文件,在之后的文件系统NTFS这个格式的分区具有系统恢复快照功能快照可以保存,这样在磁盘误操作后就可以完成恢复系统了.linux有没有磁盘快照呢?他的系统误操作怎么进行恢复呢?今天小编带您用10种方式玩转linux磁盘快照的恢复. Linux

[Z] Linux下进程的文件访问权限

原文链接:http://blog.csdn.net/chosen0ne/article/details/10581883 对进程校验文件访问权限包括两个部分,一是确定进程的角色(属于哪个用户或者组),二是确定对应的角色是否具有该操作的权限. 首先看第一部分.默认情况下,进程的有效角色就是当前执行这个进程的用户及其所在组.但是,文件具有设置用户ID位和设置组ID位(stat.st_mode的S_ISUID和S_ISGID),用于改变这种默认的行为,将进程的有效角色设置为文件所属的用户和组.这主要用