/* * TOPPERS/ASP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Advanced Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * Copyright (C) 2005-2015 by Embedded and Real-Time Systems Laboratory * Graduate School of Information Science, Nagoya Univ., JAPAN * * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する. * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー * スコード中に含まれていること. * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 * の無保証規定を掲載すること. * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ * と. * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 * 作権表示,この利用条件および下記の無保証規定を掲載すること. * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに * 報告すること. * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを * 免責すること. * * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ * の責任を負わない. * * $Id: chip_timer.h 358 2015-07-26 10:26:23Z ertl-hiro $ */ /* * タイマドライバ(MPCore内蔵タイマ用) * * ARM11 MPCoreには,コア毎にタイマとウォッチドッグがある.ウォッチドッ * グは,タイマとして使用することもできるため,この2つのタイマを使って * 高分解能タイマを実現する.具体的には,ウォッチドッグをタイマモード * に設定して現在時刻の管理のために用い,タイマを相対時間割込みの発生 * のために用いる. */ #ifndef TOPPERS_CHIP_TIMER_H #define TOPPERS_CHIP_TIMER_H #include #include "mpcore.h" /* * タイマ割込みハンドラ登録のための定数 */ #define INHNO_TIMER MPCORE_IRQNO_TMR /* 割込みハンドラ番号 */ #define INTNO_TIMER MPCORE_IRQNO_TMR /* 割込み番号 */ #define INTPRI_TIMER (TMAX_INTPRI - 1) /* 割込み優先度 */ #define INTATR_TIMER TA_NULL /* 割込み属性 */ #ifndef TOPPERS_MACRO_ONLY /* * 高分解能タイマの起動処理 */ extern void target_hrt_initialize(intptr_t exinf); /* * 高分解能タイマの停止処理 */ extern void target_hrt_terminate(intptr_t exinf); /* * 高分解能タイマの現在のカウント値の読出し */ Inline HRTCNT target_hrt_get_current(void) { /* * ウォッチドッグのカウント値を読み出し,ダウンカウンタであるため, * ビット反転して返す. */ return((HRTCNT) ~(sil_rew_mem(MPCORE_WDG_CNT))); } /* * 高分解能タイマへの割込みタイミングの設定 * * 高分解能タイマを,hrtcntで指定した値カウントアップしたら割込みを発 * 生させるように設定する. */ Inline void target_hrt_set_event(HRTCNT hrtcnt) { /* * タイマのカウント値をhrtcntに設定する. */ sil_wrw_mem(MPCORE_TMR_CNT, hrtcnt); } /* * 高分解能タイマ割込みの要求 * * 暫定的に,1μ秒後に高分解能タイマ割込みがかかるように設定しているが, * 即座に割込みを要求する方法がわかれば(Set-pending Registerが使える * と思われる),それに差し換える. */ Inline void target_hrt_raise_event(void) { target_hrt_set_event(1U); } /* * 割込みタイミングに指定する最大値 */ #define HRTCNT_BOUND 4000000002U /* * 高分解能タイマ割込みハンドラ */ extern void target_hrt_handler(void); #endif /* TOPPERS_MACRO_ONLY */ #endif /* TOPPERS_CHIP_TIMER_H */