Changeset 386 for ssp_rpi3/trunk/arch/arm64_gcc/common/core_timer.h
- Timestamp:
- Apr 17, 2019, 12:13:00 PM (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
ssp_rpi3/trunk/arch/arm64_gcc/common/core_timer.h
-
Property svn:mime-type
set to
text/plain; charset=utf-8
r384 r386 8 8 * Nagoya Municipal Industrial Research Institute, JAPAN 9 9 * 10 * ä¸è¨èä½æ¨©è 11 ã¯ï¼ä»¥ä¸ã®(1)ã(4)ã®æ¡ä»¶ãæºããå ´åã«éãï¼æ¬ã½ããã¦ã§ 12 * ã¢ï¼æ¬ã½ããã¦ã§ã¢ãæ¹å¤ãããã®ãå«ãï¼ä»¥ä¸åãï¼ã使ç¨ã»è¤è£½ã»æ¹ 13 * å¤ã»åé 14 å¸ï¼ä»¥ä¸ï¼å©ç¨ã¨å¼ã¶ï¼ãããã¨ãç¡åã§è¨±è«¾ããï¼ 15 * (1) æ¬ã½ããã¦ã§ã¢ãã½ã¼ã¹ã³ã¼ãã®å½¢ã§å©ç¨ããå ´åã«ã¯ï¼ä¸è¨ã®èä½ 16 * 権表示ï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ã®ç¡ä¿è¨¼è¦å®ãï¼ãã®ã¾ã¾ã®å½¢ã§ã½ã¼ 17 * ã¹ã³ã¼ãä¸ã«å«ã¾ãã¦ãããã¨ï¼ 18 * (2) æ¬ã½ããã¦ã§ã¢ãï¼ã©ã¤ãã©ãªå½¢å¼ãªã©ï¼ä»ã®ã½ããã¦ã§ã¢éçºã«ä½¿ 19 * ç¨ã§ããå½¢ã§åé 20 å¸ããå ´åã«ã¯ï¼åé 21 å¸ã«ä¼´ãããã¥ã¡ã³ãï¼å©ç¨ 22 * è 23 ããã¥ã¢ã«ãªã©ï¼ã«ï¼ä¸è¨ã®èä½æ¨©è¡¨ç¤ºï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ 24 * ã®ç¡ä¿è¨¼è¦å®ãæ²è¼ãããã¨ï¼ 25 * (3) æ¬ã½ããã¦ã§ã¢ãï¼æ©å¨ã«çµã¿è¾¼ããªã©ï¼ä»ã®ã½ããã¦ã§ã¢éçºã«ä½¿ 26 * ç¨ã§ããªãå½¢ã§åé 27 å¸ããå ´åã«ã¯ï¼æ¬¡ã®ããããã®æ¡ä»¶ãæºããã 28 * ã¨ï¼ 29 * (a) åé 30 å¸ã«ä¼´ãããã¥ã¡ã³ãï¼å©ç¨è 31 ããã¥ã¢ã«ãªã©ï¼ã«ï¼ä¸è¨ã®è 32 * ä½æ¨©è¡¨ç¤ºï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ã®ç¡ä¿è¨¼è¦å®ãæ²è¼ãããã¨ï¼ 33 * (b) åé 34 å¸ã®å½¢æ 35 ãï¼å¥ã«å®ããæ¹æ³ã«ãã£ã¦ï¼TOPPERSããã¸ã§ã¯ãã« 36 * å ±åãããã¨ï¼ 37 * (4) æ¬ã½ããã¦ã§ã¢ã®å©ç¨ã«ããç´æ¥çã¾ãã¯éæ¥çã«çãããããªãæ 38 * 害ãããï¼ä¸è¨èä½æ¨©è 39 ããã³TOPPERSããã¸ã§ã¯ããå 40 責ãããã¨ï¼ 41 * ã¾ãï¼æ¬ã½ããã¦ã§ã¢ã®ã¦ã¼ã¶ã¾ãã¯ã¨ã³ãã¦ã¼ã¶ããã®ãããªãç 42 * ç±ã«åºã¥ãè«æ±ãããï¼ä¸è¨èä½æ¨©è 43 ããã³TOPPERSããã¸ã§ã¯ãã 44 * å 45 責ãããã¨ï¼ 10 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ 11 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改 12 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する. 13 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 14 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー 15 * スコード中に含まれていること. 16 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 17 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 18 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 19 * の無保証規定を掲載すること. 20 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 21 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ 22 * と. 23 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 24 * 作権表示,この利用条件および下記の無保証規定を掲載すること. 25 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに 26 * 報告すること. 27 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 28 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. 29 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理 30 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを 31 * 免責すること. 46 32 * 47 * æ¬ã½ããã¦ã§ã¢ã¯ï¼ç¡ä¿è¨¼ã§æä¾ããã¦ãããã®ã§ããï¼ä¸è¨èä½æ¨©è 48 ã 49 * ãã³TOPPERSããã¸ã§ã¯ãã¯ï¼æ¬ã½ããã¦ã§ã¢ã«é¢ãã¦ï¼ç¹å®ã®ä½¿ç¨ç®ç 50 * ã«å¯¾ããé©åæ§ãå«ãã¦ï¼ãããªãä¿è¨¼ãè¡ããªãï¼ã¾ãï¼æ¬ã½ããã¦ã§ 51 * ã¢ã®å©ç¨ã«ããç´æ¥çã¾ãã¯éæ¥çã«çãããããªãæ害ã«é¢ãã¦ãï¼ã 52 * ã®è²¬ä»»ãè² ããªãï¼ 33 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お 34 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的 35 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ 36 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ 37 * の責任を負わない. 53 38 * 54 39 * $Id$ … … 56 41 57 42 /* 58 * ã¿ã¤ããã©ã¤ãï¼Generic Timerï¼43 * タイマドライバ(Generic Timer) 59 44 */ 60 45 … … 65 50 66 51 /* 67 * ã¿ã¤ãå²è¾¼ã¿ãã³ãã©ç»é²ã®ããã®å®æ°52 * タイマ割込みハンドラ登録のための定数 68 53 */ 69 54 70 #define INTNO_TIMER TINTNO_CNTPNS /* å²è¾¼ã¿çªå·*/71 #define INHNO_TIMER INTNO_TIMER /* å²è¾¼ã¿ãã³ãã©çªå·*/55 #define INTNO_TIMER TINTNO_CNTPNS /* 割込み番号 */ 56 #define INHNO_TIMER INTNO_TIMER /* 割込みハンドラ番号 */ 72 57 73 58 #ifndef INTPRI_TIMER 74 #define INTPRI_TIMER (-3) /* å²è¾¼ã¿åªå 75 度 */ 59 #define INTPRI_TIMER (-3) /* 割込み優先度 */ 76 60 #endif 77 61 78 62 #ifndef INTATR_TIMER 79 #define INTATR_TIMER TA_NULL /* å²è¾¼ã¿å±æ§*/63 #define INTATR_TIMER TA_NULL /* 割込み属性 */ 80 64 #endif 81 65 82 66 /* 83 * å¶å¾¡ã¬ã¸ã¹ã¿ã®ãããå®ç¾©67 * 制御レジスタのビット定義 84 68 */ 85 69 #define CNTP_CTL_ENABLE (1 << 0) … … 91 75 92 76 /* 93 * ç©çã¿ã¤ãã®å¶å¾¡ã¬ã¸ã¹ã¿ããã®èªã¿åºã77 * 物理タイマの制御レジスタからの読み出し 94 78 */ 95 79 Inline uint32_t … … 104 88 105 89 /* 106 * ç©çã¿ã¤ãã®å¶å¾¡ã¬ã¸ã¹ã¿ã¸ã®æ¸ãè¾¼ã¿90 * 物理タイマの制御レジスタへの書き込み 107 91 */ 108 92 Inline void … … 114 98 115 99 /* 116 * ç©çã¿ã¤ã(ããªã¼ã«ã¦ã³ã¿)ã®ã«ã¦ã³ãå¤ã®èªã¿åºã100 * 物理タイマ(フリーカウンタ)のカウント値の読み出し 117 101 */ 118 102 Inline uint64_t … … 126 110 127 111 /* 128 * ç©çã¿ã¤ãå¤ã®èªã¿åºã112 * 物理タイマ値の読み出し 129 113 */ 130 114 Inline uint32_t … … 138 122 139 123 /* 140 * ç©çã¿ã¤ãå¤ã®æ¸ãè¾¼ã¿124 * 物理タイマ値の書き込み 141 125 */ 142 126 Inline void … … 147 131 148 132 /* 149 * ã¿ã¤ãã®æ¯è¼å¤ã®èªã¿åºã133 * タイマの比較値の読み出し 150 134 */ 151 135 Inline uint64_t … … 159 143 160 144 /* 161 * ã¿ã¤ãã®æ¯è¼å¤ã®æ¸ãè¾¼ã¿145 * タイマの比較値の書き込み 162 146 */ 163 147 Inline void … … 168 152 169 153 /* 170 * ã·ã¹ãã ã«ã¦ã³ã¿ã®ã¯ããã¯å¨æ³¢æ°ã®åå¾154 * システムカウンタのクロック周波数の取得 171 155 */ 172 156 Inline uint32_t … … 179 163 180 164 /* 181 * ã¿ã¤ãã®èµ·åå¦ç165 * タイマの起動処理 182 166 * 183 * ã¿ã¤ããåæåãï¼å¨æçãªã¿ã¤ãå²è¾¼ã¿è¦æ±ãçºçãããï¼167 * タイマを初期化し,周期的なタイマ割込み要求を発生させる. 184 168 */ 185 169 extern void target_timer_initialize(intptr_t exinf); 186 170 187 171 /* 188 * ã¿ã¤ãã®åæ¢å¦ç172 * タイマの停止処理 189 173 */ 190 174 extern void target_timer_terminate(intptr_t exinf); 191 175 192 176 /* 193 * ã¿ã¤ãå²è¾¼ã¿ãã³ãã©177 * タイマ割込みハンドラ 194 178 */ 195 179 extern void target_timer_handler(void); -
Property svn:mime-type
set to
Note:
See TracChangeset
for help on using the changeset viewer.