source: rubycfg_asp/trunk/asp_dcre/target/gr_sakura_ccrx/target_timer.c@ 315

Last change on this file since 315 was 315, checked in by coas-nagasima, 7 years ago

SVNプロパティを設定

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc; charset=UTF-8
File size: 4.5 KB
Line 
1/*
2 * TOPPERS/ASP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Advanced Standard Profile Kernel
5 *
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2003-2004 by Naoki Saito
9 * Nagoya Municipal Industrial Research Institute, JAPAN
10 * Copyright (C) 2003-2004 by Platform Development Center
11 * RICOH COMPANY,LTD. JAPAN
12 * Copyright (C) 2008-2010 by Witz Corporation, JAPAN
13 * Copyright (C) 2013 by Mitsuhiro Matsuura
14 *
15 * 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
16 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
17 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
18 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
19 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
20 * スコード中に含まれていること.
21 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
22 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
23 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
24 * の無保証規定を掲載すること.
25 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
26 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
27 * と.
28 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
29 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
30 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
31 * 報告すること.
32 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
33 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
34 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
35 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
36 * 免責すること.
37 *
38 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
39 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
40 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
41 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
42 * の責任を負わない.
43 *
44 * @(#) $Id: target_timer.c 315 2017-07-23 05:29:40Z coas-nagasima $
45 */
46
47/*
48 * タイマドライバ
49 */
50
51#include "kernel_impl.h"
52#include "time_event.h"
53#include <sil.h>
54#include "target_timer.h"
55
56/*
57 * タイマの初期化処理
58 */
59void
60target_timer_initialize(intptr_t exinf)
61{
62 /*
63 * モジュールストップ機能の設定
64 */
65 sil_wrh_mem((void *)SYSTEM_PRCR_ADDR, (uint16_t)0xA502); /* 書込み許可 */
66 *SYSTEM_MSTPCRA_ADDR &= ~(SYSTEM_MSTPCRA_MSTPA15_BIT);
67 sil_wrh_mem((void *)SYSTEM_PRCR_ADDR, (uint16_t)0xA500); /* 書込み禁止 */
68
69 /*
70 * タイマ停止
71 */
72 *CMT_CMSTR0_ADDR &= ~CMT_CMSTR0_STR0_BIT;
73
74 /*
75 * カウントアップに用いられるクロック設定
76 * PCLK/32を選択
77 */
78 *CMT0_CMCR_ADDR = CMT_PCLK_DIV_8;
79
80 /*
81 * コンペアマッチタイマカウンタ設定
82 */
83 *CMT0_CMCNT_ADDR = 0U;
84
85 /*
86 * コンペアマッチタイマ周期設定
87 */
88 *CMT0_CMCOR_ADDR = CMCOR_PERIOD;
89
90 /*
91 * コンペアマッチタイマ割り込み要求先設定レジスタ(ISELR28)
92 */
93 *ICU_ISELR028_ADDR = ICU_ISEL_CPU;
94
95 /*
96 * タイマ動作開始前の割込み要求をクリア
97 */
98 x_clear_int(INTNO_TIMER);
99
100 /*
101 * コンペアマッチタイマ割り込みを許可
102 */
103 *CMT0_CMCR_ADDR |= CMT0_CMCR_CMIE_BIT;
104
105 /*
106 * タイマ動作開始
107 */
108 *CMT_CMSTR0_ADDR |= CMT_CMSTR0_STR0_BIT;
109}
110
111/*
112 * タイマの停止処理
113 */
114void
115target_timer_terminate(intptr_t exinf)
116{
117 /*
118 * タイマ停止
119 */
120 *CMT_CMSTR0_ADDR &= ~CMT_CMSTR0_STR0_BIT;
121}
122
123/*
124 * タイマ割込みハンドラ
125 */
126void target_timer_handler(void)
127{
128 i_begin_int(INTNO_TIMER);
129
130 signal_time(); /* タイムティックの供給 */
131
132 i_end_int(INTNO_TIMER);
133}
Note: See TracBrowser for help on using the repository browser.