00000 Index Invalidate              INDEX_INVALIDATE_I          (I)
00001 Index WriteBack Invalidate INDEX_WRITEBACK_INV_D (D)
00101 Index Load Tag INDEX_LOAD_TAG_D (D)
01001 Index Store Tag INDEX_STORE_TAG_D (D)
10001 Hit Invalidate HIT_INVALIDATE_D (D)
10101 Hit WriteBack Invalidate HIT_WRITEBACK_INV_D (D)
// R10000-specific cacheops
11001 Index Load Data INDEX_LOAD_DATA_D (D)
11101 Index Store Data INDEX_STORE_DATA_D (D)
00011 Index WriteBack Invalidate INDEX_WRITEBACK_INV_S(/D) (S)
00111 Index Load Tag INDEX_LOAD_TAG_S(/D) (S)
01011 Index Store Tag INDEX_STORE_TAG_S(/D) (S)
10011 Hit Invalidate HIT_INVALIDATE_S(/D) (S)
10111 Hit WriteBack Invalidate HIT_WRITEBACK_INV_S(/D) (S)
11011 Index Load Data INDEX_LOAD_DATA_S (S)
11111 Index Store Data INDEX_STORE_DATA_S (S)

Index WriteBack Invalidate (S) 指令将二级Cache 中的对应块置为Invalid 状态。如果二级Cache 对应块的数据是脏的,则将数据写到处理器系统接口部件。由于二级Cache与数据Cache 和指令Cache 保持包含关系,因此在二级Cache 无效写回前先将数据Cache和指令Cache 中的对应数据无效,如果数据Cache 中对应的数据是脏的,则先将其写入二级Cache,最后完成二级Cache 块的无效写回。PA[16:5]定义物理地址,PA[1:0]定义无效的组号。
无效写回操作过程如下:
1. 处理器从二级 Cache 的Tag 数组读取STag 和状态位.如果状态位State=00(Invalid),则不需要采取任何操作。如果对应Cache 块是有效的,STag 用来对对指令和数据Cache 进行操作。
2. 查询指令 Cache,如果指令Cache 的ITag=STag 并且指令Cache 中该块的状态IState=1(Valid),处理器将指令Cache 中的对应块无效,即将状态置位为0(Invalid)。
3. 查询数据 Cache,如果数据Cache 的DTag=STag 并且数据Cache 中该块的状态DState 不等于00(Invalid),若Dirty 位的值为1,则将数据写入二级Cache,无效对应Cache 块。若Dirty 位的值为0,则直接无效数据Cache 的对应块。
4. 将二级 Cache 块的状态置为00(Invalid)。如果二级Cache 的状态为11(Dirty),将对应块写回到处理器接口。

Hit WriteBack Invalidate (S) 指令二级Cache 中地址PA 匹配的对应块置为Invalid 状态。如果二级Cache 对应块的数据是脏的,则将数据写到处理器系统接口部件。由于二级Cache 与数据Cache 和指令Cache 保持包含关系,因此在二级Cache 无效写回前先将数据Cache 和指令Cache 中的对应数据无效,如果数据Cache 中对应的数据是脏的,则先将其写入二级Cache,最后完成二级Cache 块的无效写回。
无效写回操作过程如下:
1. 处理器用 PA 从二级Cache 的Tag 数组读取STag 和状态位。如果STag 的值与PA对应位的值相同,且状态位State 不等于00(Invalid),则发生了命中。如果没有发生命中,该Cache 指令操作完成。
2. 查询指令 Cache,如果指令Cache 的ITag=STag 并且指令Cache 中该块的状态IState=1(Valid),处理器将指令Cache 中的对应块无效,即将状态置位为0(Invalid)。
3. 查询数据 Cache,如果数据Cache 的DTag=STag 并且数据Cache 中该块的状态DState 不等于00(Invalid),若Dirty 位的值为1,则将数据写入二级Cache,无效对应Cache 块。若Dirty 位的值为0,则直接无效数据Cache 的对应块。
4. 将二级 Cache 块的状态置为00(Invalid)。如果二级Cache 的状态为11(Dirty),将对应块写回到处理器接口。

Hit Invalidate (S) 指令将二级Cache 中地址匹配的对应块置为Invalid 状态。由于二
级Cache 与数据Cache 和指令Cache 保持包含关系,因此在二级Cache 无效写回前先将数据Cache 和指令Cache 中的对应数据无效,最后完成二级Cache 块的无效。
无效操作过程如下:
1.处理器用PA 从二级Cache 的Tag 数组读取STag 和状态位。如果STag 的值与PA对应位的值相同,且状态位State 不等于00(Invalid),则发生了命中。如果没有
发生命中,该Cache 指令操作完成。
2.查询指令Cache,如果指令Cache 的PA 与STag 匹配,并且指令Cache 中该块的状态IState=1(Valid),处理器将指令Cache 中的对应块无效,即将状态置位为0(Invalid)。
3.查询数据Cache,如果数据Cache 的DTag=STag 并且数据Cache 中该块的状态DState 不等于00(Invalid),则无效数据Cache 的对应块。4.将二级Cache 块的状态置为00(Invalid)。

loongson 2f 和u-boot中的cache命令对照的更多相关文章

  1. spring boot 中 Cache 的使用

    参考:https://blog.csdn.net/qq_38974634/article/details/80650810 一.JSR107 Java Caching 定义5个核心的接口,分别是Cac ...

  2. spring boot(三):Spring Boot中Redis的使用

    spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结 ...

  3. springboot(三):Spring boot中Redis的使用

    spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结 ...

  4. 在Spring Boot中使用数据缓存

    春节就要到了,在回家之前要赶快把今年欠下的技术债还清.so,今天继续.Spring Boot前面已经预热了n篇博客了,今天我们来继续看如何在Spring Boot中解决数据缓存问题.本篇博客是以初识在 ...

  5. Spring Boot:Spring Boot 中 Redis 的使用

    Redis 介绍 Redis 是目前业界使用最广泛的内存数据存储.相比 Memcached,Redis 支持更丰富的数据结构,例如 hashes, lists, sets 等,同时支持数据持久化.除此 ...

  6. (转)Spring Boot(三):Spring Boot 中 Redis 的使用

    http://www.ityouknow.com/springboot/2016/03/06/spring-boot-redis.html Spring Boot 对常用的数据库支持外,对 Nosql ...

  7. 204. jetcache:在Spring Boot中怎么玩?

      [视频&交流平台] àSpringBoot视频:http://t.cn/R3QepWG à SpringCloud视频:http://t.cn/R3QeRZc à Spring Boot源 ...

  8. 学习Spring Boot:(二十三)Spring Boot 中使用 Docker

    前言 简单的学习下怎么在 Spring Boot 中使用 Docker 进行构建,发布一个镜像,现在我们通过远程的 docker api 构建镜像,运行容器,发布镜像等操作. 这里只介绍两种方式: 远 ...

  9. Spring boot(三)在Spring boot中Redis的使用

    spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结 ...

随机推荐

  1. FJUTOJ-周赛2016-12-16

    注:fjutoj基本每周都有一次周赛,欢迎大家都来参加! 网址:http://59.77.139.92/index.jsp A题:来源 POJ 2773 题意:给两个数m和k,问第k 个和m 互素的数 ...

  2. Windows apache-flume-1.6.0+Kafka+Es

    apache-flume-1.6.0 kafka_2.11-1.1.0 elasticsearch1.5.1 flume配置 a1.sources = kafkaSource a1.channels ...

  3. adb push 中文路径文件名丢失后缀

    adb 的一个BUG. 今天刷机的时候,用以下命令多次 push 安装包到手机: adb push F:\刷机\Nexus5\lineage-14.1-20170314-nightly-hammerh ...

  4. Django_ORM操作 - 查询

    ORM 操作 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(* ...

  5. CAN通信帧ID如何设定?

    CAN总线ID是包含在报文帧中的. 1.主要用作CAN总线的仲裁使用,所以一般来说网络上的每个节点(向总线上发送)的ID应该有所不同.ID值越低,报文优先级越高,在两组不同ID报文同时上线时候,仲裁机 ...

  6. VSCode的Markdown All in One插件,列表选项卡只有3个空格的解决方案

    Q: 在win10中,列表选项卡只有3个空格,非列表是正常的4个空格: A: 设置Markdown All in One的list.indentationSize: Thank You For yzh ...

  7. Outlook 2013 日历/任务本地备份与还原

    1.日历: 备份日历:切换到日历项,按如下步骤备份.文件 --> 保存日历 --> 其它选项: 日期范围:指定日期(开始日期:2018/1/1,结束日期:2018/12/31) 详细信息: ...

  8. Java EE Expression Language

    什么是EL? 形如这样(立即执行的): ${sessionScope.cart.total} 或者这样(延迟执行的): #{customer.name} 的表达式语言(Expression Langu ...

  9. Django 后台定制自己的选择框删除函数

    from django.contrib import admin from .models import Article,Category from datetime import datetime ...

  10. Django 中的static文件的设置

    STATIC_URL = '/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), ('article',os.path.jo ...