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. Java基础--接口和抽象类的区别

    任何不谈使用方法的空理论都是耍流氓 使用场景 · 如果你拥有一些方法并且想让它们中的一些有默认实现,那么使用抽象类吧(Java1.8中接口也可以这么做了) · 如果你想实现多重继承,那么你必须使用接口 ...

  2. syntax error near unexpected token `$'\r''

    这种情况发生的原因是因为你所处理的文件换行符是dos格式的"\r\n"可以使用cat -v 文件名 来查看换行符是否是,如果是上述的,则行结尾会是^m需要转换成linux/unix ...

  3. SQL语句中 INNER JOIN的用法!

    一.SQL语句中  INNER JOIN的用法? 1.INNER JOIN的作用? 可以在两个或者更多的表中获取结果,得出一张新表. [隐式内连接] 表一 car  购物车 表二 user 用户 发现 ...

  4. 关于flex布局【转】

    很受用,原文链接:http://blog.csdn.net/magneto7/article/details/70854472

  5. JPA javax.persistence.TransactionRequiredException

    直接说一下解决方案 Dao层,一定要是Dao层. 1 增加Transactional,必须要事务! 2 增加Modifying,告诉jpa这是修改! @Transactional @Modifying ...

  6. swagger.core的使用方法

    Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务,那么如何在abp中使用呢,已经有大牛为我们实现了一个swagger.core的组件而作为菜鸟 ...

  7. loadrunner断言多结果返回

    有这么一个场景,接口返回的多个状态都是正常的,那么在压测的时候,断言就需要多 init里面执行登录,根据返回获取到tokenId action中,执行登录后的操作,获取响应返回的状态,把正确的状态个数 ...

  8. Codeforces Round #544 (Div. 3) D F1 F2

    题目链接:D. Zero Quantity Maximization #include <bits/stdc++.h> using namespace std; #define maxn ...

  9. 洛谷P1032 字串变换-题解

    https://www.luogu.org/problemnew/show/P1032--(题目传送) 好在数据范围很小,暴力一点也能过.思路较简单,按照所有规则,从第一位开始广搜. 注意:1.str ...

  10. CF235B Let's Play Osu! 期望DP

    貌似是一道很裸的期望\(DP\).直接说思路: 设\(f[i]\)表示到\(i\)位置时的期望分数,但是只有\(f[i]\)的话我们发现是无法转移的,我们还需要知道到\(i\)位置时的期望连续长度,于 ...