0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

剖析Zynq-7000系列全局定时器(GT)

FPGA开源工作室 来源:ZYNQ 作者:小默 2021-06-16 16:49 次阅读

每个 Cortex-A9 处理器都有自己的私有 32 位定时器和 32 位看门狗定时器,两个处理器共享一个全局 64 位定时器,这些定时器始终以 CPU 频率 (CPU_3x2x) 的 1/2 计时。

在系统层面,有一个 24 位看门狗定时器和两个 16 位三重定时器/计数器。

系统看门狗定时器的时钟频率为 CPU 频率 (CPU_1x) 的 1/4 或 1/6,或者可以由来自 MIO 引脚或来自 PL 的外部信号提供时钟。

两个三重定时器/计数器始终以 CPU 频率 (CPU_1x) 的 1/4 或 1/6 计时,用于计算来自 MIO 引脚或来自 PL 的信号脉冲的宽度。

下图显示了系统定时器的关系

本文重点说一下全局定时器。

全局定时器

全局定时器是一个 64 位的具有自动递增功能的递增计数器。

全局定时器是内存映射到与私有定时器相同的地址空间。

所有 Cortex-A9 处理器都可以访问全局定时器。

每个 Cortex-A9 处理器都有一个 64 位比较器,用于在全局定时器达到比较器值时声明一个私有中断。

计时

GTC 始终以 CPU 频率 (CPU_3x2x) 的 1/2 计时。

寄存器概述

有关GTC的注册概述如下表

411eb9ec-cac4-11eb-9e57-12bb97331649.png

全局定时器寄存器概述

怎么使用?

下面两个函数是在bsp standalone中的xtime_l.c中。

void XTime_SetTime(XTime Xtime_Global)

{

/* Disable Global Timer */

Xil_Out32((u32)GLOBAL_TMR_BASEADDR +(u32)GTIMER_CONTROL_OFFSET, (u32)0x0);

/* Updating Global Timer Counter Register */

Xil_Out32((u32)GLOBAL_TMR_BASEADDR +(u32)GTIMER_COUNTER_LOWER_OFFSET, (u32)Xtime_Global);

Xil_Out32((u32)GLOBAL_TMR_BASEADDR +(u32)GTIMER_COUNTER_UPPER_OFFSET,

(u32)((u32)(Xtime_Global》》32U)));

/* Enable Global Timer */

Xil_Out32((u32)GLOBAL_TMR_BASEADDR + (u32)GTIMER_CONTROL_OFFSET, (u32)0x1);

}

void XTime_GetTime(XTime *Xtime_Global)

{

u32 low;

u32 high;

/* Reading Global Timer Counter Register */

do

{

high = Xil_In32(GLOBAL_TMR_BASEADDR + GTIMER_COUNTER_UPPER_OFFSET);

low = Xil_In32(GLOBAL_TMR_BASEADDR + GTIMER_COUNTER_LOWER_OFFSET);

} while(Xil_In32(GLOBAL_TMR_BASEADDR + GTIMER_COUNTER_UPPER_OFFSET) != high);

*Xtime_Global = (((XTime) high) 《《 32U) | (XTime) low;

}

官方已经把全局定时器自动初始化好了,其频率为CPU频率的一半。

定义全局定时器的7个寄存器全部按照地址进行了宏定义,采用xil_io.h里的out32和in32两个函数进行读写操作:

#define Global_Timer_INTR XPAR_GLOBAL_TMR_INTR#define Global_Timer_Counter_Register0 XPAR_GLOBAL_TMR_BASEADDR+0x0U#define Global_Timer_Counter_Register1 XPAR_GLOBAL_TMR_BASEADDR+0x4U#define Global_Timer_Control_Register XPAR_GLOBAL_TMR_BASEADDR+0x8U#define Global_Timer_Interrupt_Status_Register XPAR_GLOBAL_TMR_BASEADDR+0xCU#define Comparator_Value_Register0 XPAR_GLOBAL_TMR_BASEADDR+0x10U#define Comparator_Value_Register1 XPAR_GLOBAL_TMR_BASEADDR+0x14U#define Auto_increment_Register XPAR_GLOBAL_TMR_BASEADDR+0x18U

接下来进行全局定时器的初始化和中断函数绑定:

GT_Write_Reg(Global_Timer_Control_Register,0);//停止全局定时器

GT_Write_Reg(Global_Timer_Counter_Register0,0);//清空计数器低32位

GT_Write_Reg(Global_Timer_Counter_Register1,0);//清空计数器高32位

GT_Write_Reg(Global_Timer_Interrupt_Status_Register,1);//清除中断标志位

GT_Write_Reg(Comparator_Value_Register0,TIMER_LOAD_VALUE);//加载比较器低32位

GT_Write_Reg(Comparator_Value_Register1,0);//加载比较器高32位

GT_Write_Reg(Auto_increment_Register,TIMER_LOAD_VALUE);//加载递增寄存器数值

Status = XScuGic_Connect(IntcInstancePtr, Global_Timer_INTR,

(Xil_ExceptionHandler)TimerIntrHandler,

0);//绑定全局定时器中断服务函数

if (Status != XST_SUCCESS)

{

return Status;

}

XScuGic_InterruptMaptoCpu(IntcInstancePtr,1,Global_Timer_INTR);//将27号全局定时器中断映射到CPU1

XScuGic_Enable(IntcInstancePtr, Global_Timer_INTR);//打开全局定时器中断(27号)

主程序中打开全局定时器开始计时

GT_Write_Reg(Global_Timer_Control_Register,//启动全局定时器

Auto_Increment_Bit|IRQ_Enable_Bit|Comp_Enable_Bit|Timer_Enable_Bit);

总结

全局定时器一共7个寄存器,打开SDK再想看看对应的BSP文档时就会发现还是很复杂的。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    19125

    浏览量

    228888
  • 寄存器
    +关注

    关注

    31

    文章

    5304

    浏览量

    119886
  • cpu
    cpu
    +关注

    关注

    68

    文章

    10813

    浏览量

    210918
  • 计数器
    +关注

    关注

    32

    文章

    2253

    浏览量

    94302
  • 定时器
    +关注

    关注

    23

    文章

    3234

    浏览量

    114371

原文标题:Zynq-7000系列全局定时器(GT)详解

文章出处:【微信号:leezym0317,微信公众号:FPGA开源工作室】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    当ADC3663的LVDS输出给到ZYNQ-7000的LVDS接收这两者之间可以直连吗?

    ADC3663的LVDS差分输出与xilinx的ZYNQ-7000的LVDS输入的电平匹配问题 ADC3663的供电是1.8V,ADC3663的LVDS输出给到ZYNQ-7000的BANK12
    发表于 11-14 07:43

    Xilinx ZYNQ 7000系列SoC的功能特性

    本文介绍下Xilinx ZYNQ 7000系列SoC的功能特性、资源特性、封装兼容性以及如何订购器件。
    的头像 发表于 10-24 15:04 276次阅读
    Xilinx <b class='flag-5'>ZYNQ</b> <b class='flag-5'>7000</b><b class='flag-5'>系列</b>SoC的功能特性

    [XILINX] 正点原子ZYNQ7035/7045/7100开发板发布、ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2!

    正点原子FPGA新品ZYNQ7035/7045/7100开发板,ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2! 正点原子Z100
    发表于 09-02 17:18

    定时器的工作方式介绍

    定时器是计算机和嵌入式系统中常见的一种硬件模块,用于实现定时和计数功能。定时器的工作方式通常由一组寄存来控制,这些寄存定义了
    的头像 发表于 07-12 10:29 671次阅读

    定时器相关的寄存有哪些类型

    ,微控制通常提供了一系列定时器寄存,用于配置和控制定时器的行为。 以下是一些常见的与定时器
    的头像 发表于 07-12 10:25 713次阅读

    简谈Xilinx Zynq-7000嵌入式系统设计与实现

    今天给大侠带来简谈Xilinx Zynq-7000嵌入式系统设计与实现,话不多说,上货。 Xilinx的ZYNQ系列FPGA是二种看上去对立面的思想的融合,ARM处理的串行执
    发表于 05-08 16:23

    Xilinx ZYNQ 动手实操演练

    。可编程逻辑可由用户配置,并通过“互连”模块连接在一起,这样可以提供用户自定义的任意逻辑功能,从而扩展处理系统的性能及功能。不过,与采用嵌入式处理的FPGA不同,Zynq-7000产品系列
    发表于 05-03 19:28

    如何实现一个软件定时器

    在Linux,uC/OS,FreeRTOS等操作系统中,都带有软件定时器,原理大同小异。典型的实现方法是:通过一个硬件定时器产生固定的时钟节拍,每次硬件定时器中断到,就对一个全局的时间
    的头像 发表于 04-29 11:00 571次阅读

    Zynq-7000为何不是FPGA?

    Zynq-7000可扩展处理平台是采用赛灵思新一代FPGA(Artix-7与Kintex-7FPGA)所采用的同一28nm可编程技术的最新产品系列
    发表于 04-26 11:30 1068次阅读
    <b class='flag-5'>Zynq-7000</b>为何不是FPGA?

    简谈Xilinx Zynq-7000嵌入式系统设计与实现

    今天给大侠带来简谈Xilinx Zynq-7000嵌入式系统设计与实现,话不多说,上货。 Xilinx的ZYNQ系列FPGA是二种看上去对立面的思想的融合,ARM处理的串行执
    发表于 04-10 16:00

    定时器在STEP 7V5.x及STEP 7(TIA Portal)的不同处理步骤

    基于STEP 5的兼容性,仍然可以使用STEP7 S5定时器与计数定时器和计数全局的且基于编号寻址,当启动
    的头像 发表于 04-07 11:35 1618次阅读
    <b class='flag-5'>定时器</b>在STEP 7V5.x及STEP 7(TIA Portal)的不同处理步骤

    使用555定时器的可调双定时器电路

    定时器 IC 555 是最通用和最常用的 IC 之一,因为它的应用范围更广,如 PWM放大器、延迟定时器、开关电路、占空比选择、时钟脉冲发生等。这也可用于各种应用,如精确
    的头像 发表于 02-25 15:16 1962次阅读
    使用555<b class='flag-5'>定时器</b>的可调双<b class='flag-5'>定时器</b>电路

    AT32 定时器配置中pr和div的作用

    AT32定时器是51系列单片机中的一种定时器,可以实现多种定时功能。在AT32定时器中,pr和div是两个相关的参数,用于配置
    的头像 发表于 01-08 10:12 1178次阅读

    单片机定时器的用法

    本章以CW32通用定时器为例介绍单片机定时器的用法。
    的头像 发表于 01-04 10:37 1326次阅读
    单片机<b class='flag-5'>定时器</b>的用法

    定时器会阻塞线程吗 定时器指令有哪几种

    定时器会阻塞线程吗 定时器指令有哪几种  定时器一般不会阻塞线程,但具体是否会阻塞取决于所使用的定时器实现方式和使用方式。 定时器指令可以分
    的头像 发表于 12-19 14:03 870次阅读