| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> ZYNQ ARM核之SCU -> 正文阅读 |
|
[嵌入式]ZYNQ ARM核之SCU |
? ? ? ? Snoop Control Unit,窥探控制单元,详情见UG585。SCU主要是解决ARM的L1和L2的缓存协调(因为两个processor的缓存是共用的)和AXI总线的ACP存取的,也就是DMA等高速中断需求的外设。 ?????????SCU 块将两个 Cortex-A9 处理器连接到内存子系统,并包含智能管理两个处理器和 L2 缓存之间的数据缓存一致性。这块负责管理互连仲裁、通信、缓存和系统Cortex-A9 处理器的内存传输和缓存一致性。 The APU also exposes the capabilities of the SCU to system accelerators that are implemented in the PL through the accelerator coherency port (ACP) interface。该接口允许 PL 主机共享和访问处理器缓存层次结构。这里提供的系统一致性不仅提高了性能,但也降低了维护所涉及的软件复杂性每个操作系统驱动程序内的软件一致性。 总结一下: SCU通过AXI接口将一至四个Cortex-A9处理器连接到存储器系统。 SCU功能是: 1、在Cortex-A9处理器之间维护数据Cache的一致性 2、初始化L2 AXI存储器访问 3、在请求L2访问的Cortex-A9处理器之间仲裁 4、管理ACP【译者注:加速器一致性端口】访问。 注:Cortex-A9 SCU不支持对指令Cache一致性的硬件管理。 SCU实现了对ARM架构安全扩展的支持。 独立的CPU事件监视器可以被配置用于收集对SCU操作的各类事件统计信息。 ?SCU控制寄存器: SCU控制寄存器的特征如下: 目的: 1、允许用PL310【译者注:PrimeCell二级Cache控制器】对L2投机地进行行填充 2、允许迫使所有连到端口0的设备 3、允许IC待机模式 4、允许SCU待机模式 5、允许奇偶校验支持 6、允许地址过滤 7、允许SCU 使用限制: 1、在安全状态下这个寄存器是可写的,如果SAC寄存器中的相关位置1 2、在非安全状态下这个寄存器是可写的,如果SAC以及SNSAC寄存器中的相关位置1 配置:在所有Cortex-A9多处理器配置中都可用 SCU控制寄存器介绍: [位6] IC待机模式允许:当置1时,如果此时没有中断是未决的,并且没有处理器在执行一次读写请求,那么停止中断控制器时钟。 [位5] SCU待机允许:当置1时,如果此时所有处理器处于WFI模式,在ACP(如果实现的话)上没有未决请求,并且在SCU中没有剩余活动,那么SCU CLK被关闭。 ? ? ? ? ? ? ? ? ? ? ? ? ? ? 当SCU CLK被关闭时,在ACP上的ARREADYS,AWREADYS以及DWREADYS被迫使为HIGH。当任一处理器离开WFI模式,或在ACP上有一个新的请求时,时钟被打开。 [位4] 迫使所有到端口0的设备允许:当置1时,所有来自ACP或AxCACHE = DV的处理器的请求被迫使在AXI主机端口M0上被发布。 [位3] 投机的行填充允许:当置1时,一致性的行填充请求被投机地并行发送到带有标签查找的PL310中。如果标签查找失败,那么已确认的行填充被发送到PL310,并更早地获得R数据,因为数据请求已经被投机请求所启动。这个特征只有当PL310在设计中存在时才能工作。 [位2] 奇偶校验打开:1=奇偶校验打开;0=奇偶校验关闭,这个是默认设置。 [位1] 地址过滤允许:1=地址过滤打开;0=地址过滤关闭。默认值为从复位退出时所采样到的FILTEREN的值。这个位总是为0,如果SCU在单主机端口配置中实现。 [位0] SCU允许:1=SCU允许;0=SCU禁止。这是默认设置。 SCU配置寄存器: SCU配置寄存器的特征是: 1、目的:——读总线上所连接的所有Cortex-A9处理器的标签RAM大小 ? ? ? ? ? ? ? ? ? ——判定参与一致性的Cortex-A9处理器 ? ? ? ? ? ? ? ? ? ——读总线上所连接的Cortex-A9处理器的个数 2、使用限制:此寄存器是只读的 3、配置:在所有Cortex-A9多处理器配置中可用 4、属性:见SCU寄存器中的寄存器概述,在P2-3 SCU配置寄存器功能描述: 标签RAM大小:最多四个CPU(CPU0~3);64KB Cache,每个标签RAM有256个索引;32KB Cache,每个标签RAM有128个索引;16KB Cache,每个标签RAM有64个索引。 CPU SMP:定义Cortex-A9处理器是处于对称多处理器(SMP)还是非对称多处理器(AMP)模式中; ? ? ? ? ? ? ? ? ? ? ?0表示指定的Cortex-A9处理器处于AMP模式,并不参与一致性或是不存在 ? ? ? ? ? ? ? ? ? ? ?1表示指定的Cortex-A9处理器处于SMP模式,并参与一致性 参考: ARM Cortex-A9 MPCore手册——窥探控制单元(Snoop Control Unit) - zenny_chen - 博客园 |
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 23:41:29- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |