ASIB中的valid信号,有两部分,一部分add产生的地址映射,到main中的default addr。(vect)

一部分由Dmu和Cdas组成,到main中的build。

Dmu:interconnect中的power manage unit。

两个输入信号:m0_cactive:来自asib的valid信号和目前的tracker_busy信号,表示目前还有未传完的ourtstanding的transaction。

m0_cactive_wakeup:来自master口的新的transaction的valid信号。

在经过内部的FSM后,输出m0_port_enable信号,cd_m0_csysreq和cd_m0_csysack信号。

内部不会有相应的clock gate逻辑,只是提供握手信号和状态信号。

Asib中:add_decode模块,进行address的remap,包括(security/protect/cache信号的处理),

地址可以分段判断,每一段有自己的security和protect的设置,最终输出几位的valid信号。

传入asib内的其他模块和ib模块中,表示该次transaction有效。读写通道分别例化。每一个address region对应一个slave区域。

Asib中的maskcnt模块:在master端,表示为issue capacity,主要进行计数,产生tracker_busy信号。

读写通过最终的resp的返回来判断是否结束。tracker_busy信号只用在dmu中的wakeup输入端。

内部计数为read/write可接受的outstanding的个数,输出wr_cnt_empty信号来作为outstanding满之后的mask信号。

Asib中的cdas模块:根据连接的slave interface个数和acceptance capability,和相应的cdas策略,

实现对同一master口,发送transaction的控制,防止死锁,较多的策略有single slave和per ID per slave。

其中的asel来自add_decode的valid信号,位宽相同。读写该模块实现并不相同,读通道只输出一个ar_enable信号。

Asib中的register slice模块5个通道可以分别例化,都有四种模块可配置。位置可调整。

Master端的Ib模块中,有upsizer/downsizer模块,

slave端的ib模块中有async bridge和interface conversion bridge。针对cdc,会有5个通道的fifo进行cdc设计。

涉及到upsizer/downsizer时,会有read_address_format,write_address_format,write_control,write_merge_buffer,

write_response_block以及fifo_wr。

cd_main中包括:busmatrix的switch模块,default slave模块,dmu模块,以及master和slave的ib模块。

Switch中包括两部分:Build模块,实现master到slave的1-n转换。Map模块,实现slave端的n-1转换。

Build模块中有和master个数相同的blayer模块,每个内部例化rd/wr通道。通过build_rd/build_wr生成的enable信号,使能到各个slave的valid信号。

其中asel信号来自add_decode模块输出的每个slave的valid信号,三个enable信号在此基础上产生,使能到slave端口的valid信号。

Map模块内包括add_sel模块,ret_sel模块,wr_sel模块。

add_sel模块主要实现rd/wr address的arb选择,以及outstanding的mask操作。

Ret_sel模块根据id号,选择正确的B通道和R通道到build模块。

Wr_sel模块,实现wdata信号到slave的选择,直到address的arbitrated做好,否则stall wdata channel。

Add_sel模块内包含三个模块:ar_arb模块,aw_arb模块,maskcnt1模块。Maskcntl模块。

这里的maskcntl模块,输出mask_w/mask_r给arb模块,在outstanding的个数到之后,进行mask操作。

Arb模块,通过qos或者LRG算法,从选择从不同master过来的transaction。内部实现highest_qos和lrg_arb两个模块。

Mask信号从maskcntl模块来,a_valid_vector为信号add_decode输出的valid信号与master的valid信号的与结果。

PL301 matrix内部模块的更多相关文章

  1. 查看python内部模块命令,内置函数,查看python已经安装的模块命令

    查看python内部模块命令,内置函数,查看python已经安装的模块命令 可以用dir(modules) 或者用 pip list或者用 help('modules') 或者用 python -m  ...

  2. nw.js node-webkit系列(15)如何使用内部模块和第三方模块进行开发

    原文链接:http://blog.csdn.net/zeping891103/article/details/50786259 原谅原版链接:https://github.com/nwjs/nw.js ...

  3. pytho文件命名不要内部模块或者引用模块名字相同

    自己写的包和模块,注意命名不要和python内置模块和包.以及引用的模块和包名字冲突

  4. Mysql架构与内部模块-第二章

    接上文,上文简述到了Mysql中的查询缓存和解析器,今日我们继续. 先来看一段SQL:SELECT * FROM `jianghuadong`; 先假设我们数据库中并没有一张名为jianghuadon ...

  5. Mysql架构与内部模块-第三章

    前言 接上文,本篇文章专门简述Mysql存储引擎,内容繁多,如果你只需知道每种存储引擎的适用场景,可以直接查看本文最后列出的适用场景部分. 正文: Mysql存储引擎作为本系列文章中相对重要的一环,也 ...

  6. Visual Studio Code 断点调试Nodejs程序跳过node内部模块(internal modules)

    Built-in core modules of Node.js can be referred to by the ‘magic name’ <node_internals> in a ...

  7. Mysql架构与内部模块-第一章

    Mysql作为大多数中小型企业的首选数据库,也可能是众多同僚接触的第一个数据库,其热门程度不言而喻,一些相对基础的知识本系列不做赘述,主要简述Mysql相关的进阶知识. 本章将由浅入深的讲解从连接My ...

  8. OpenCV学习笔记:opencv_core模块

    一,简介: opencv最基础的库.包含exception,point,rect,size,slice,vector,matrix,image等数据结构,和相应的操作函数,以及一些基础算法. 二,分析 ...

  9. Google TPU 揭密——看TPU的架构框图,矩阵加乘、Pool等处理模块,CISC指令集,必然需要编译器

    Google TPU 揭密 转自:https://mp.weixin.qq.com/s/Kf_L4u7JRxJ8kF3Pi8M5iw Google TPU(Tensor Processing Unit ...

随机推荐

  1. Linux下memcached安装和启动方法

    Linux下memcached安装和启动方法 1. 首先下载memcached 和 libevent 包. Memcached用到了libevent这个库用于Socket的处理.下面是下载的两个包文件 ...

  2. nodejs之async异步编程

    1.什么是异步编程? 异步编程是指由于异步I/O等因素,无法同步获得执行结果时, 在回调函数中进行下一步操作的代码编写风格,常见的如setTimeout函数.ajax请求等等. 示例:  for (v ...

  3. 【腾讯云】腾讯云服务器搭建ftp服务器

    一.硬件描述 1.1 云服务器:腾讯云 云主机 操作系统:Ubuntu Server 14.04.1 LTS 32位 CPU:1核 内存:1GB 系统盘:20GB(本地磁盘) 数据盘:0GB 公网带宽 ...

  4. [LintCode] Surrounded Regions 包围区域

    Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A region is captured ...

  5. Hadoop.2.x_高级应用_二次排序及MapReduce端join

    一.对于二次排序案例部分理解 1. 分析需求(首先对第一个字段排序,然后在对第二个字段排序) 杂乱的原始数据 排序完成的数据 a,1 a,1 b,1 a,2 a,2 [排序] a,100 b,6 == ...

  6. php读取html文件(或php文件)的方法

    一.使用fopen()函数   此函数主要传入的是头两个参数(第一个是文件地址,第二个是打开方式),可以读取任何一个文本文件,然后用while将fopen函数读取到的每一行数据循环输出.   如:   ...

  7. c#中enum的用法小结

    转自:http://blog.csdn.net/moxiaomomo/article/details/8056356 enums枚举是值类型,数据直接存储在栈中,而不是使用引用和真实数据的隔离方式来存 ...

  8. SQL serve 聚合函数、字符串函数

    1.聚合函数 sum,avg,max,min,count        having后面只能跟聚合函数 2.数学函数和字符串函数 3.练习: 1)新建一个学生信息表,根据问题写出程序. 2)新建一个超 ...

  9. IIS 8 下使用 WCF

    按照以下步骤添加后,IIS8即支持WCF服务. 首先添加MIME类型 扩展名“.svc”,MIME类型 “application/octet-stream” 2. 然后在“Handler Mappin ...

  10. 深入了解ios系统机制

    1.什么叫ios?        ios一般指ios(Apple公司的移动操作系统) .        苹果iOS是由苹果公司开发的移动操作系统.苹果公司最早于2007年1月9日的Macworld大会 ...