📄 hw_timer.h
字号:
/*
* TOPPERS/JSP Kernel
* Toyohashi Open Platform for Embedded Real-Time Systems/
* Just Standard Profile Kernel
*
* Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
* Toyohashi Univ. of Technology, JAPAN
*
* TOPPERS/JSP for Blackfin
*
* Copyright (C) 2004 by Suikan
* Copyright (C) 2004 by Ujinosuke
*
* 忋婰挊嶌尃幰偼丆埲壓偺 (1)乣(4) 偺忦審偐丆Free Software Foundation
* 偵傛偭偰岞昞偝傟偰偄傞 GNU General Public License 偺 Version 2 偵婰
* 弎偝傟偰偄傞忦審傪枮偨偡応崌偵尷傝丆杮僜僼僩僂僃傾乮杮僜僼僩僂僃傾
* 傪夵曄偟偨傕偺傪娷傓丏埲壓摨偠乯傪巊梡丒暋惢丒夵曄丒嵞攝晍乮埲壓丆
* 棙梡偲屇傇乯偡傞偙偲傪柍彏偱嫋戻偡傞丏
* (1) 杮僜僼僩僂僃傾傪僜乕僗僐乕僪偺宍偱棙梡偡傞応崌偵偼丆忋婰偺挊嶌
* 尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕偑丆偦偺傑傑偺宍偱僜乕
* 僗僐乕僪拞偵娷傑傟偰偄傞偙偲丏
* (2) 杮僜僼僩僂僃傾傪丆儔僀僽儔儕宍幃側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒傞宍偱嵞攝晍偡傞応崌偵偼丆嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡
* 幰儅僯儏傾儖側偳乯偵丆忋婰偺挊嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰
* 偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (3) 杮僜僼僩僂僃傾傪丆婡婍偵慻傒崬傓側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒側偄宍偱嵞攝晍偡傞応崌偵偼丆師偺偄偢傟偐偺忦審傪枮偨偡偙
* 偲丏
* (a) 嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡幰儅僯儏傾儖側偳乯偵丆忋婰偺挊
* 嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (b) 嵞攝晍偺宍懺傪丆暿偵掕傔傞曽朄偵傛偭偰丆TOPPERS僾儘僕僃僋僩偵
* 曬崘偡傞偙偲丏
* (4) 杮僜僼僩僂僃傾偺棙梡偵傛傝捈愙揑傑偨偼娫愙揑偵惗偠傞偄偐側傞懝
* 奞偐傜傕丆忋婰挊嶌尃幰偍傛傃TOPPERS僾儘僕僃僋僩傪柶愑偡傞偙偲丏
*
* 杮僜僼僩僂僃傾偼丆柍曐徹偱採嫙偝傟偰偄傞傕偺偱偁傞丏忋婰挊嶌尃幰偍
* 傛傃TOPPERS僾儘僕僃僋僩偼丆杮僜僼僩僂僃傾偵娭偟偰丆偦偺揔梡壜擻惈傕
* 娷傔偰丆偄偐側傞曐徹傕峴傢側偄丏傑偨丆杮僜僼僩僂僃傾偺棙梡偵傛傝捈
* 愙揑傑偨偼娫愙揑偵惗偠偨偄偐側傞懝奞偵娭偟偰傕丆偦偺愑擟傪晧傢側偄丏
*
*
*/
/*
* 僞僀儅僪儔僀僶乮ADSP-BF537梡乯
*
*/
#ifndef _HW_TIMER_H_
#define _HW_TIMER_H_
#include <s_services.h>
#ifndef _MACRO_ONLY
#include <cdefBF53x.h>
#include <ccblkfn.h>
/**************************************************************
* 僞僀儅偺婲摦張棟
*
* 僞僀儅傪弶婜壔偟丆廃婜揑側僞僀儅妱崬傒梫媮傪敪惗偝偣傞丏
*
**************************************************************/
Inline void
hw_timer_initialize()
{
#ifndef USE_TIC_CORE
UW reg;
#endif
#ifdef USE_TIC_CORE
// Core timer
*pTCNTL = TMPWR; // power up timer;
asm("ssync;");
*pTPERIOD = CORECLOCK/1000; // CORE CLOCK is defined in sys_config.h
asm("ssync;");
*pTCNTL = TMPWR | TMREN | TAUTORLD;
asm("ssync;");
#else
// GPT7(General-purpose timer7)
reg = *pSIC_IMASK;
reg |= SIC_MASK(INTNO_GP_TIMER7); //
*pSIC_IMASK = reg; // Interrupt enable
*pTIMER7_CONFIG = PERIOD_CNT | OUT_DIS |IRQ_ENA | PWM_OUT; // PWM_OUT, Output Pad disable
asm("csync;");
*pTIMER7_PERIOD = SYSCLOCK/1000; // SYS CLOCK is defined in sys_config.h
*pTIMER7_WIDTH = 1; // 0 < width < period
asm("ssync;");
*pTIMER_ENABLE = TIMEN7; // timer2 start
asm("ssync;");
ena_int( INHNO_TIMER ); // enable Timer Interrupt
#endif
}
/**************************************************************
* 僞僀儅妱崬傒梫媮偺僋儕傾
**************************************************************/
Inline void
hw_timer_int_clear()
{
#ifdef USE_TIC_CORE
// Core timer
*pTCNTL = TMPWR | TMREN | TAUTORLD | TINT;
asm("ssync;");
#else
// GPT7(General-purpose timer7)
*pTIMER_STATUS = TIMIL7;
asm("ssync;");
#endif
}
/**************************************************************
* 僞僀儅偺掆巭張棟
*
* 僞僀儅偺摦嶌傪掆巭偝偣傞丏
**************************************************************/
Inline void
hw_timer_terminate()
{
/*
* 僞僀儅偺摦嶌傪掆巭偡傞丏
*/
#ifdef USE_TIC_CORE
// Core timer
*pTCNTL = TMPWR | TAUTORLD | TINT; // 掆巭
asm("ssync;");
*pTCNTL = 0; // 僷儚乕僟僂儞儌乕僪
asm("ssync;");
#else
// GPT7(General-purpose timer7)
*pTIMER_DISABLE = TIMEN7; // timer7 disable
asm("ssync;");
#endif
}
#endif /* _MACRO_ONLY */
#endif /* _HW_TIMER_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -