烂泥桑 发表于 2014-8-27 10:36:35

疑惑Dcache和Write buffer,求指教

本帖最后由 烂泥桑 于 2014-8-27 11:04 编辑

如标题,本人在阅读关于这方面的资料(主要就是ATSAM9260的datasheet和ARM926EJ-S用户手册)时,感到很迷惑,就来请教了。首先附上图:
1、请问隶属于DEXT中的write buffer和隶属于Dcache中的write back write buffer分别起到什么作用呢?
2、在网络上的资料里,讲述cache多数都以CPU从memory读数据、指令作为例子讲述cache的作用,那么如果是CPU往外部memory写,Dcache和write buffer(这里的write buffer是指问题1中的哪一个我也不太清楚)分别怎么起作用呢?
3、在write back和write through操作中,问题2的答案会有不同吗?

望各位大牛详解,谢谢。

Nuker 发表于 2014-8-27 11:22:53

你可以把Dcache当成外部mem数据区的镜像,但是因为Dcache的容量有限,所以只能实现多条小段的镜像,每条对应一小块外部mem数据区。当CPU要回写外部mem的时候,cache控制器会检索目标地址是否已经在镜像范围内,在的话(hit)就直接写到Dcache镜像对应的位置,cache控制器会将已更新数据的条块标记为dirty,意即内容相对外部mem而言已经更新,如果没有hit,则需要直接写到外部mem,write buffer就是直接写到外部mem的缓冲区。

Nuker 发表于 2014-8-27 11:25:14

你可以把Dcache当成外部mem数据区的镜像,但是因为Dcache的容量有限,所以只能实现多个条块的小段镜像,每个条块对应一小块外部mem数据区。
当CPU要回写外部mem的时候,cache控制器会检索目标地址是否已经在镜像范围内:
* 在镜像范围内的话(hit)就直接写到Dcache镜像对应的位置,cache控制器会将已更新数据的条块标记为dirty,表示内容相对外部mem而言已经更新
* 如果没有hit,则需要直接写到外部mem,write buffer就是直接写到外部mem的缓冲区。

烂泥桑 发表于 2014-8-27 18:22:59

Nuker 发表于 2014-8-27 11:25
你可以把Dcache当成外部mem数据区的镜像,但是因为Dcache的容量有限,所以只能实现多个条块的小段镜像,每 ...

请问您那个write back write buffer(在Dcache框图里面那个)是怎么一回事呢?

Nuker 发表于 2014-8-28 12:57:43

标记为dirty的cache条块需要回写(更新)到外部mem的时候,就通过这个write back write buffer回写到外部mem

烂泥桑 发表于 2014-8-28 21:55:58

Nuker 发表于 2014-8-28 12:57
标记为dirty的cache条块需要回写(更新)到外部mem的时候,就通过这个write back write buffer回写到外部me ...

可以理解为:“回写时,起作用的仅是write back write buffer;而除回写操作外,其余写操作就是write buffer起作用” 吗?

Nuker 发表于 2014-8-29 01:22:22

不是的。
没有hit的回写直接通过write buffer写回mem。
hit的回写直接写入cache对应的条块,tag标记为dirty,等整个已标记为dirty的条块不再使用时,通过write back write buffer写回mem。

烂泥桑 发表于 2014-8-29 11:07:25

《ARM926EJ-S用户手册》第四章有说明,资料没好好看就来发问,真是对不起党和人民{:shy:}

烂泥桑 发表于 2014-8-29 18:17:04

Nuker 发表于 2014-8-29 01:22
不是的。
没有hit的回写直接通过write buffer写回mem。
hit的回写直接写入cache对应的条块,tag标记为dirty ...

我又想到一个问题,找了文档都没有说到,虽然有自己的理解,还是想请教一下:write through操作中,如果hit了,cache和外部men对应的地方都会更新;如果miss时,外部men中被写入新的数据,问题是cache会不会变化,我觉得应该有一个类似read的Miss时候的操作,就是会更新cache中的line,不知对不对呢?

dr2001 发表于 2014-8-29 19:18:24

烂泥桑 发表于 2014-8-29 18:17
我又想到一个问题,找了文档都没有说到,虽然有自己的理解,还是想请教一下:write through操作中,如果h ...

那个是Write Allocation的特性,可以搜索一下。
如果写Miss,需要分配的话,那就是Write Allocation;否则就是不分配Cache Line。

烂泥桑 发表于 2014-8-29 22:36:20

找到这个网址,有图片真是帮大忙了
http://witmax.cn/cache-writing-policies.html
页: [1]
查看完整版本: 疑惑Dcache和Write buffer,求指教