Ignore:
Timestamp:
Aug 23, 2017, 9:27:43 AM (7 years ago)
Author:
coas-nagasima
Message:

文字コードを設定

File:
1 edited

Legend:

Unmodified
Added
Removed
  • EcnlProtoTool/trunk/asp3_dcre/arch/arm_gcc/rza1/chip_timer.h

    • Property svn:keywords deleted
    • Property svn:mime-type changed from text/x-chdr to text/x-chdr;charset=UTF-8
    r270 r321  
    99 *              Graduate School of Information Science, Nagoya Univ., JAPAN
    1010 *
    11  *  上記著作権è€
    12 ã¯ï¼Œä»¥ä¸‹ã®(1)~(4)の条件を満たす場合に限り,本ソフトウェ
    13  *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
    14  *  変・再é
    15 å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
    16  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
    17  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
    18  *      スコード中に含まれていること.
    19  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
    20  *      用できる形で再é
    21 å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é
    22 å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
    23  *      è€
    24 ãƒžãƒ‹ãƒ¥ã‚¢ãƒ«ãªã©ï¼‰ã«ï¼Œä¸Šè¨˜ã®è‘—作権表示,この利用条件および下記
    25  *      の無保証規定を掲載すること.
    26  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
    27  *      用できない形で再é
    28 å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
    29  *      と.
    30  *    (a) 再é
    31 å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€
    32 ãƒžãƒ‹ãƒ¥ã‚¢ãƒ«ãªã©ï¼‰ã«ï¼Œä¸Šè¨˜ã®è‘—
    33  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
    34  *    (b) 再é
    35 å¸ƒã®å½¢æ
    36 ‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
    37  *        報告すること.
    38  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
    39  *      害からも,上記著作権è€
    40 ãŠã‚ˆã³TOPPERSプロジェクトをå
    41 è²¬ã™ã‚‹ã“と.
    42  *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
    43  *      由に基づく請求からも,上記著作権è€
    44 ãŠã‚ˆã³TOPPERSプロジェクトを
    45  *      å
    46 è²¬ã™ã‚‹ã“と.
    47  *
    48  *  本ソフトウェアは,無保証で提供されているものである.上記著作権è€
    49 ãŠ
    50  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
    51  *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
    52  *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
    53  *  の責任を負わない.
     11 *  上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
     12 *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
     13 *  変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
     14 *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
     15 *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
     16 *      スコード中に含まれていること.
     17 *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
     18 *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
     19 *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
     20 *      の無保証規定を掲載すること.
     21 *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
     22 *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
     23 *      と.
     24 *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
     25 *        作権表示,この利用条件および下記の無保証規定を掲載すること.
     26 *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
     27 *        報告すること.
     28 *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
     29 *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
     30 *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
     31 *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
     32 *      免責すること.
     33 *
     34 *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
     35 *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
     36 *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
     37 *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
     38 *  の責任を負わない.
    5439 *
    5540 *  $Id$
     
    5742
    5843/*
    59  *              タイマドライバ(RZ/A1 OSタイマ用)
     44 *              タイマドライバ(RZ/A1 OSタイマ用)
    6045 *
    61  *  RZ/A1は2チャンネルのOSタイマを持つが,そのå†
    62 ã®1つを用いて高分解能タ
    63  *  イマを,もう1つを用いてオーバランタイマを実現する.
     46 *  RZ/A1は2チャンネルのOSタイマを持つが,その内の1つを用いて高分解能タ
     47 *  イマを,もう1つを用いてオーバランタイマを実現する.
    6448 */
    6549
     
    7155
    7256/*
    73  *  タイマ割込みハンドラ登録のための定数
    74  */
    75 #define INHNO_TIMER             INTNO_OSTM0                     /* 割込みハンドラ番号 */
    76 #define INTNO_TIMER             INTNO_OSTM0                     /* 割込み番号 */
    77 #define INTPRI_TIMER    (TMAX_INTPRI - 1)       /* 割込み優å
    78 ˆåº¦ */
    79 #define INTATR_TIMER    TA_EDGE                         /* 割込み属性 */
    80 
    81 /*
    82  *  オーバランタイマ割込みハンドラ登録のための定数
     57 *  タイマ割込みハンドラ登録のための定数
     58 */
     59#define INHNO_TIMER             INTNO_OSTM0                     /* 割込みハンドラ番号 */
     60#define INTNO_TIMER             INTNO_OSTM0                     /* 割込み番号 */
     61#define INTPRI_TIMER    (TMAX_INTPRI - 1)       /* 割込み優先度 */
     62#define INTATR_TIMER    TA_EDGE                         /* 割込み属性 */
     63
     64/*
     65 *  オーバランタイマ割込みハンドラ登録のための定数
    8366 */
    8467#ifdef TOPPERS_SUPPORT_OVRHDR
    85 #define INHNO_OVRTIMER          INTNO_OSTM1                     /* 割込みハンドラ番号 */
    86 #define INTNO_OVRTIMER          INTNO_OSTM1                     /* 割込み番号 */
    87 #define INTPRI_OVRTIMER         TMAX_INTPRI                     /* 割込み優å
    88 ˆåº¦ */
    89 #define INTATR_OVRTIMER         TA_EDGE                         /* 割込み属性 */
     68#define INHNO_OVRTIMER          INTNO_OSTM1                     /* 割込みハンドラ番号 */
     69#define INTNO_OVRTIMER          INTNO_OSTM1                     /* 割込み番号 */
     70#define INTPRI_OVRTIMER         TMAX_INTPRI                     /* 割込み優先度 */
     71#define INTATR_OVRTIMER         TA_EDGE                         /* 割込み属性 */
    9072#endif /* TOPPERS_SUPPORT_OVRHDR */
    9173
    9274/*
    93  *  OSタイマの周波数の想定値のチェック
     75 *  OSタイマの周波数の想定値のチェック
    9476 *
    95  *  現在の実è£
    96 ã¯ï¼Œã‚¯ãƒ­ãƒƒã‚¯ãŒ33.33…MHzの場合のみに対応している.
     77 *  現在の実装は,クロックが33.33…MHzの場合のみに対応している.
    9778 */
    9879#if OSTM_CLK != 33333333UL
     
    10182
    10283/*
    103  *  OSタイマレジスタの番地の定義
     84 *  OSタイマレジスタの番地の定義
    10485 */
    10586#define OSTM_CMP(base)          ((uint32_t *)(base + 0x00U))
     
    11192
    11293/*
    113  *  OSタイマ カウント開始トリガレジスタの設定値の定義
     94 *  OSタイマ カウント開始トリガレジスタの設定値の定義
    11495 */
    11596#define OSTM_TS_START           0x01U
    11697
    11798/*
    118  *  OSタイマ カウント停止トリガレジスタの設定値の定義
     99 *  OSタイマ カウント停止トリガレジスタの設定値の定義
    119100 */
    120101#define OSTM_TT_STOP            0x01U
    121102
    122103/*
    123  *  OSタイマ 制御レジスタの設定値の定義
    124  */
    125 #define OSTM_CTL_INTERVAL       0x00U           /* インターバルタイマモード */
    126 #define OSTM_CTL_FRCMP          0x02U           /* フリーランニングコンペアモード */
     104 *  OSタイマ 制御レジスタの設定値の定義
     105 */
     106#define OSTM_CTL_INTERVAL       0x00U           /* インターバルタイマモード */
     107#define OSTM_CTL_FRCMP          0x02U           /* フリーランニングコンペアモード */
    127108
    128109#ifndef TOPPERS_MACRO_ONLY
    129110
    130111/*
    131  *  高分解能タイマの起動処理
     112 *  高分解能タイマの起動処理
    132113 */
    133114extern void     target_hrt_initialize(intptr_t exinf);
    134115
    135116/*
    136  *  高分解能タイマの停止処理
     117 *  高分解能タイマの停止処理
    137118 */
    138119extern void     target_hrt_terminate(intptr_t exinf);
    139120
    140121/*
    141  *  高分解能タイマの現在のカウント値の読出し
     122 *  高分解能タイマの現在のカウント値の読出し
    142123 */
    143124Inline HRTCNT
     
    148129        cnt = sil_rew_mem(OSTM_CNT(OSTM0_BASE));
    149130
    150         /* μ秒単位に変換(クロックが33.33…MHzである前提)*/
     131        /* μ秒単位に変換(クロックが33.33…MHzである前提)*/
    151132        cnt1 = cnt / 1000000000;
    152133        return((HRTCNT)((cnt - cnt1 * 999999999) * 3 / 100 + cnt1 * 30000000));
     
    154135
    155136/*
    156  *  高分解能タイマへの割込みタイミングの設定
     137 *  高分解能タイマへの割込みタイミングの設定
    157138 *
    158  *  高分解能タイマを,hrtcntで指定した値カウントアップしたら割込みを発
    159  *  生させるように設定する.
     139 *  高分解能タイマを,hrtcntで指定した値カウントアップしたら割込みを発
     140 *  生させるように設定する.
    160141 */
    161142extern void target_hrt_set_event(HRTCNT hrtcnt);
    162143
    163144/*
    164  *  高分解能タイマ割込みの要求
     145 *  高分解能タイマ割込みの要求
    165146 */
    166147extern  void target_hrt_raise_event(void);
    167148
    168149/*
    169  *  割込みタイミングに指定する最大値
     150 *  割込みタイミングに指定する最大値
    170151 */
    171152#define HRTCNT_BOUND    100000002U
    172153
    173154/*
    174  *  高分解能タイマ割込みハンドラ
     155 *  高分解能タイマ割込みハンドラ
    175156 */
    176157extern void     target_hrt_handler(void);
     
    179160
    180161/*
    181  *  オーバランタイマの初期化処理
     162 *  オーバランタイマの初期化処理
    182163 */
    183164extern void target_ovrtimer_initialize(intptr_t exinf);
    184165
    185166/*
    186  *  オーバランタイマの停止処理
     167 *  オーバランタイマの停止処理
    187168 */
    188169extern void target_ovrtimer_terminate(intptr_t exinf);
    189170
    190171/*
    191  *  オーバランタイマの動作開始
     172 *  オーバランタイマの動作開始
    192173 */
    193174Inline void
     
    201182
    202183/*
    203  *  オーバランタイマの停止
     184 *  オーバランタイマの停止
    204185 */
    205186extern PRCTIM target_ovrtimer_stop(void);
    206187
    207188/*
    208  *  オーバランタイマの現在値の読出し
     189 *  オーバランタイマの現在値の読出し
    209190 */
    210191extern PRCTIM target_ovrtimer_get_current(void);
    211192
    212193/*
    213  *  オーバランタイマ割込みハンドラ
     194 *  オーバランタイマ割込みハンドラ
    214195 */
    215196extern void     target_ovrtimer_handler(void);
Note: See TracChangeset for help on using the changeset viewer.