/*
 *  TOPPERS/ASP Kernel
 *      Toyohashi Open Platform for Embedded Real-Time Systems/
 *      Advanced Standard Profile Kernel
 * 
 *  Copyright (C) 2007 by Embedded and Real-Time Systems Laboratory
 *              Graduate School of Information Science, Nagoya Univ., JAPAN
 *  Copyright (C) 2011 by Naoki Saito
 *             Nagoya Municipal Industrial Research Institute, JAPAN
 * 
 *  上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
 *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
 *  変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
 *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
 *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
 *      スコード中に含まれていること.
 *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
 *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
 *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
 *      の無保証規定を掲載すること.
 *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
 *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
 *      と.
 *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
 *        作権表示,この利用条件および下記の無保証規定を掲載すること.
 *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
 *        報告すること.
 *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
 *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
 *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
 *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
 *      免責すること.
 * 
 *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
 *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
 *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
 *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
 *  の責任を負わない.
 * 
 *  @(#) $Id: prc_timer.c 1304 2008-08-27 07:28:36Z ertl-honda $
 */

/*
 *  カーネルのタイムティック用タイマドライバ(Renesas Starter Kit for M32C/87)
 *    ターゲット毎に使用するタイマデバイスが異なり得ることから
 *    このファイルをターゲット依存部に配置する.
 *    ここでは,タイマ A0 をカーネルのタイムティック供給用タイマとして使用する.
 */
#include "kernel_impl.h"
#include "target_timer.h"
#include "time_event.h"

/*
 *  タイマの起動処理
 */
void
target_timer_initialize(intptr_t exinf)
{
	uint8_t	tmp;

	tmp = sil_reb_mem((void *)TADR_TABSR);	/* タイマカウント停止  */
	tmp &= ~TBIT_TABSR_TA0S;
	sil_wrb_mem((void *)TADR_TABSR, tmp);

	sil_wrb_mem((void *)TADR_UDF, 0x00);	/* ダウンカウント設定	*/
	sil_wrb_mem((void *)TADR_TA0MR, 0x00);	/*  カウントソースf1, タイマモード  */

	/*
	 *  タイマは 1msで TIMER_CLOCK カウント,
	 *  レジスタ設定値はマイナス1する.
	 */
	sil_wrh_mem((void *)TADR_TA0, TIMER_CLOCK - 1);

	/* カウント開始	*/
	tmp = sil_reb_mem((void *)TADR_TABSR);	/* タイマカウント停止  */
	tmp |= TBIT_TABSR_TA0S;
	sil_wrb_mem((void *)TADR_TABSR, tmp);
}

/*
 *  タイマの停止処理
 */
void
target_timer_terminate(intptr_t exinf)
{
	uint8_t	tmp;

	tmp = sil_reb_mem((void *)TADR_TABSR);	/* タイマカウント停止  */
	tmp &= ~TBIT_TABSR_TA0S;
	sil_wrb_mem((void *)TADR_TABSR, tmp);
}

/*
 *  タイマ割込みハンドラ
 */
void
target_timer_handler(void)
{
	signal_time();                    /* タイムティックの供給 */
}