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

    文章

    20378

    浏览量

    255619
  • 寄存器
    +关注

    关注

    31

    文章

    5623

    浏览量

    130632
  • cpu
    cpu
    +关注

    关注

    68

    文章

    11370

    浏览量

    226408
  • 计数器
    +关注

    关注

    32

    文章

    2324

    浏览量

    98728
  • 定时器
    +关注

    关注

    23

    文章

    3378

    浏览量

    125079

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    探索Cebek I - 36延时定时器:设计与应用指南

    ,全方位剖析这款产品。 文件下载: I-36.pdf 一、I - 36延时定时器特性 电气参数 供电电压 :I - 36需要12V直流供电,稳定的电源对其性能至关重要。 功耗 :最小功耗为15 mA,最大功耗为70 mA。 定时
    的头像 发表于 05-11 14:40 137次阅读

    瑞萨RA系列FSP库开发实战指南之AGT低功耗定时器简介和结构框图

    瑞萨RA MCU有两种定时器外设:GPT(General PWM Timer)定时器和AGT(Asynchronous General Purpose Timer)定时器
    的头像 发表于 04-30 16:47 7562次阅读
    瑞萨RA<b class='flag-5'>系列</b>FSP库开发实战指南之AGT低功耗<b class='flag-5'>定时器</b>简介和结构框图

    深入剖析NE555定时器:特性、参数与应用

    深入剖析NE555定时器:特性、参数与应用 在电子工程师的工具箱中,NE555定时器是一款经典且实用的双极性集成电路。它以其高精度的定时功能和广泛的应用场景,在电子设计领域占据着重要的
    的头像 发表于 04-28 15:40 213次阅读

    PT8A2524-26/34-36/44-46通用定时器控制技术剖析

    PT8A2524-26/34-36/44-46通用定时器控制技术剖析 在电子设备的设计中,定时器控制是实现精确时间控制和安全电源管理的关
    的头像 发表于 03-27 14:05 190次阅读

    深入剖析TLC556:双LinCMOS定时器的技术魅力与应用潜力

    深入剖析TLC556:双LinCMOS定时器的技术魅力与应用潜力 在电子设计的广阔领域中,定时器作为一种基础且关键的组件,广泛应用于各种需要精确时间控制的场景。TLC556作为一款双LinCMOS
    的头像 发表于 02-10 15:40 521次阅读

    深入解析xx555系列精密定时器:功能、应用与设计要点

    深入解析xx555系列精密定时器:功能、应用与设计要点 在电子工程师的工具箱中,定时器是一种至关重要的组件,它广泛应用于各种电子设备中,用于实现精确的时间控制。今天,我们将深入探讨xx555
    的头像 发表于 02-10 15:40 1193次阅读

    深入解析 LM555 定时器:特性、应用与设计要点

    ,成为电子设计中的经典之选。本文将深入剖析 LM555 定时器的特性、应用场景以及设计过程中的注意事项,希望能为工程师们提供有价值的参考。 文件下载: lm555.pdf 二、LM555 定时器的特性 2.1 兼容性强 LM55
    的头像 发表于 02-10 15:35 657次阅读

    探索xx555系列精密定时器:从特性到应用的全面解析

    探索xx555系列精密定时器:从特性到应用的全面解析 在电子设计领域,定时器是一种不可或缺的基础元件,它能为各种电路提供精确的时间控制。今天我们要深入探讨的就是xx555系列
    的头像 发表于 02-10 15:20 3461次阅读

    探索xx555系列精密定时器:特性、应用与设计要点

    探索xx555系列精密定时器:特性、应用与设计要点 在电子设计领域,定时器是实现精确时间控制和信号处理的重要元件。今天,我们将深入探讨NA555、NE555、SA555、SE555这一系列
    的头像 发表于 02-10 14:45 346次阅读

    深入剖析LTC2956:多功能唤醒定时器的卓越之选

    深入剖析LTC2956:多功能唤醒定时器的卓越之选 在电子设备的设计中,如何实现高效的电源管理和精确的定时控制是关键问题。LTC2956作为一款具有强大功能的唤醒定时器,为工程师们提供
    的头像 发表于 02-08 16:00 722次阅读

    LAT1173高精度定时器的同步功能应用笔记

    STM32G474 所含的高精度定时器(HRTIMER)其实包含了多个定时器,多个定时器之间可以单独工作,也可以进行同步,且高精度定时器还能与片上的其他
    发表于 01-11 17:32 0次下载

    PWM、定时器、SysTick 区别及应用场景

    在单片机和嵌入式开发中,经常会遇到PWM(脉宽调制)、定时器、SysTick(系统滴答定时器)这几个词。很多初学者容易把它们混为一谈,以为都是“定时相关的东西”。其实,它们在本质和应用上有明显差别
    的头像 发表于 11-17 10:53 864次阅读
    PWM、<b class='flag-5'>定时器</b>、SysTick 区别及应用场景

    SysTick系统滴答定时器简介

    SysTick—系统定时器是属于CM33内核中的一个外设,内嵌在NVIC中。系统定时器是一个24bit的向下递减的计数,计数每计数一次的时间为 1/SYSCLK,一般我们设置系统时
    的头像 发表于 09-23 09:50 1908次阅读
    SysTick系统滴答<b class='flag-5'>定时器</b>简介

    fpga开发板 璞致ZYNQ 7000 系列之 PZ7035/PZ7045/PZ7100-FH 核心板与开发板用户手册

    本文介绍了Xilinx Zynq-7000系列可扩展处理平台及其开发板应用。Zynq-7000采用双核ARM Cortex-A9处理与28nm FPGA架构,支持高性能嵌入式开发。开
    的头像 发表于 09-15 15:54 7727次阅读
    fpga开发板 璞致<b class='flag-5'>ZYNQ</b> <b class='flag-5'>7000</b> <b class='flag-5'>系列</b>之 PZ7035/PZ7045/PZ7100-FH 核心板与开发板用户手册

    大彩讲堂:VisualHMI-LUA教程-定时器的使用指南

    定时器的使用
    的头像 发表于 08-31 16:59 1500次阅读
    大彩讲堂:VisualHMI-LUA教程-<b class='flag-5'>定时器</b>的使用指南