日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > ZYNQ
		


每個 Cortex-A9 處理器都有自己的私有 32 位定時器和 32 位看門狗定時器,兩個處理器共享一個全局 64 位定時器,這些定時器始終以 CPU 頻率 (CPU_3x2x) 的 1/2 計時。

在系統(tǒng)層面,有一個 24 位看門狗定時器和兩個 16 位三重定時器/計數(shù)器。

系統(tǒng)看門狗定時器的時鐘頻率為 CPU 頻率 (CPU_1x) 的 1/4 或 1/6,或者可以由來自 MIO 引腳或來自 PL 的外部信號提供時鐘。

兩個三重定時器/計數(shù)器始終以 CPU 頻率 (CPU_1x) 的 1/4 或 1/6 計時,用于計算來自 MIO 引腳或來自 PL 的信號脈沖的寬度。

下圖顯示了系統(tǒng)定時器的關(guān)系

本文重點說一下全局定時器。

全局定時器

全局定時器是一個 64 位的具有自動遞增功能的遞增計數(shù)器。

全局定時器是內(nèi)存映射到與私有定時器相同的地址空間。

所有 Cortex-A9 處理器都可以訪問全局定時器。

每個 Cortex-A9 處理器都有一個 64 位比較器,用于在全局定時器達到比較器值時聲明一個私有中斷。

計時

GTC 始終以 CPU 頻率 (CPU_3x2x) 的 1/2 計時。

寄存器概述

有關(guān)GTC的注冊概述如下表

全局定時器寄存器概述

怎么使用?

下面兩個函數(shù)是在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;
}

官方已經(jīng)把全局定時器自動初始化好了,其頻率為CPU頻率的一半。

定義全局定時器的7個寄存器全部按照地址進行了宏定義,采用xil_io.h里的out32和in32兩個函數(shù)進行讀寫操作:

#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 

接下來進行全局定時器的初始化和中斷函數(shù)綁定:

GT_Write_Reg(Global_Timer_Control_Register,0);//停止全局定時器
GT_Write_Reg(Global_Timer_Counter_Register0,0);//清空計數(shù)器低32位
GT_Write_Reg(Global_Timer_Counter_Register1,0);//清空計數(shù)器高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);//加載遞增寄存器數(shù)值
Status = XScuGic_Connect(IntcInstancePtr, Global_Timer_INTR,
 (Xil_ExceptionHandler)TimerIntrHandler,
 0);//綁定全局定時器中斷服務(wù)函數(shù) 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);

總結(jié)

全局定時器一共7個寄存器,打開SDK再想看看對應(yīng)的BSP文檔時就會發(fā)現(xiàn)還是很復雜的。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
關(guān)閉