Zynq7000系列中的时钟管理

2024-04-18 17:12
文章标签 时钟 管理 系列 zynq7000

本文主要是介绍Zynq7000系列中的时钟管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PS(处理系统)时钟子系统生成的所有时钟都源自三个可编程PLL(锁相环)中的一个:CPU、DDR和I/O。时钟子系统的主要组件如图25-1所示。
Figure 25‐1: PS Clock System Block Diagram
在正常工作期间,PLL被启用,并由PS_CLK时钟引脚驱动。在启用PLL之前需要保持PS_CLK稳定,并且必须保持其稳定性。时钟频率必须在数据手册中指定的工作范围内。
如果PLL被旁路,PS_CLK引脚上的时钟信号将作为各种时钟发生器的源。PS_CLK可以按需慢速切换,直至其额定输入频率。这可以用于逐步启动过程、通过软件控制时钟或在低时钟频率下运行系统。在低时钟频率下运行系统可能会排除使用设备内的一些模块(例如,USB ULPI时钟的频率必须低于CPU_1x时钟)。
当PS_POR上电复位信号撤销时,会采样PLL旁路引导模式引脚,并为三个PLL选择PLL旁路或PLL启用。旁路模式运行的系统速度明显低于正常模式,但对于低功耗应用和调试很有用。在启动过程结束后以及用户代码执行时,每个PLL的旁路模式和输出频率都可以通过软件单独控制。
时钟生成路径包括无抖动多路复用器和无抖动时钟门控,以支持动态时钟控制。
1、三个可编程PLL
• 三个PLL共用单个外部参考时钟输入
Arm PLL:为CPU和互联设备推荐的时钟源
DDR PLL:为DDR DRAM控制器和AXI_HP接口推荐的时钟
I/O PLL:为I/O外设推荐的时钟
• 每个PLL都具有单独的旁路控制和频率编程功能
• VCO(压控振荡器)共享带隙基准电压电路
2、时钟Branches
负责将主时钟信号分发到各个需要时钟的组件或模块。
• 六位可编程频率分频器
• 大多数时钟电路上的动态切换
• 四个用于PL(可编程逻辑)的时钟发生器
这些可编程PLL和时钟分支为系统提供了灵活性和可配置性,使得开发人员可以根据应用需求调整时钟频率和分配。通过软件控制,可以动态地调整每个PLL的旁路模式和输出频率。同时,时钟Branches的设计使得时钟信号能够高效地分配到各个子系统和外设中,确保整个系统的同步性和稳定性。
3、时钟域
CPU时钟用于大多数内部时钟。
PL的AXI(AXI_HP、AXI_ACP和AXI_GP)通道是ARM处理器与外设之间通信的重要接口,它们也需要在PS和PL之间进行异步通信。在这些异步接口中,时钟域crossing发生的同步机制位于PS内部。这意味着,当数据从一个时钟域传递到另一个时钟域时,PS负责确保数据的正确同步和传输。
PL不仅接收来自PS的同步信号,还为PS提供接口时钟。此外,由于PL的高度可编程性,前述的每个接口在PL中都可以配置为使用独特的时钟,以满足特定的性能、功耗或时序要求。
4、复位
时钟子系统是PS(处理系统)的重要组成部分,并且只有在整个系统复位时才会被复位。当这种情况发生时,控制时钟模块的所有寄存器都将返回到它们的复位值。
5、功耗
PLL的功耗与PLL的输出频率直接相关。通过使用较低的PLL输出频率,可以降低功耗。如果不需要其中的一个或两个PLL,也可以减少功耗。例如,如果所有时钟发生器都可以由DDR PLL驱动,那么可以禁用Arm和I/O PLL来降低功耗。DDR PLL是唯一能够驱动所有时钟发生器的单元。
当某个时钟未被使用时,可以单独禁用它。在某些情况下,各个子系统还包含额外的时钟禁用和其他降低功耗的功能。
6、Central Interconnect时钟禁用
通过设置TOPSW_CLK_CTRL [0]位为1,可以停止Central Interconnect(CPU_2x和CPU_1x)的CPU时钟。当该位被设置时,时钟控制器会等待L2缓存和SCU的AXI接口空闲,并且等待PL的FPGAIDLEN信号被断言,然后才会关闭Central Interconnect的时钟。对于其他接口,系统软件必须确保接口空闲后才能禁用Central Interconnect时钟。一旦PS检测到L2缓存或SCU上的流量,或者FPGAIDLEN信号被撤销,时钟将被重新启用。

这篇关于Zynq7000系列中的时钟管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/915389

相关文章

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

Spring中管理bean对象的方式(专业级说明)

《Spring中管理bean对象的方式(专业级说明)》在Spring框架中,Bean的管理是核心功能,主要通过IoC(控制反转)容器实现,下面给大家介绍Spring中管理bean对象的方式,感兴趣的朋... 目录1.Bean的声明与注册1.1 基于XML配置1.2 基于注解(主流方式)1.3 基于Java

基于Python+PyQt5打造一个跨平台Emoji表情管理神器

《基于Python+PyQt5打造一个跨平台Emoji表情管理神器》在当今数字化社交时代,Emoji已成为全球通用的视觉语言,本文主要为大家详细介绍了如何使用Python和PyQt5开发一个功能全面的... 目录概述功能特性1. 全量Emoji集合2. 智能搜索系统3. 高效交互设计4. 现代化UI展示效果

Mysql中的用户管理实践

《Mysql中的用户管理实践》:本文主要介绍Mysql中的用户管理实践,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录13. 用户管理13.1 用户 13.1.1 用户信息 13.1.2 创建用户 13.1.3 删除用户 13.1.4 修改用户

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M