网站大量收购独家精品文档,联系QQ:2885784924

总线地址和物理地址.pptxVIP

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
总线地址和物理地址研发部徐东远2022-06-29物理地址逻辑地址:相对于进程4G空间来说的,为了隔离物理地址与程序直接交互,减轻程序员的负担。通过段映射,页映射可以转换成物理地址。?物理地址:物理地址是与CPU相关的。在CPU的地址信号线上产生的就是物理地址。在程序指令中的虚拟地址经过 段映射和页面映射后,就生成了物理地址,这个物理地址被放到CPU的地址线上。?总线地址:总线地址,顾名思义,是与总线相关的,就是总线的地址线或在地址周期上产生的信号。外设使用的 是总线地址。虚拟地址:就是为了在小内存的系统中运行大的应用程序而出现的一种机制。这里就牵涉到了页中断,就是在某个进程不用的时候,把其中的内存存放到硬件中,等需要使用的时候,产生一个页中断把它重新调回到内存中。当然,它牺牲了时间。典型的“以时间换空间”的做法。物理地址与总线地址之间的关系由系统的设计决定的。在x86平台上,物理地址与PCI总线地址是相同的。在其他平台上,也许会有某种转换,通常是线性的转换。比如:CPU需要访问物理地址是0xfa000的单元,那么在x86平台上,会产生一个PCI总线上对0xfa000地址的访问。这个单元或者是内存中,或者是某个卡上的存储单元,甚至可能这个地址上没有对应的存储器。而在另外一个平台上,或许在PCI总线上产生的访问是针对地址为0x1fa000的单元。PCI设备总线地址与CPU物理地址的区别物理地址:MMU看到的内存的地址虚拟地址:cpu,程序员操作的地址总线地址:设备看到的地址1 域的概念PCI设备域包括: PCI设备,PCI设备上的DMA Enginer, CPU端的DMA 控制器。CPU域包括: CPU比如一块内存,物理地址是0,在 设备端看起来是0而物理地址0又通常被映射为虚拟地址0xc0000000,从而同一地址就具备了三个身份,但他们在物理上指的是同一片区域。2 物理地址到总线地址的映射物理地址和总线地址一一映射,而且在绝大多数平台上,为了简便,总线地址和物理地址起始地址也是一样的。虽然方便,但是很多开发者弄不清楚某个具体值到底是物理地址还是总线地址。有了域的概念,就好理解多了,如设备的PCI config space 中的BAR地址就是总线地址,因为它是给设备用的。而调用kernel API pci_resource_start(dev,...) 返回的值则是CPU域的物理地址。我的理解就是,物理地址一般与CPU有关系,是给CPU指令使用的。而总线地址主要是给设备使用的,是设备中的一些内存资源。如果要CPU的物理地址连接上设备上的总线地址就需要使用mmapi映射,这样就能将物理地址与总线地址链接在一起。linux内核代码结构arch 这个子目录包含了此核心源代码所支持的硬件体系结构相关的核心代码。如对于X86平台就是i386。include 这个目录包括了核心的大多数include文件。另外对于每种支持的体系结构分别有一个子目录。init 此目录包含核心启动代码。mm 此目录包含了所有的内存管理代码。与具体硬件体系结构相关的内存管理代码位于arch/*/mm目录下,如对应于X86的就是arch/i386/mm/fault.cdrivers 系统中所有的设备驱动都位于此目录中。它又进一步划分成几类设备驱动,每一种也有对应的子目录,如声卡的驱动对应于drivers/sound。ipc 此目录包含了核心的进程间通讯代码。modules 此目录包含已建好可动态加载的模块。fs Linux支持的文件系统代码。不同的文件系统有不同的子目录对应,如ext2文件系统对应的就是ext2子目录。kernel 主要核心代码。同时与处理器结构相关代码都放在arch/*/kernel目录下。net 核心的网络部分代码。里面的每个子目录对应于网络的一个方面。 lib 此目录包含了核心的库代码。与处理器结构相关库代码被放在arch/*/lib/目录下。Scripts 此目录包含用于配置核心的脚本文件。Documentation 此目录是一些文档,起参考作用。linux内核源码结构arch:包含和硬件体系结构相关的代码,每个架构的CPU都对应?个?录,如i386、arm、arm64、powerpc、mips等, Linux内核目前支持30种左右的体系结构。在arch目录下存放的是各个平台以及各个平台的芯片对Linux内核进 程调度、内存管理、中断等的支持,以及每个具体的SOC和电路板的板级支持代码。block:块设备的通用函数,驱动程序I/O调度。crypto:常用加密和散列算法(如AES、SHA等),还有一些压缩和CRC校验算法。drivers:所有的设备驱动程序,每一类的驱动对应一个子目录,如driver/block为块设备驱动

文档评论(0)

***** + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档