📄 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 * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: hw_timer.h,v 1.7 2003/12/11 00:58:01 honda Exp $ */#ifndef _HW_TIMER_H_#define _HW_TIMER_H_/* * CPU巴赂タイマモジュ〖ル∈MicroBlaze脱∷ */ #include <s_services.h>#include <microblaze.h>/* * タイマ充哈みハンドラの充哈み戎规 */#define INHNO_TIMER TIMINTLVL#ifndef _MACRO_ONLY/* * タイマ猛の柒婶山附の房 */typedef UW CLOCK;/* * タイマ猛の柒婶山附とミリ擅ˇμ擅帽疤との恃垂 * TIMER_CLOCK はタ〖ゲットボ〖ド髓に肋年 */#define TO_CLOCK(nume, deno) (TIMER_CLOCK * (nume) / (deno))#define TO_USEC(clock) ((clock) * 1000 / TIMER_CLOCK)/* * 肋年できる呵络タイマ件袋∈帽疤は柒婶山附∷ */#define MAX_CLOCK ((CLOCK) 0xffffffff)/* * 拉墙删擦脱システム箕癸を艰り叫す狠の借妄箕粗の斧姥り猛∈帽疤は柒婶山附∷ */#define GET_TOLERANCE 100#define BEFORE_IREQ(clock) \ ((clock) >= TO_CLOCK(TIC_NUME, TIC_DENO) - GET_TOLERANCE)/* * タイマの弹瓢借妄 * * タイマを介袋步し·件袋弄なタイマ充哈みを券栏させる */ Inline voidhw_timer_initialize(void){ CLOCK cyc = TO_CLOCK(TIC_NUME, TIC_DENO); sil_wrw_mem((VP)TIMER_TCSR0,TIMER_RESET); /* リセット */ assert(cyc <= MAX_CLOCK); /* タイマ惧嘎猛のチェック */ sil_wrw_mem((VP)TIMER_TCCR0, cyc); /* カウンタ〖セット */ /* * タイマ〖0イネ〖ブル·オ〖トリロ〖ド·ダウンカウント 充哈み钓材 */ sil_wrw_mem((VP)TIMER_TCSR0,TIMER_ENABLE | TIMER_RELOAD | TIMER_DOWN_COUNT | TIMER_ENABLE_INTR); /* * INTC充哈み钓材 */ intc_enable_interrupt((1 << (TIMINTLVL - 1)));}/* * タイマ充哈み妥滇のクリア */Inline voidhw_timer_int_clear(){ sil_wrw_mem((VP)TIMER_TCSR0,sil_rew_mem((VP)TIMER_TCSR0)); /* * レベル充哈みのため·充哈み妥傍を布ろした稿にACK */ intc_ack_interrupt(1 << (TIMINTLVL - 1));}/* * タイマの敦贿借妄 */Inline voidhw_timer_terminate(){ int dummy; sil_wrw_mem((VP)TIMER_TCSR0, ~TIMER_ENABLE); /* タイマ匿贿 */ sil_wrw_mem((VP)TIMER_TCSR0, sil_rew_mem((VP)TIMER_TCSR0)); /* 充哈み妥滇のクリア */ /* * すでに充哈みが掐っている眷圭があるので充哈み妥滇をクリア */ dummy = 1 << (TIMINTLVL - 1); intc_ack_interrupt(dummy); intc_disable_interrupt(dummy); /* INTCの减け烧け敦贿 */}/* * タイマの附哼猛の粕み叫し * * 充哈み敦贿惰粗面で钙び叫すこと */Inline CLOCKhw_timer_get_current(void){ return(TO_CLOCK(TIC_NUME, TIC_DENO) - sil_rew_mem((VP)TIMER_TCR0));}/* * 充哈みが券栏しているかの冉年 */Inline BOOLhw_timer_fetch_interrupt(void){ return(sil_rew_mem((VP)TIMER_TCSR0) & TIMER_INTERRUPT);}#endif /* _MACRO_ONLY */#endif /* _HW_TIMER_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -