以下摘录《步骤吓得核心——软-core处理器的室内设计与分析》一本书

13.7DCache使用情景之中的一个——存储指令运行阶段DCache失靶

存储指令运行阶段DCache失靶这样的情景在通写法、回写法策略下有不同的运行过程,在通写法策略下直接写存储器中相应的地址,不操作DCache。

在回写法策略下。首先推断目的地址相应的DCache中文件夹表的line是否被改动,假设是(Dirty为1)。则将该line写回到内存,然后将目的地址所在的内存块读入DCache,填充到相应line,然后再改动DCache中相应目的地址的数据。假设目的地址相应的line没有被改动(Dirty为0),那么直接将目的地址所在的内存块读入DCache,填充到相应line,然后再改动DCache中相应目的地址的数据。

如图13.7所看到的。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGVpc2hhbmd3ZW4=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

(详细分析过程參考书中正文)

13.8 DCache使用情景之二——存储指令运行阶段DCache命中

存储指令运行阶段DCache命中这样的情景在通写法、回写法策略下也有不同的运行过程,在通写法策略下,既要写DCache中文件夹表相应的line,还要写内存中相应的地址,在回写法策略下,仅仅是写DCache中文件夹表相应的line。如图13.11所看到的。

(详细分析过程參考书中正文)

13.9 DCache使用情景之三——l.mtspr指令写DCache中特殊寄存器

DCache中有三个特殊寄存器:DCBIR、DCBFR、DCBWR,其作用在13.3节已说明。从代码分析中能够发现,在通写法策略下,仅仅能使用DCBIR、DCBFR。在回写法策略下,能够使用所有三个特殊寄存器。这也是非常好理解的,在通写法策略下。DCache文件夹表中line的标志位Dirty始终为0。所以DCBIR、DCBFR的作用是一样。而且不是必需存在DCBWR寄存器,所以本章将指令l.mtspr写DCache中特殊寄存器这一情景又分为例如以下四种情景:

(1)通写法策略下。指令l.mtspr写DCBIR、DCBFR

(2)回写法策略下,指令l.mtspr写DCBIR

(3)回写法策略下,指令l.mtspr写DCBWR

(4)回写法策略下。指令l.mtspr写DCBFR

(详细分析过程參考书中正文)

13.10 DCache分析小结

DCache有多种使用情景,本章仅仅是分析了当中的三种,但这已经足够我们了解DCache的工作过程了。其余情景的处理过程与此是类似的。笔者个人感觉DCache模块是OR1200中最复杂的模块,由于要考虑到载入、存储指令,还要考虑採用的写策略是通写法、回写法,还要考虑DCache中相应文件夹项的标志位V、Dirty的情况,所以非常复杂。

为此。在本章最后分别给出在通写法、回写法情况下。DCache的工作流程图,如图13.18、13.19所看到的,当中也给出了DC_FSM模块中有限状态机各个状态之间的转换情况。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGVpc2hhbmd3ZW4=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

版权声明:本文博客原创文章,博客,未经同意,不得转载。

OR1200数据Cache运用情景分析的更多相关文章

  1. OR1200数据Cache介绍

    以下摘录<步骤吓得核心--软-core处理器的室内设计与分析>一本书 上一章剖析了ICache模块. 本章将剖析DCache模块.首先指出DCache模块相比ICache的特别之处.由于这 ...

  2. Linux内核源代码情景分析系列

    http://blog.sina.com.cn/s/blog_6b94d5680101vfqv.html Linux内核源代码情景分析---第五章 文件系统  5.1 概述 构成一个操作系统最重要的就 ...

  3. OR1200指令Cache使用举例

    下面内容摘自<步步惊芯--软核处理器内部设计分析>一书 12.4 ICache中的特殊寄存器 通过ICache的接口可知其具有特殊寄存器,而且是不可读的特殊寄存器,OR1200处理器中IC ...

  4. 《Android系统源代码情景分析》连载回忆录:灵感之源

    上个月,在花了一年半时间之后,写了55篇文章,分析完成了Chromium在Android上的实现,以及Android基于Chromium实现的WebView.学到了很多东西,不过也挺累的,平均不到两个 ...

  5. Android系统--Binder系统具体框架分析(二)Binder驱动情景分析

    Android系统--Binder系统具体框架分析(二)Binder驱动情景分析 1. Binder驱动情景分析 1.1 进程间通信三要素 源 目的:handle表示"服务",即向 ...

  6. Android系统--输入系统(十四)Dispatcher线程情景分析_dispatch前处理

    Android系统--输入系统(十四)Dispatcher线程情景分析_dispatch前处理 1. 回顾 我们知道Android输入系统是Reader线程通过驱动程序得到上报的输入事件,还要经过处理 ...

  7. go语言调度器源代码情景分析之五:汇编指令

    本文是<go调度器源代码情景分析>系列 第一章 预备知识的第4小节. 汇编语言是每位后端程序员都应该掌握的一门语言,因为学会了汇编语言,不管是对我们调试程序还是研究与理解计算机底层的一些运 ...

  8. go语言调度器源代码情景分析之四:函数调用栈

    本文是<go调度器源代码情景分析>系列 第一章 预备知识的第3小节. 什么是栈 栈是一种“后进先出”的数据结构,它相当于一个容器,当需要往容器里面添加元素时只能放在最上面的一个元素之上,需 ...

  9. go语言调度器源代码情景分析之三:内存

    本文是<go调度器源代码情景分析>系列 第一章 预备知识的第2小节. 内存是计算机系统的存储设备,其主要作用是协助CPU在执行程序时存储数据和指令. 内存由大量内存单元组成,内存单元大小为 ...

随机推荐

  1. OPENVPN开启用户password认证

    一.服务端配置 1.改动openvpn的主配置文件,加入例如以下内容 [root@ttt openvpn]# cat /etc/openvpn/server.conf |more #########a ...

  2. Ext JS4百强应用: 做可编辑的,可checked的treegrid--第11强

    做一个可编辑的,可checked的treegrid,代码相当简洁: 请看代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN&quo ...

  3. ios在SQLite3基本操作

    iOS关于sqlite3操作 iPhone中支持通过sqlite3来訪问iPhone本地的数据库. 详细用法例如以下 1:加入开发包libsqlite3.0.dylib 首先是设置项目文件.在项目中加 ...

  4. 写一个程序,乞讨1+2*2+3*3+n*n值 Java

    public static void main(String[] args) {         // 1*1+2*2+3*3+n*n         int n = 40;         // 1 ...

  5. emeditor 配置教程

    1.众多的图形界面配置功能 通过查看EmEditor的安装目录,可以发现,EmEditor有几个配置文件,理论上应该可以通过修改配置文件来达到配置EmEditor的目 的.然而,打开配置文件一看,如果 ...

  6. Android开发框架SmartAndroid2.0 强劲框架

    SmartAndroid 是一个功能强劲的 Android 框架,作为一个简单而"优雅"的工具库包,它能够为 Android 开发人员建立功能完好的Android 应用程序. 经过 ...

  7. 微软中国裁员曝光:在CD结束后!薪酬不变!

    聚众抗议的前诺基亚员工(腾讯科技配图) 腾讯科技 郭晓峰 腾讯科技刚刚获取了一份微软设备事业部中国区管理团队4日晚间发给被裁员工的补偿方案邮件. 邮件内容显示,微软承诺在收购诺基亚交易结束(2014年 ...

  8. React Native是一套使用 React 构建 Native app 的编程框架

    React Native是一套使用 React 构建 Native app 的编程框架 React Native at first sight what is React Native? 跟据官方的描 ...

  9. richedit设置滚动条的位置和更新内容

    需要txt发现读者richedit的scrollbar位置(为了便于下一次读,直接访问与上次读取下一个读取位置)不值得治疗,采用GetScrollPos.SetScrollPos你可以设置scorll ...

  10. MongoDB时间处理问题

    MongoDB保存到数据库的时候,默认为UTC时间,在数据库保存时,会和当前时间有个间隔,差距为8小时. 在读取的时候,需要再次转换回来,比较麻烦. 其实,Mongo本身就已经提供了相应的处理方法,即 ...