1 |
|
---|
2 | TOPPERS/ASPカーネル
|
---|
3 | ターゲット依存部 ポーティングガイド
|
---|
4 |
|
---|
5 | 対応バージョン: Release 1.7.0
|
---|
6 | 最終更新: 2011年4月10日
|
---|
7 |
|
---|
8 | このドキュメントは,TOPPERS/ASPカーネルを,未サポートのターゲットシステ
|
---|
9 | ムにポーティングするために必要となるターゲット依存部の実装方法を説明す
|
---|
10 | るものである.
|
---|
11 |
|
---|
12 | ----------------------------------------------------------------------
|
---|
13 | TOPPERS/ASP Kernel
|
---|
14 | Toyohashi Open Platform for Embedded Real-Time Systems/
|
---|
15 | Advanced Standard Profile Kernel
|
---|
16 |
|
---|
17 | Copyright (C) 2005-2011 by Embedded and Real-Time Systems Laboratory
|
---|
18 | Graduate School of Information Science, Nagoya Univ., JAPAN
|
---|
19 |
|
---|
20 | 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
|
---|
21 | ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
|
---|
22 | 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
|
---|
23 | (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
|
---|
24 | 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
|
---|
25 | スコード中に含まれていること.
|
---|
26 | (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
|
---|
27 | 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
|
---|
28 | 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
|
---|
29 | の無保証規定を掲載すること.
|
---|
30 | (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
|
---|
31 | 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
|
---|
32 | と.
|
---|
33 | (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
|
---|
34 | 作権表示,この利用条件および下記の無保証規定を掲載すること.
|
---|
35 | (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
|
---|
36 | 報告すること.
|
---|
37 | (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
|
---|
38 | 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
|
---|
39 | また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
|
---|
40 | 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
|
---|
41 | 免責すること.
|
---|
42 |
|
---|
43 | 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
|
---|
44 | よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
|
---|
45 | に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
|
---|
46 | アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
|
---|
47 | の責任を負わない.
|
---|
48 |
|
---|
49 | $Id: porting.txt 2064 2011-05-01 08:09:00Z ertl-hiro $
|
---|
50 | ----------------------------------------------------------------------
|
---|
51 |
|
---|
52 | ○目次
|
---|
53 |
|
---|
54 | 1.共通事項
|
---|
55 | 1.1 ターゲット依存部の構成
|
---|
56 | 1.2 名前の衝突の防止
|
---|
57 | 1.3 多重インクルードの防止
|
---|
58 | 1.4 アセンブリ言語とのヘッダファイルの共用
|
---|
59 | 1.5 インクルード記述の方法
|
---|
60 | 1.6 クリティカルセクションの出入処理の実現に関する制約
|
---|
61 | 2.システム構築環境のターゲット依存部
|
---|
62 | 2.1 ターゲット略称とターゲット依存部のディレクトリ
|
---|
63 | 2.2 Makefileのターゲット依存部
|
---|
64 | 2.3 開発環境名とコマンド名の設定
|
---|
65 | 2.4 コンパイルオプションとオブジェクトファイルの設定
|
---|
66 | 2.5 オフセットファイルの生成方法
|
---|
67 | 2.5.1 コンフィギュレータを用いる方法
|
---|
68 | 2.5.2 makeoffset.cとgenoffsetを用いる方法
|
---|
69 | 2.6 リンク方法の設定
|
---|
70 | 2.7 依存関係の定義
|
---|
71 | 2.8 その他の設定
|
---|
72 | 3.TOPPERS共通定義のターゲット依存部
|
---|
73 | 3.1 ターゲット識別マクロ
|
---|
74 | 3.2 整数型の最大値・最小値・ビット数
|
---|
75 | 3.3 サイズの指定された整数型,その最大値・最小値,整数定数を作るマクロ
|
---|
76 | 3.4 サイズの指定された浮動小数点型,その最大値・最小値のマクロ
|
---|
77 | 3.5 コンパイラの拡張機能のためのマクロ定義
|
---|
78 | 3.6 標準的な定義の上書き
|
---|
79 | 3.7 アサーションのための定義
|
---|
80 | 4.システムインタフェースレイヤ(SIL)のターゲット依存部
|
---|
81 | 4.1 全割込みロック状態の管理
|
---|
82 | 4.2 微少時間待ち
|
---|
83 | 4.3 プロセッサのエンディアン
|
---|
84 | 4.4 メモリ空間アクセス関数
|
---|
85 | 4.5 I/O空間アクセス関数
|
---|
86 | 5.カーネルAPIのターゲット依存部
|
---|
87 | 5.1 ターゲット定義でサポートする機能
|
---|
88 | 5.2 割込み優先度の範囲
|
---|
89 | 5.3 タイムティックの定義
|
---|
90 | 5.4 メモリ領域確保のための型定義
|
---|
91 | 5.5 ビットパターンのビット数
|
---|
92 | 5.6 メモリ領域確保のためのマクロ
|
---|
93 | 5.7 オーバランハンドラ機能拡張のための定義(オプション)
|
---|
94 | 6.カーネル実装のターゲット依存部
|
---|
95 | 6.1 カーネル実装のターゲット依存部の共通事項
|
---|
96 | 6.1.1 カーネル実装のターゲット依存部の構成要素
|
---|
97 | 6.1.2 ターゲット依存部の関数の命名規則
|
---|
98 | 6.2 トレースログ機能への対応
|
---|
99 | 6.3 システム状態の管理
|
---|
100 | 6.3.1 全割込みロック状態の管理
|
---|
101 | 6.3.2 コンテキストの管理
|
---|
102 | 6.3.3 CPUロック状態の管理
|
---|
103 | 6.4 割込みに関連するシステム状態の管理
|
---|
104 | 6.4.1 割込み優先度マスクの管理
|
---|
105 | 6.4.2 割込み要求禁止フラグの管理
|
---|
106 | 6.4.3 割込み要求のクリア
|
---|
107 | 6.4.4 割込み要求のプローブ
|
---|
108 | 6.4.5 割込みハンドラの先頭処理と末尾処理
|
---|
109 | 6.5 タスクディスパッチャ
|
---|
110 | 6.5.1 タスクコンテキストブロックとタスク初期化コンテキストブロック
|
---|
111 | 6.5.2 ディスパッチャ本体
|
---|
112 | 6.5.3 タスクコンテキストからのディスパッチ
|
---|
113 | 6.5.4 ディスパッチャの動作開始
|
---|
114 | 6.5.5 現在のコンテキストを捨ててディスパッチ
|
---|
115 | 6.5.6 タスクの起動処理
|
---|
116 | 6.6 割込みハンドラ
|
---|
117 | 6.6.1 割込みハンドラの出入口処理
|
---|
118 | 6.6.2 割込みハンドラ毎の出入口処理の生成
|
---|
119 | 6.6.3 割込みハンドラの設定
|
---|
120 | 6.6.4 割込み要求ラインの属性の設定
|
---|
121 | 6.6.5 割込み管理機能の初期化処理の変更
|
---|
122 | 6.6.6 デフォルトの割込みハンドラ
|
---|
123 | 6.6.7 カーネル管理外の割込み
|
---|
124 | 6.6.8 割込みサービスルーチンの生成
|
---|
125 | 6.7 CPU例外ハンドラとCPU例外発生時のシステム状態の参照
|
---|
126 | 6.7.1 CPU例外ハンドラの出入口処理
|
---|
127 | 6.7.2 CPU例外ハンドラの出入口処理の生成
|
---|
128 | 6.7.3 CPU例外ハンドラの設定
|
---|
129 | 6.7.4 CPU例外管理機能の初期化処理の変更
|
---|
130 | 6.7.5 デフォルトのCPU例外ハンドラ
|
---|
131 | 6.7.6 CPU例外発生時のシステム状態の参照
|
---|
132 | 6.8 カーネルの起動・終了とスタック領域など
|
---|
133 | 6.9 カーネル内部のチューニング
|
---|
134 | 6.9.1 ビットマップサーチ
|
---|
135 | 6.9.2 ビットフィールド
|
---|
136 | 6.10 カーネル実装に関するその他の定義
|
---|
137 | 6.10.1 オブジェクト属性の拡張
|
---|
138 | 6.10.2 エラーチェック方法の指定
|
---|
139 | 6.10.3 非タスクコンテキスト用のスタック領域
|
---|
140 | 6.10.4 空ラベルの定義
|
---|
141 | 6.11 トレースログ機能に関する設定
|
---|
142 | 6.11.1 取得できるトレースログの種類とマクロ
|
---|
143 | 6.11.2 トレースログ記録のサンプルコード
|
---|
144 | 6.12 カーネル実装のターゲット依存部のためのリネーム記述
|
---|
145 | 6.13 タイマドライバ
|
---|
146 | 6.13.1 タイマドライバのファイル構成
|
---|
147 | 6.13.2 タイマの初期化・終了処理・割込み処理
|
---|
148 | 6.13.3 性能評価用システム時刻の参照のための機能
|
---|
149 | 6.14 オーバランタイマドライバ(オプション)
|
---|
150 | 6.14.1 オーバランタイマドライバのファイル構成
|
---|
151 | 6.14.2 オーバランタイマの操作と割込み処理
|
---|
152 | 6.15 動的メモリ管理
|
---|
153 | 6.15.1 TLSFを用いたメモリ管理モジュールの例
|
---|
154 | 7.コンフィギュレータ設定ファイルのターゲット依存部
|
---|
155 | 7.1 設定ファイルとターゲット依存部の位置付け
|
---|
156 | 7.2 パス2のテンプレートファイルのターゲット依存部
|
---|
157 | 7.2.1 ターゲット非依存部をインクルードする前に定義すべき変数
|
---|
158 | 7.2.2 ターゲット非依存部で定義される変数
|
---|
159 | 7.3 パス3のテンプレートファイルのターゲット依存部
|
---|
160 | 7.3.1 ターゲット非依存部をインクルードする前に定義すべき変数
|
---|
161 | 7.3.2 ターゲット依存部で行うべきエラーチェック
|
---|
162 | 7.4 cfg1_out.cのリンクに必要なスタブの定義ファイル
|
---|
163 | 8.システムサービス等のターゲット依存部
|
---|
164 | 8.0 システムサービスのターゲット依存部
|
---|
165 | 8.1 システムログ機能のターゲット依存定義
|
---|
166 | 8.2 ログタスクのターゲット依存定義
|
---|
167 | 8.3 シリアルインタフェースドライバのターゲット依存部
|
---|
168 | 8.3.1 変数,データ型,管理関数
|
---|
169 | 8.3.2 デバイスサービスルーチン
|
---|
170 | 8.3.3 コールバックルーチン
|
---|
171 | 8.4 カーネル起動メッセージの出力のターゲット依存定義
|
---|
172 | 8.5 サンプルプログラムとテストプログラムのターゲット依存定義
|
---|
173 | 8.6 実行時間分布集計モジュールのターゲット依存定義
|
---|
174 | 9.その他
|
---|
175 | 9.1 ドキュメント
|
---|
176 | 9.2 パッケージ記述ファイル
|
---|
177 | 10.リファレンス
|
---|
178 | 10.1 ターゲット依存部のファイル一覧
|
---|
179 |
|
---|
180 |
|
---|
181 | 1.共通事項
|
---|
182 |
|
---|
183 | 1.1 ターゲット依存部の構成
|
---|
184 |
|
---|
185 | ターゲット依存部は,targetディレクトリの下に,ターゲットハードウェアと
|
---|
186 | 開発環境の組み合わせ毎に用意する.ただし,ターゲット依存部の再利用性を
|
---|
187 | 考慮し,プロセッサ,チップ,開発環境のみに依存する部分を,プロセッサ依
|
---|
188 | 存部,チップ依存部,開発環境依存部という形で切り分けてもよい.切り分け
|
---|
189 | 方は,ターゲット依存部の実装に任されている.プロセッサ依存部,チップ依
|
---|
190 | 存部,開発環境依存部は,archディレクトリの下に置く.
|
---|
191 |
|
---|
192 | ASPカーネルのターゲット依存部は,システム構築環境(Makefile等)のターゲッ
|
---|
193 | ト依存部,TOPPERS共通定義(t_stddef.h)のターゲット依存部,システムイン
|
---|
194 | タフェースレイヤ(SIL,sil.h)のターゲット依存部,カーネルAPI(kernel.h)
|
---|
195 | のターゲット依存部,カーネル実装のターゲット依存部(コンフィギュレータ
|
---|
196 | 設定ファイルのターゲット依存部を含む),システムサービスのターゲット依
|
---|
197 | 存部,ターゲット依存部に関するドキュメント等で構成される.
|
---|
198 |
|
---|
199 | 1.2 名前の衝突の防止
|
---|
200 |
|
---|
201 | TOPPERSプロジェクトが提供するソフトウェアのために,TOPPERS_で始まるシン
|
---|
202 | ボルを予約している.ヘッダファイル中に記述され,アプリケーションから参
|
---|
203 | 照できる内部シンボルは,TOPPERS_で始まる名前とする.
|
---|
204 |
|
---|
205 | また,_kernel_で始まるシンボルは,カーネル内部の変数や関数のために予約
|
---|
206 | している.カーネル内部の変数や関数の名前で,リンク時にアプリケーション
|
---|
207 | の名前と衝突する可能性があるものは,リネーム記述にリストアップすること
|
---|
208 | で,コンパイル時に_kernel_で始まる名前に置き換えることとしている.
|
---|
209 |
|
---|
210 | 1.3 多重インクルードの防止
|
---|
211 |
|
---|
212 | すべてのヘッダファイルは,多重にインクルードされるのを防止するための条
|
---|
213 | 件コンパイル記述を入れることとする.例えば,target_config.hであれば,ファ
|
---|
214 | イルの先頭に
|
---|
215 |
|
---|
216 | #ifndef TOPPERS_TARGET_CONFIG_H
|
---|
217 | #define TOPPERS_TARGET_CONFIG_H
|
---|
218 |
|
---|
219 | を,ファイルの末尾に
|
---|
220 |
|
---|
221 | #endif /* TOPPERS_TARGET_CONFIG_H */
|
---|
222 |
|
---|
223 | を記述する.
|
---|
224 |
|
---|
225 | 1.4 アセンブリ言語とのヘッダファイルの共用
|
---|
226 |
|
---|
227 | ASPカーネルのヘッダファイルの多くは,アセンブリ言語のソースファイルから
|
---|
228 | もインクルードできるようにするために,次のルールに従って記述するものと
|
---|
229 | する.
|
---|
230 |
|
---|
231 | ・TOPPERS_MACRO_ONLYがマクロ定義されている場合には,アセンブリ言語では
|
---|
232 | 解釈できない記述(マクロ定義以外の記述)を除くように記述する.
|
---|
233 |
|
---|
234 | ・符号無し整数型の定数値は,UINT_CやULONG_Cなどの整数定数を作るためのマ
|
---|
235 | クロを用いて記述する.ただし,アセンブリ言語のソースファイルからもイ
|
---|
236 | ンクルードできるファイル中であっても,C言語のみで用いる定数をこれらの
|
---|
237 | マクロを使って記述する必要はない.
|
---|
238 |
|
---|
239 | また,カーネル実装においては,次のルールに従うものとする.
|
---|
240 |
|
---|
241 | ・アセンブリ言語からも用いる定数の定義中に型キャストを用いる場合には,
|
---|
242 | CASTマクロを用いて記述する.
|
---|
243 |
|
---|
244 | アセンブリ言語からヘッダファイルをインクルードする際には,必要に応じて,
|
---|
245 | TOPPERS_MACRO_ONLY,UINC_C,ULONG_C,CASTをマクロ定義してから,インクルー
|
---|
246 | ドしなければならない.
|
---|
247 |
|
---|
248 | 1.5 インクルード記述の方法
|
---|
249 |
|
---|
250 | 開発環境で用意されている標準ヘッダファイルおよびincludeディレクトリ下の
|
---|
251 | 標準ヘッダファイルは,「#include <...>」によりインクルードする.
|
---|
252 |
|
---|
253 | その他のヘッダファイルは,「#include "..."」によりインクルードする.ヘッ
|
---|
254 | ダファイルが,カレントディレクトリやインクルードするファイルと同じディ
|
---|
255 | レクトリ以外のディレクトリに置かれている場合には,次のようにパス指定を
|
---|
256 | 行う.
|
---|
257 |
|
---|
258 | ・ターゲット依存部(target/<ターゲット名>)のディレクトリに置かれている
|
---|
259 | 場合は,パス指定を行わず,ファイル名のみを記述する.
|
---|
260 | 例)#include "target_config.h"
|
---|
261 |
|
---|
262 | ・archディレクトリ下のディレクトリに置かれている場合には,archディレク
|
---|
263 | トリからの相対パスで記述する.
|
---|
264 | 例)#include "m68k_gcc/prc_config.h"
|
---|
265 |
|
---|
266 | ・その他の場合には,ソースプログラムのルートディレクトリ(configureが置
|
---|
267 | かれているディレクトリ)からの相対パスで記述する.
|
---|
268 | 例)#include "pdic/upd72001/upd72001.h"
|
---|
269 |
|
---|
270 | ・カーネルを構成するファイルから,kernelディレクトリ下のヘッダファイル
|
---|
271 | をインクルードする場合は,パス指定を行わず,ファイル名のみを記述する.
|
---|
272 | 例)#include "kernel_impl.h"
|
---|
273 |
|
---|
274 | 1.6 クリティカルセクションの出入処理の実現に関する制約
|
---|
275 |
|
---|
276 | カーネル内で用いるクリティカルセクションの出入処理を実現する場合には,
|
---|
277 | 次の2つの条件を満たすように実装しなければならない.
|
---|
278 |
|
---|
279 | (1-6-1) 出入処理から抜けた時点では,割込みの禁止/許可が完了していなけ
|
---|
280 | ればならない.例えば,割込み禁止/許可命令を実行してから実際に割込みが
|
---|
281 | 禁止/許可されるまで何命令か遅延するプロセッサの場合には,出入処理の中
|
---|
282 | にNOP命令を入れるなどの方法で,出入処理を抜けた時点では,割込みが禁止/
|
---|
283 | 許可された状態になっていることを保証しなければならない.
|
---|
284 |
|
---|
285 | (1-6-2) メモリ上のデータ構造が書き変わる可能性があることを,何らかの方
|
---|
286 | 法でコンパイラに知らせなければならない.GNU開発環境では,次のいずれかの
|
---|
287 | 方法でこの制約を満たすことができる.
|
---|
288 |
|
---|
289 | (a) クリティカルセクションの出入処理の全体または出入処理の本質的な部分
|
---|
290 | (具体的には,割込み禁止/許可する処理)を(インラインでない)通常
|
---|
291 | の関数により実現する.
|
---|
292 |
|
---|
293 | (b) クリティカルセクションの出入処理の本質的な部分をインラインアセンブ
|
---|
294 | ラによって実現している場合には,そのインラインアセンブラのclobber変
|
---|
295 | 数リストに"memory"を追加する.
|
---|
296 |
|
---|
297 | (c) クリティカルセクションの出入処理の本質的な部分が,マクロやインライ
|
---|
298 | ン関数呼出しで実現している場合には,クリティカルセクションに入る処
|
---|
299 | 理の最後と出る処理の先頭に,Asm("":::"memory")という記述を入れる.
|
---|
300 |
|
---|
301 | このような制約を設ける理由については,「TOPPERS/ASPカーネル 設計メモ」
|
---|
302 | の「カーネルのデータ構造に対するvolatile宣言について」の節を参照するこ
|
---|
303 | と.
|
---|
304 |
|
---|
305 |
|
---|
306 | 2.システム構築環境のターゲット依存部
|
---|
307 |
|
---|
308 | この章の説明は,GNU開発環境(GCC,GAS,BINUTILS,GNU Make)を用いること
|
---|
309 | を想定して記述してある.それ以外の開発環境を用いる場合には,開発環境に
|
---|
310 | あわせて修正する必要がある.
|
---|
311 |
|
---|
312 | 2.1 ターゲット略称とターゲット依存部のディレクトリ
|
---|
313 |
|
---|
314 | 新しいターゲット依存部を作成する時は,まず,ターゲット略称を定める.ター
|
---|
315 | ゲット略称は,システム略称と開発環境略称を"_"で連結したものとする.シス
|
---|
316 | テム略称に用いる文字は英小文字と数字と"_"に,開発環境略称に用いる文字は
|
---|
317 | 英小文字と数字に限定する.GNU開発環境の開発環境略称は,"gcc"とする.例
|
---|
318 | えば,システム略称が"dve68k"で,GNU開発環境を用いる場合には,ターゲット
|
---|
319 | 略称は"dve68k_gcc"となる.
|
---|
320 |
|
---|
321 | ターゲット依存部のファイルを置くために,targetディレクトリの下に,ター
|
---|
322 | ゲット略称を名称とするディレクトリを作成する.これをターゲット依存部ディ
|
---|
323 | レクトリと呼ぶ.
|
---|
324 |
|
---|
325 | ターゲット依存部からプロセッサ依存部やチップ依存部を切り分ける場合には,
|
---|
326 | 依存部略称を定める.依存部略称は,プロセッサやチップの略称と開発環境略
|
---|
327 | 称を"_"で連結したものとする.プロセッサやチップの略称に用いる文字は,英
|
---|
328 | 小文字と数字と"_"に限定する.例えば,プロセッサ略称が"m68k"で,GNU開発
|
---|
329 | 環境を用いる場合には,依存部略称は"m68k_gcc"となる.
|
---|
330 |
|
---|
331 | また,ターゲット依存部から開発環境依存部を切り分ける場合には,開発環境
|
---|
332 | 略称を依存部略称とする.例えば,GNU開発環境依存部の依存部略称は,"gcc"
|
---|
333 | となる.
|
---|
334 |
|
---|
335 | これらの依存部のファイルを置くために,archディレクトリの下に,依存部略
|
---|
336 | 称を名称とするディレクトリを作成する.
|
---|
337 |
|
---|
338 | なお,GNU開発環境以外の開発環境を用いる場合には,コンフィギュレーション
|
---|
339 | スクリプト(configure),サンプルのMakefile(sample/Makefile),一部の
|
---|
340 | ユーティリティプログラム(utils/makedep)を,その開発環境用に用意する必
|
---|
341 | 要がある場合がある.その場合には,これらのファイルを,ターゲット依存部
|
---|
342 | ディレクトリか開発環境依存部ディレクトリに置くものとする.また,開発環
|
---|
343 | 境用のプロジェクトファイルが必要な場合には,ターゲット依存部ディレクト
|
---|
344 | リに置くものとする.
|
---|
345 |
|
---|
346 | 2.2 Makefileのターゲット依存部
|
---|
347 |
|
---|
348 | Makefileのターゲット依存部は,ターゲット依存部ディレクトリに置いた
|
---|
349 | Makefile.targetまたはそこからインクルードされるファイル(プロセッサ・チッ
|
---|
350 | プ・開発環境依存部で用意されるファイルなど)に含める.
|
---|
351 |
|
---|
352 | 2.3 開発環境名とコマンド名の設定
|
---|
353 |
|
---|
354 | 開発環境名とコマンド名を設定するために,Makefileのターゲット依存部で次
|
---|
355 | の変数を定義する.
|
---|
356 |
|
---|
357 | (2-3-1) TOOL 開発環境名
|
---|
358 |
|
---|
359 | 開発環境名に定義する.GNU開発環境を用いる場合には,gccに定義する.
|
---|
360 |
|
---|
361 | (2-3-2) GCC_TARGET GNU開発環境のターゲット名
|
---|
362 |
|
---|
363 | GNU開発環境を用いる場合に,GNU開発環境をconfigureする場合に指定するター
|
---|
364 | ゲット名に定義する.ここで指定したターゲット名は,開発環境のコマンド名
|
---|
365 | の先頭に付与される文字列となる.例えば,GCC_TARGETをm68k-unknown-elfに
|
---|
366 | 定義した場合には,コンパイラとしてm68k-unknown-elf-gccが使われる.この
|
---|
367 | 変数が定義されない場合には,単なるgccが使われる.
|
---|
368 |
|
---|
369 | (2-3-3) CC Cコンパイラドライバの名称
|
---|
370 | (2-3-4) CXX C++コンパイラドライバの名称
|
---|
371 | (2-3-5) AS アセンブラの名称
|
---|
372 | (2-3-6) LD リンカの名称
|
---|
373 | (2-3-7) AR アーカイバの名称
|
---|
374 | (2-3-8) NM nmプログラムの名称
|
---|
375 | (2-3-9) RANLIB ranlibプログラムの名称
|
---|
376 | (2-3-10) OBJCOPY objcopyプログラムの名称
|
---|
377 | (2-3-11) OBJDUMP objdumpプログラムの名称
|
---|
378 |
|
---|
379 | GNU開発環境以外の開発環境を用いる場合に,それぞれのコマンドの名称に定義
|
---|
380 | する.対応するコマンドがない場合や,コマンドパラメータが異なる場合には,
|
---|
381 | Makefile中でそのコマンドを呼び出している部分を変更する必要がある.
|
---|
382 |
|
---|
383 | GNU開発環境では,これらはGCC_TARGETを用いて定義されるので,定義する必要
|
---|
384 | はない.
|
---|
385 |
|
---|
386 | 2.4 コンパイルオプションとオブジェクトファイルの設定
|
---|
387 |
|
---|
388 | Makefileのターゲット依存部で以下で説明する変数を定義する時には,":="を
|
---|
389 | 用いて,それまでの定義に追加する形で行う.例えば,コンパイラに対するそ
|
---|
390 | の他のオプションとして「-Wall -g -O2」を追加したい場合には,「COPTS :=
|
---|
391 | $(COPTS) -Wall -g -O2」という記述をMakefileのターゲット依存部に含める.
|
---|
392 |
|
---|
393 | (2-4-1) COPTS コンパイラに対するその他のオプション
|
---|
394 | (2-4-2) CDEFS マクロ定義オプション(-Dオプション)
|
---|
395 | (2-4-3) INCLUDES ヘッダファイルの置かれたディレクトリ指定オ
|
---|
396 | プション(-Iオプション)
|
---|
397 | (2-4-4) LDFLAGS リンカに対するその他のオプション
|
---|
398 | (2-4-5) LIBS ライブラリリンク指定のためのオプション
|
---|
399 |
|
---|
400 | ターゲットに依存して,すべてのソースファイルに共通するコンパイルオプショ
|
---|
401 | ンの追加が必要な場合には,オプションの種類毎に上に示した変数に定義する.
|
---|
402 |
|
---|
403 | ほとんどの場合に,ターゲット依存部ディレクトリのMakefile.targetには,以
|
---|
404 | 下の記述を含める必要がある.
|
---|
405 |
|
---|
406 | ----------------------------------------
|
---|
407 | INCLUDES := $(INCLUDES) -I$(TARGETDIR)
|
---|
408 | ----------------------------------------
|
---|
409 |
|
---|
410 | ここでTARGETDIRは,ターゲット依存部ディレクトリに定義されている.また
|
---|
411 | SRCDIRは,Makefileにおいて,ソースプログラムのルートディレクトリ
|
---|
412 | (configureが置かれているディレクトリ)に定義されている.
|
---|
413 |
|
---|
414 | コンパイラの問題等で,警告メッセージが出ることを防げない状況以外では,
|
---|
415 | COPTSに-Werrorを追加することを推奨する.
|
---|
416 |
|
---|
417 | ----------------------------------------
|
---|
418 | COPTS := $(COPTS) -Werror
|
---|
419 | ----------------------------------------
|
---|
420 |
|
---|
421 | カーネルのコンパイル時に,dereferencing type-punned pointer will break
|
---|
422 | strict-aliasing rulesという警告が出る場合には,以下を追加するとよい.こ
|
---|
423 | の警告メッセージに関する詳細は,「TOPPERS/ASPカーネル 設計メモ」の「型
|
---|
424 | キャストに伴う警告メッセージ」の節を参照すること.
|
---|
425 |
|
---|
426 | ----------------------------------------
|
---|
427 | KERNEL_CFLAGS := $(KERNEL_CFLAGS) -fno-strict-aliasing
|
---|
428 | ----------------------------------------
|
---|
429 |
|
---|
430 | また,アセンブリ言語レベルの識別名が,C言語レベルの識別名の先頭に"_"が
|
---|
431 | 付いたものになる場合には,CDEFSに-DTOPPERS_LABEL_ASMを追加する.
|
---|
432 |
|
---|
433 | (2-4-6) SYSSVC_DIR システムサービスのソースが置かれたディレクトリ
|
---|
434 | (2-4-7) SYSSVC_ASMOBJS アセンブリ言語で記述されたシステムサービスの
|
---|
435 | オブジェクト
|
---|
436 | (2-4-8) SYSSVC_COBJS C言語で記述されたシステムサービスのオブジェクト
|
---|
437 | (2-4-9) SYSSVC_CFLAGS システムサービスに対するコンパイルオプション
|
---|
438 | (2-4-10) SYSSVC_LIBS システムサービスに対するライブラリリンク指定
|
---|
439 |
|
---|
440 | ターゲットに依存して,システムサービス(システムログタスクやデバイスド
|
---|
441 | ライバなど)のソースが置かれたディレクトリ,システムサービスを構成する
|
---|
442 | オブジェクトファイルのリスト,それらをコンパイルする際に適用するコンパ
|
---|
443 | イルオプション,その構成に必要なライブラリリンク指定を追加する場合には,
|
---|
444 | 上に示した変数に定義する.
|
---|
445 |
|
---|
446 | (2-4-11) KERNEL_DIR カーネルのソースが置かれたディレクトリ
|
---|
447 | (2-4-12) KERNEL_ASMOBJS アセンブリ言語で記述されたカーネルのオブジェクト
|
---|
448 | (2-4-13) KERNEL_COBJS C言語で記述されたカーネルのオブジェクト
|
---|
449 | (2-4-14) KERNEL_CFLAGS カーネルに対するコンパイルオプション
|
---|
450 |
|
---|
451 | ターゲットに依存して,カーネルのソースが置かれたディレクトリ,カーネル
|
---|
452 | を構成するオブジェクトファイルのリスト,それらをコンパイルする際に適用
|
---|
453 | するコンパイルオプションを追加する場合には,上に示した変数に定義する.
|
---|
454 |
|
---|
455 | ほとんどの場合に,ターゲット依存部ディレクトリのMakefile.targetには,以
|
---|
456 | 下の記述を含める必要がある.
|
---|
457 |
|
---|
458 | ----------------------------------------
|
---|
459 | KERNEL_DIR := $(KERNEL_DIR) $(TARGETDIR)
|
---|
460 | KERNEL_ASMOBJS := $(KERNEL_ASMOBJS) target_support.o
|
---|
461 | KERNEL_COBJS := $(KERNEL_COBJS) target_config.o target_timer.o
|
---|
462 | ----------------------------------------
|
---|
463 |
|
---|
464 | (2-4-15) CFG_TABS コンフィギュレータに対するオプション
|
---|
465 |
|
---|
466 | ターゲットに依存して,コンフィギュレータに対するオプションを追加する場
|
---|
467 | 合には,上に示した変数に定義する.具体的には,コンフィギュレータの値取
|
---|
468 | 得シンボルテーブルのターゲット依存部(target_def.csv)がある場合には,
|
---|
469 | それを指定するオプションを追加する必要がある.
|
---|
470 |
|
---|
471 | ほとんどの場合に,ターゲット依存部ディレクトリのMakefile.targetには,以
|
---|
472 | 下の記述を含める必要がある.
|
---|
473 |
|
---|
474 | ----------------------------------------
|
---|
475 | CFG_TABS := $(CFG_TABS) --cfg1-def-table $(TARGETDIR)/target_def.csv
|
---|
476 | ----------------------------------------
|
---|
477 |
|
---|
478 | (2-4-16) CFG1_OUT_LDFLAGS cfg1_out.cに対するリンクオプション
|
---|
479 |
|
---|
480 | ターゲットに依存して,cfg1_out.cをリンクする際に適用するオプションを追
|
---|
481 | 加する場合には,上に示した変数に定義する.
|
---|
482 |
|
---|
483 | (2-4-17) CFG_OBJS システムコンフィギュレーションのためのオブ
|
---|
484 | ジェクト
|
---|
485 |
|
---|
486 | ターゲットに依存して,システムコンフィギュレーションのためのオブジェク
|
---|
487 | トファイルを(kernel_cfg.o以外に)追加する場合には,上に示した変数に定
|
---|
488 | 義する.この場合,追加したオブジェクトファイルの作成ルール(コンパイル/
|
---|
489 | アセンブルルールと依存関係作成ルール)を,Makefileのターゲット依存部に
|
---|
490 | 記述する必要がある.
|
---|
491 |
|
---|
492 | (2-4-18) CFG2_OUT
|
---|
493 |
|
---|
494 | ターゲットに依存して,コンフィギュレータのパス2でkernel_cfg.cと
|
---|
495 | kernel_cfg.h以外のファイルを生成する場合には,上に示した変数に定義する.
|
---|
496 |
|
---|
497 | (2-4-19) OMIT_WARINIG_ALL
|
---|
498 | (2-4-20) OMIT_OPTIMIZATION
|
---|
499 |
|
---|
500 | サンプルのMakefileでは,コンパイラに対するオプションに「-Wall -g -O2」
|
---|
501 | を追加する.-Wallを追加したくない場合には,Makefileのターゲット依存部で
|
---|
502 | OMIT_WARNING_ALLを"true"に定義する.-O2を追加したくない場合には,
|
---|
503 | Makefileのターゲット依存部でOMIT_OPTIMIZATIONを"true"に定義する.
|
---|
504 |
|
---|
505 | 2.5 オフセットファイルの生成方法
|
---|
506 |
|
---|
507 | アセンブリ言語で記述されるプログラムから,C言語の構造体にアクセスする場
|
---|
508 | 合には,構造体の各フィールドのオフセット値を参照することが必要である.
|
---|
509 | ASPカーネルでは,必要なオフセット値を求めてファイル(標準ではoffset.h)
|
---|
510 | に生成するための仕組みを用意している.
|
---|
511 |
|
---|
512 | この仕組みを用いることで,例えば,TCB中のtexptnフィールドのオフセット値
|
---|
513 | をTCB_texptnにマクロ定義することや,TCB中のタスクコンテキストブロック
|
---|
514 | (tskctxb)に含まれるpcフィールドのオフセット値をTCB_pcにマクロ定義する
|
---|
515 | ことができる.また,TCB中のenatexフィールドのオフセット値,ビット位置,
|
---|
516 | ビットマスクを,それぞれTCB_enatex,TCB_enatex_bit,TCB_enatex_maskにマ
|
---|
517 | クロ定義することができる.
|
---|
518 |
|
---|
519 | offset.hを生成するための仕組みとして,現時点では,コンフィギュレータを
|
---|
520 | 用いる方法と,makeoffset.cとgenoffsetを用いる方法を用意している.後者の
|
---|
521 | 方法は,GNU開発環境にしか対応していないことから,将来のバージョンでは,
|
---|
522 | 後者の方法のサポートをやめる計画である.新たにポーティングする場合には,
|
---|
523 | 前者の方法を用いることを推奨する.
|
---|
524 |
|
---|
525 | これらの仕組みでオフセットファイルを生成できない時には,offset.hをター
|
---|
526 | ゲット依存部で用意し,Makefileのターゲット依存部でOMIT_MAKEOFFSETを
|
---|
527 | "true"に定義する.
|
---|
528 |
|
---|
529 | 拡張パッケージの中には,TCBにフィールドを追加するものがあるため,TCB中
|
---|
530 | のフィールドのオフセット値は変化する.offset.hを生成する場合でも,ター
|
---|
531 | ゲット依存部で用意する場合でも,拡張パッケージに対応するためには,この
|
---|
532 | ことを考慮する必要がある.
|
---|
533 |
|
---|
534 | 2.5.1 コンフィギュレータを用いる方法
|
---|
535 |
|
---|
536 | コンフィギュレータのパス1で生成するcfg1_out.cをコンパイルして生成したオ
|
---|
537 | ブジェクトファイルから,コンフィギュレータによってoffset.hを生成する方
|
---|
538 | 法である.この方法を用いるためには,ターゲット依存部でオフセットファイ
|
---|
539 | ル生成用テンプレートファイルを用意し,target_cfg1_out.h(または,そこか
|
---|
540 | らインクルードされるファイル)とtarget_def.csv(または,同等の役割を持
|
---|
541 | つファイル)に記述を追加する必要がある.なお,これらのファイルを新たに
|
---|
542 | 用意した際や修正した際には,offset.hに妥当な定義が生成されていることを
|
---|
543 | 確認すべきである.
|
---|
544 |
|
---|
545 | オフセットファイル生成用テンプレートファイルは,ターゲット依存部で,
|
---|
546 | target_offset.tf(または,プロセッサ依存部やチップ依存部で用意するそれ
|
---|
547 | に代わるファイル)に用意する.また,Makefileのターゲット依存部で,次の
|
---|
548 | 例のように,OFFSET_TFにオフセットファイル生成用テンプレートファイルのファ
|
---|
549 | イル名を定義する.
|
---|
550 |
|
---|
551 | ----------------------------------------
|
---|
552 | # オフセットファイル生成のための定義
|
---|
553 | OFFSET_TF = $(TARGETDIR)/target_offset.tf
|
---|
554 | ----------------------------------------
|
---|
555 |
|
---|
556 | オフセットファイル生成用テンプレートファイルには,以下の内容を記述する.
|
---|
557 |
|
---|
558 | (1) 標準テンプレートファイルのインクルード
|
---|
559 |
|
---|
560 | オフセットファイル生成用の標準テンプレートファイル(kernel/genoffset.tf)
|
---|
561 | をインクルードする.標準テンプレートファイルには,以下で用いるDEFINE関
|
---|
562 | 数やDEFINE_BIT関数の定義などが含まれている.
|
---|
563 |
|
---|
564 | ----------------------------------------
|
---|
565 | $ 標準テンプレートファイルのインクルード
|
---|
566 | $INCLUDE "kernel/genoffset.tf"$
|
---|
567 | ----------------------------------------
|
---|
568 |
|
---|
569 | (2) オフセット値のマクロ定義の生成
|
---|
570 |
|
---|
571 | DEFINE関数を用いて,オフセット値のマクロ定義を生成する.例えば,TCB中の
|
---|
572 | タスクコンテキストブロック(tskctxb)に含まれるpcフィールドのオフセット
|
---|
573 | 値を,TCB_pcにマクロ定義する場合には,次のように記述する.
|
---|
574 |
|
---|
575 | ----------------------------------------
|
---|
576 | $ オフセット値のマクロ定義の生成
|
---|
577 | $DEFINE("TCB_pc", offsetof_TCB_pc)$
|
---|
578 | ----------------------------------------
|
---|
579 |
|
---|
580 | ここで,DEFINE関数の第1パラメータはマクロ定義するシンボル,第2パラメー
|
---|
581 | タは,オフセット値を保持するコンフィギュレータの変数である.
|
---|
582 |
|
---|
583 | また,コンフィギュレータが,オフセット値を保持する変数(上の例では
|
---|
584 | offsetof_TCB_pc)に値を設定するために,target_def.csv(または,同等の役
|
---|
585 | 割を持つファイル)に次の例のような行を追加する.
|
---|
586 |
|
---|
587 | ----------------------------------------
|
---|
588 | offsetof_TCB_pc,"offsetof(TCB,tskctxb.pc)"
|
---|
589 | ----------------------------------------
|
---|
590 |
|
---|
591 | ただし,各オブジェクトの初期化ブロックのターゲット非依存のフィールドの
|
---|
592 | オフセット値を取得するための記述は,kernel/kernel_def.csvに含まれている.
|
---|
593 | kernel/kernel_def.csvに含まれている記述は,target_def.csv(または,同等
|
---|
594 | の役割を持つファイル)に追加する必要はない.
|
---|
595 |
|
---|
596 | (3) ビットオフセット値等のマクロ定義の生成
|
---|
597 |
|
---|
598 | DEFINE_BIT関数を用いて,ビットのオフセット値,ビット位置,ビットマスク
|
---|
599 | のマクロ定義を生成する.例えば,TCB中のenatexフィールドのオフセット値,
|
---|
600 | ビット位置,ビットマスクを,それぞれTCB_enatex,TCB_enatex_bit,
|
---|
601 | TCB_enatex_maskにマクロ定義する場合には,次のように記述する.
|
---|
602 |
|
---|
603 | ----------------------------------------
|
---|
604 | $DEFINE_BIT("TCB_enatex", sizeof_TCB, "B")$
|
---|
605 | ----------------------------------------
|
---|
606 |
|
---|
607 | ここで,DEFINE_BIT関数の第1パラメータはマクロ定義するシンボル(の先頭部
|
---|
608 | 分),第2パラメータは構造体のサイズである.第3パラメータには,ビットの
|
---|
609 | オフセット,ビット位置,ビットマスクを,8ビット単位(バイト単位)で求め
|
---|
610 | る場合には"B"を,16ビット単位で求める場合には"H"を,32ビット単位で求め
|
---|
611 | る場合には"W"を指定する.なお,ビット位置は,LSBを0とした値(ビットリト
|
---|
612 | ルエンディアンを想定)を求める.
|
---|
613 |
|
---|
614 | また,target_cfg1_out.h(または,そこからインクルードされるファイル)に,
|
---|
615 | ビットオフセット値等を求めるための構造体の変数定義を追加する.この構造
|
---|
616 | 体の変数は,名称をマクロ定義するシンボル(DEFINE_BIT関数の第1パラメータ)
|
---|
617 | とし,対象のビットのみが1で,他のすべてのビットが0になるように初期化す
|
---|
618 | る.また,const修飾子を付加する.例えば,TCB中のenatexフィールドのビッ
|
---|
619 | トオフセット値等を求める場合には,次のような定義を追加する(tskctxbの初
|
---|
620 | 期値は,ターゲット依存なので注意すること).
|
---|
621 |
|
---|
622 | ----------------------------------------
|
---|
623 | const TCB TCB_enatex = {
|
---|
624 | { NULL, NULL }, /* task_queue */
|
---|
625 | NULL, /* p_tinib */
|
---|
626 | 0U, /* tstat */
|
---|
627 | #ifdef TOPPERS_SUPPORT_MUTEX
|
---|
628 | 0U, /* bpriority */
|
---|
629 | #endif /* TOPPERS_SUPPORT_MUTEX */
|
---|
630 | 0U, /* priority */
|
---|
631 | false, /* acqeue */
|
---|
632 | false, /* wupque */
|
---|
633 | true, /* enatex */
|
---|
634 | 0U, /* texptn */
|
---|
635 | NULL, /* p_winifo */
|
---|
636 | #ifdef TOPPERS_SUPPORT_MUTEX
|
---|
637 | { NULL, NULL }, /* mutex_queue */
|
---|
638 | #endif /* TOPPERS_SUPPORT_MUTEX */
|
---|
639 | #ifdef TOPPERS_SUPPORT_OVRTIM
|
---|
640 | 0U, /* leftotm */
|
---|
641 | #endif /* TOPPERS_SUPPORT_OVRTIM */
|
---|
642 | { NULL, NULL } /* tskctxb */
|
---|
643 | };
|
---|
644 | ----------------------------------------
|
---|
645 |
|
---|
646 | さらに,コンフィギュレータが,構造体のサイズ(上の例ではsizeof_TCB)に
|
---|
647 | 値を設定するために,target_def.csv(または,同等の役割を持つファイル)
|
---|
648 | に次の例のような行を追加する.
|
---|
649 |
|
---|
650 | ----------------------------------------
|
---|
651 | sizeof_TCB,sizeof(TCB)
|
---|
652 | ----------------------------------------
|
---|
653 |
|
---|
654 | ただし,前述した通り,kernel/kernel_def.csvに含まれている記述は,
|
---|
655 | target_def.csv(または,同等の役割を持つファイル)に追加する必要はない.
|
---|
656 |
|
---|
657 | 最後に,target_cfg1_out.h(または,そこからインクルードされるファイル)
|
---|
658 | に,offset.hを生成する仕組みが正しく動作していることを確認するための次
|
---|
659 | の記述を追加する.
|
---|
660 |
|
---|
661 | ----------------------------------------
|
---|
662 | const uint8_t MAGIC_1 = 0x12;
|
---|
663 | const uint16_t MAGIC_2 = 0x1234;
|
---|
664 | const uint32_t MAGIC_4 = 0x12345678;
|
---|
665 | ----------------------------------------
|
---|
666 |
|
---|
667 | 2.5.2 makeoffset.cとgenoffsetを用いる方法
|
---|
668 |
|
---|
669 | makeoffset.cは,どのオフセット値をoffset.hに生成するかを指定するファイ
|
---|
670 | ルで,ターゲット依存部で用意する.genoffsetは,makeoffset.cをコンパイル
|
---|
671 | して得られるアセンブリソースファイルから,offset.hを生成するスクリプト
|
---|
672 | である.genoffsetは,GNU開発環境にのみ対応している.
|
---|
673 |
|
---|
674 | makeoffset.cを記述する場合には,既存のターゲット依存部に含まれる
|
---|
675 | makeoffset.cを修正するのが近道である.標準的なmakeoffset.cは,以下の6つ
|
---|
676 | の部分で構成されている.なお,makeoffset.cを新たに記述した際には,
|
---|
677 | offset.hに妥当な定義が生成されていることを確認すべきである.
|
---|
678 |
|
---|
679 | (1) 必要なファイルのインクルード
|
---|
680 |
|
---|
681 | オフセット値を求めたいフィールドを含む構造体を定義するヘッダファイルを
|
---|
682 | インクルードする.TCB中のフィールドのオフセット値を求めたい場合には,以
|
---|
683 | 下の3行を含めればよい.
|
---|
684 |
|
---|
685 | #include "kernel_impl.h"
|
---|
686 | #include "task.h"
|
---|
687 | #include "sil.h"
|
---|
688 |
|
---|
689 | (2) オフセット値出力用マクロの定義
|
---|
690 |
|
---|
691 | 構造体中のフィールドのオフセット値の定義を生成するために用いるマクロ
|
---|
692 | (OFFSET_DEFとOFFSET_DEF2)の定義.これらのマクロの定義は,修正する必要
|
---|
693 | がない.
|
---|
694 |
|
---|
695 | (3) オフセット値出力用関数の定義
|
---|
696 |
|
---|
697 | 構造体中のフィールドのオフセット値の定義を生成するための関数
|
---|
698 | (makeoffset)の定義.オフセット値のマクロ定義を生成したいフィールド毎
|
---|
699 | に,次のいずれかのマクロを記述する.
|
---|
700 |
|
---|
701 | (2-5-2-1) OFFSET_DEF(TYPE, FIELD)
|
---|
702 |
|
---|
703 | TYPEに構造体のデータ型名,FIELDにその構造体中のフィールドを指定すると,
|
---|
704 | TYPE_FIELDという名前のシンボルに,そのフィールドのオフセット値をマクロ
|
---|
705 | 定義する記述を生成する.
|
---|
706 |
|
---|
707 | (2-5-2-2) OFFSET_DEF2(TYPE, FIELD, FIELDNAME)
|
---|
708 |
|
---|
709 | TYPEに構造体のデータ型名,FIELDにその構造体中のフィールドを指定すると,
|
---|
710 | TYPE_FIELDNAMEという名前のシンボルに,そのフィールドのオフセット値をマ
|
---|
711 | クロ定義する記述を生成する.構造体に含まれる構造体中のフィールドのオフ
|
---|
712 | セット値を求めたい場合には,こちらのマクロを使用する.
|
---|
713 |
|
---|
714 | (4) エンディアンを参照するための関数の定義
|
---|
715 |
|
---|
716 | SILで定義されたエンディアンを参照するための関数(sil_endian)の定義.こ
|
---|
717 | の関数の定義は,修正する必要がない.
|
---|
718 |
|
---|
719 | (5) ビットオフセット値出力のための参照定義
|
---|
720 |
|
---|
721 | 初期値を持った変数定義に対して,コンパイラが生成するアセンブリ命令を参
|
---|
722 | 照するための変数(BIT_REF_4,BIT_REF_2,BIT_REF_1)の定義.これらの定義
|
---|
723 | は,ほとんどの場合に修正する必要がない.ただし,uint8_t型のサポートされ
|
---|
724 | ていないターゲットでは,BIT_REF_1の定義は削除する必要がある.また,ポイ
|
---|
725 | ンタが64ビットのターゲット等では,BIT_REF_8の定義を追加しなければならな
|
---|
726 | いと思われる.
|
---|
727 |
|
---|
728 | (6) ビットオフセット値出力用変数の定義
|
---|
729 |
|
---|
730 | ビットのオフセット値,ビット位置,ビットマスクの定義を生成するためのデー
|
---|
731 | タ型の定義.これらの定義を生成したいビットフィールド毎に,以下の説明す
|
---|
732 | る変数を定義する.
|
---|
733 |
|
---|
734 | 構造体のデータ型名がTYPE,その構造体中のビットフィールド名がFIELDの場合
|
---|
735 | に,データ型がTYPEで,変数名がBIT_xy_TYPE_FIELDの変数を定義する.また,
|
---|
736 | その変数を,対象のビットのみが1で,他のすべてのビットが0になるように初
|
---|
737 | 期化する.ここで,xはエンディアンを指定する文字で,B(ビッグエンディア
|
---|
738 | ン)またはL(リトルエンディアン)を指定する.またyには,ビットのオフセッ
|
---|
739 | ト,ビット位置,ビットマスクを,8ビット単位(バイト単位)で求める場合に
|
---|
740 | はBを,16ビット単位で求める場合にはHを,32ビット単位で求める場合にはWを
|
---|
741 | 指定する.
|
---|
742 |
|
---|
743 | これにより,TYPE_FIELDという名前のシンボルにそのビットのオフセット,
|
---|
744 | TYPE_FIELD_bitという名前のシンボルにビット位置,TYPE_FIELD_maskという名
|
---|
745 | 前のシンボルにビットマスクをマクロ定義する記述を生成する.なお,ビット
|
---|
746 | 位置は,LSBを0とした値(ビットリトルエンディアンを想定)を求める.
|
---|
747 |
|
---|
748 | 2.6 リンク方法の設定
|
---|
749 |
|
---|
750 | (2-6-1) LDSCRIPT リンカスクリプトのファイル名
|
---|
751 |
|
---|
752 | 開発環境に標準のリンカスクリプトが使用できない場合には,ターゲット依存
|
---|
753 | 部でリンカスクリプトを用意し,そのファイル名をこの変数に定義する.
|
---|
754 |
|
---|
755 | (2-6-2) TEXT_START_ADDRESS テキストセクションの先頭番地
|
---|
756 | (2-6-3) DATA_START_ADDRESS データセクションの先頭番地
|
---|
757 |
|
---|
758 | 各セクションの先頭番地の指定が必要な場合には,これらの変数に先頭番地を
|
---|
759 | 定義する.
|
---|
760 |
|
---|
761 | (2-6-4) START_OBJS 先頭にリンクすべきモジュール名
|
---|
762 | (2-6-5) END_OBJS 最後にリンクすべきモジュール名
|
---|
763 |
|
---|
764 | ターゲットによっては,ロードモジュールの先頭と最後にリンクすべきモジュー
|
---|
765 | ルを,ターゲット依存部で用意する必要がある.多くの場合,スタートアップ
|
---|
766 | モジュールをロードモジュールの先頭にリンクする必要がある.
|
---|
767 |
|
---|
768 | ロードモジュールの先頭にリンクすべきプログラムがある場合には,Makefile
|
---|
769 | のターゲット依存部において,そのオブジェクトファイル名をSTART_OBJSに定
|
---|
770 | 義し,それに対するコンパイルルールと依存関係作成ルールを定義する.ロー
|
---|
771 | ドモジュールの最後にリンクすべきモジュールがある場合には,そのオブジェ
|
---|
772 | クトファイル名をEND_OBJSに定義し,それに対するコンパイルルールと依存関
|
---|
773 | 係作成ルールを定義する.また,標準のスタートアップモジュール(crt0.o)
|
---|
774 | をリンクしないように,LDFLAGSに-nostdlibを追加する必要がある.さら
|
---|
775 | に,-nostdlibをつけることで標準ライブラリがリンクされなくなるため,
|
---|
776 | LIBSに-lgccを追加しなければならない.
|
---|
777 |
|
---|
778 | 例えば,スタートアップモジュールのソースファイルがstart.Sの場合には,
|
---|
779 | Makefileのターゲット依存部に次のような記述を入れるとよい.
|
---|
780 |
|
---|
781 | ----------------------------------------
|
---|
782 | # スタートアップモジュールのオブジェクトファイル名
|
---|
783 | START_OBJS = start.o
|
---|
784 |
|
---|
785 | # スタートアップモジュールのコンパイルルール
|
---|
786 | $(START_OBJS): %.o: %.S
|
---|
787 | $(CC) -c $(CFLAGS) $(KERNEL_CFLAGS) $<
|
---|
788 |
|
---|
789 | # スタートアップモジュールの依存関係作成ルール
|
---|
790 | $(START_OBJS:.o=.d): %.d: %.S
|
---|
791 | @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
|
---|
792 | -O "$(CFLAGS) $(KERNEL_CFLAGS)" $< >> Makefile.depend
|
---|
793 |
|
---|
794 | # リンカに対するオプション
|
---|
795 | LDFLAGS := -nostdlib $(LDFLAGS)
|
---|
796 | LIBS := $(LIBS) -lgcc
|
---|
797 | ----------------------------------------
|
---|
798 |
|
---|
799 | また,GNU開発環境で,コンパイラに標準のcrtbegin.oとcrtend.oを用いる場合
|
---|
800 | には,Makefile のターゲット依存部に次のような記述を入れるとよい.
|
---|
801 |
|
---|
802 | ----------------------------------------
|
---|
803 | # オブジェクトファイル名
|
---|
804 | START_OBJS = $(shell $(CC) -print-file-name=crtbegin.o)
|
---|
805 | END_OBJS = $(shell $(CC) -print-file-name=crtend.o)
|
---|
806 |
|
---|
807 | # 依存関係作成ルール
|
---|
808 | $(START_OBJS:.o=.d): %.d:
|
---|
809 | $(END_OBJS:.o=.d): %.d:
|
---|
810 |
|
---|
811 | # リンカに対するオプション
|
---|
812 | LDFLAGS := -nostdlib $(LDFLAGS)
|
---|
813 | LIBS := $(LIBS) -lgcc
|
---|
814 | ----------------------------------------
|
---|
815 |
|
---|
816 | この場合,これらのファイルをコンパイルすることはないため,コンパイルルー
|
---|
817 | ルは不要である.また,依存関係作成ルールはダミーでよい(依存関係作成ルー
|
---|
818 | ルがないとエラーになる).
|
---|
819 |
|
---|
820 | (2-6-6) HIDDEN_OBJS 指定しなくてもリンクされるモジュール名
|
---|
821 |
|
---|
822 | ロードモジュールにリンクすべきモジュールを,リンカに対するパラメータで
|
---|
823 | はなく,リンカスクリプト中に(例えば,GNU開発環境のリンカスクリプトの
|
---|
824 | STARTUPを使って)記述する場合には,そのオブジェクトファイル名を,
|
---|
825 | (START_OBJSまたはEND_OBJSではなく)HIDDEN_OBJSに定義し,それに対するコ
|
---|
826 | ンパイルルールと依存関係作成ルールを定義する.HIDDEN_OBJSに定義したモ
|
---|
827 | ジュールは,リンカに対するパラメータからは除外される.LIBSとLDFLAGSにつ
|
---|
828 | いては,START_OBJSまたはEND_OBJSを用いる場合と同様である.
|
---|
829 |
|
---|
830 | 例えば,スタートアップモジュールのソースファイルがstart.Sで,start.oを
|
---|
831 | リンクすることをリンカスクリプト中に記述する場合には,Makefileのターゲッ
|
---|
832 | ト依存部に次のような記述を入れるとよい.
|
---|
833 |
|
---|
834 | ----------------------------------------
|
---|
835 | # スタートアップモジュールのオブジェクトファイル名
|
---|
836 | HIDDEN_OBJS = start.o
|
---|
837 |
|
---|
838 | # スタートアップモジュールのコンパイルルール
|
---|
839 | $(HIDDEN_OBJS): %.o: %.S
|
---|
840 | $(CC) -c $(CFLAGS) $(KERNEL_CFLAGS) $<
|
---|
841 |
|
---|
842 | # スタートアップモジュールの依存関係作成ルール
|
---|
843 | $(HIDDEN_OBJS:.o=.d): %.d: %.S
|
---|
844 | @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
|
---|
845 | -O "$(CFLAGS) $(KERNEL_CFLAGS)" $< >> Makefile.depend
|
---|
846 |
|
---|
847 | # リンカに対するオプション
|
---|
848 | LDFLAGS := -nostdlib $(LDFLAGS)
|
---|
849 | LIBS := $(LIBS) -lgcc
|
---|
850 | ----------------------------------------
|
---|
851 |
|
---|
852 | 2.7 依存関係の定義
|
---|
853 |
|
---|
854 | コンフィギュレータの各パスに対して,ターゲット依存のファイルへの依存関
|
---|
855 | 係を定義する.具体的には,パス1,パス2,パス3が依存するファイルを,それ
|
---|
856 | ぞれcfg1_out.c,kernel_cfg.timestamp,$(OBJFILE)に対する依存関係の形で
|
---|
857 | 記述する.
|
---|
858 |
|
---|
859 | ほとんどの場合に,ターゲット依存部ディレクトリのMakefile.targetには,以
|
---|
860 | 下の記述を含める必要がある.
|
---|
861 |
|
---|
862 | ----------------------------------------
|
---|
863 | cfg1_out.c: $(TARGETDIR)/target_def.csv
|
---|
864 | kernel_cfg.timestamp: $(TARGETDIR)/target.tf
|
---|
865 | $(OBJFILE): $(TARGETDIR)/target_check.tf
|
---|
866 | ----------------------------------------
|
---|
867 |
|
---|
868 | 2.8 その他の設定
|
---|
869 |
|
---|
870 | (2-8-1) CLEAN_FILES cleanにより削除するファイル名
|
---|
871 |
|
---|
872 | cleanにより削除するファイルをターゲット依存部で追加したい場合には,ファ
|
---|
873 | イル名をこの変数に追加定義する.
|
---|
874 |
|
---|
875 | (2-8-2) REALCLEAN_FILES realcleanにより削除するファイル名
|
---|
876 |
|
---|
877 | realcleanにより削除するファイルをターゲット依存部で追加したい場合には,
|
---|
878 | ファイル名をこの変数に追加定義する.
|
---|
879 |
|
---|
880 |
|
---|
881 | 3.TOPPERS共通定義のターゲット依存部
|
---|
882 |
|
---|
883 | TOPPERS共通定義(t_stddef.h)のターゲット依存部は,target_stddef.hまた
|
---|
884 | はそこからインクルードされるファイル(プロセッサ・チップ・開発環境依存
|
---|
885 | 部で用意されるヘッダファイルなど)に含める.
|
---|
886 |
|
---|
887 | 3.1 ターゲット識別マクロ
|
---|
888 |
|
---|
889 | アプリケーションやシステムサービスでターゲットを識別するために,
|
---|
890 | "TOPPERS_"にシステム略称を大文字にした文字列を連結したもの(例えば,
|
---|
891 | "TOPPERS_DVE68K")をマクロ定義する.
|
---|
892 |
|
---|
893 | また,ターゲット依存部からプロセッサ依存部やチップ依存部を切り分けた場
|
---|
894 | 合には,"TOPPERS_"に依存部略称を大文字にした文字列を連結したもの(例え
|
---|
895 | ば,"TOPPERS_M68K")をマクロ定義する.
|
---|
896 |
|
---|
897 | 3.2 整数型の最大値・最小値・ビット数
|
---|
898 |
|
---|
899 | (3-2-1) INT_MAX intに格納できる最大値(C90準拠)
|
---|
900 | (3-2-2) INT_MIN intに格納できる最小値(C90準拠)
|
---|
901 | (3-2-3) UINT_MAX unsigned intに格納できる最大値(C90準拠)
|
---|
902 | (3-2-4) LONG_MAX longに格納できる最大値(C90準拠)
|
---|
903 | (3-2-5) LONG_MIN longに格納できる最小値(C90準拠)
|
---|
904 | (3-2-6) ULONG_MAX unsigned longに格納できる最大値(C90準拠)
|
---|
905 | (3-2-7) CHAR_BIT char型のビット数(C90準拠)
|
---|
906 |
|
---|
907 | 整数型の最大値・最小値・ビット数を,これらのシンボルにマクロに定義する.
|
---|
908 |
|
---|
909 | これらのマクロは,C90に準拠したものである.開発環境にC90に準拠した
|
---|
910 | limits.hが用意されている場合には,これらのマクロを定義することに代えて,
|
---|
911 | limits.hをインクルードすればよい.
|
---|
912 |
|
---|
913 | 3.3 サイズの指定された整数型,その最大値・最小値,整数定数を作るマクロ
|
---|
914 |
|
---|
915 | (3-3-1) int8_t 符号付き8ビット整数(オプション,C99準拠)
|
---|
916 | (3-3-2) uint8_t 符号無し8ビット整数(オプション,C99準拠)
|
---|
917 | (3-3-3) int16_t 符号付き16ビット整数(C99準拠)
|
---|
918 | (3-3-4) uint16_t 符号無し16ビット整数(C99準拠)
|
---|
919 | (3-3-5) int32_t 符号付き32ビット整数(C99準拠)
|
---|
920 | (3-3-6) uint32_t 符号無し32ビット整数(C99準拠)
|
---|
921 | (3-3-7) int64_t 符号付き64ビット整数(オプション,C99準拠)
|
---|
922 | (3-3-8) uint64_t 符号無し64ビット整数(オプション,C99準拠)
|
---|
923 | (3-3-9) int128_t 符号付き128ビット整数(オプション,C99準拠)
|
---|
924 | (3-3-10) uint128_t 符号無し128ビット整数(オプション,C99準拠)
|
---|
925 | (3-3-11) int_least8_t 8ビット以上の符号付き整数(C99準拠)
|
---|
926 | (3-3-12) uint_least8_t 8ビット以上の符号無し整数(C99準拠)
|
---|
927 | (3-3-13) intptr_t ポインタを格納できるサイズの符号付き整数(C99準拠)
|
---|
928 | (3-3-14) uintptr_t ポインタを格納できるサイズの符号無し整数(C99準拠)
|
---|
929 | (3-3-15) INT8_MAX int8_tに格納できる最大値(オプション,C99準拠)
|
---|
930 | (3-3-16) INT8_MIN int8_tに格納できる最小値(オプション,C99準拠)
|
---|
931 | (3-3-17) UINT8_MAX uint8_tに格納できる最大値(オプション,C99準拠)
|
---|
932 | (3-3-18) INT16_MAX int16_tに格納できる最大値(C99準拠)
|
---|
933 | (3-3-19) INT16_MIN int16_tに格納できる最小値(C99準拠)
|
---|
934 | (3-3-20) UINT16_MAX uint16_tに格納できる最大値(C99準拠)
|
---|
935 | (3-3-21) INT32_MAX int32_tに格納できる最大値(C99準拠)
|
---|
936 | (3-3-22) INT32_MIN int32_tに格納できる最小値(C99準拠)
|
---|
937 | (3-3-23) UINT32_MAX uint32_tに格納できる最大値(C99準拠)
|
---|
938 | (3-3-24) INT64_MAX int64_tに格納できる最大値(オプション,C99準拠)
|
---|
939 | (3-3-25) INT64_MIN int64_tに格納できる最小値(オプション,C99準拠)
|
---|
940 | (3-3-26) UINT64_MAX uint64_tに格納できる最大値(オプション,C99準拠)
|
---|
941 | (3-3-27) INT128_MAX int128_tに格納できる最大値(オプション,C99準拠)
|
---|
942 | (3-3-28) INT128_MIN int128_tに格納できる最小値(オプション,C99準拠)
|
---|
943 | (3-3-29) UINT128_MAX uint128_tに格納できる最大値(オプション,C99準拠)
|
---|
944 | (3-3-30) INT_LEAST8_MAX int_least8_tに格納できる最大値(C99準拠)
|
---|
945 | (3-3-31) INT_LEAST8_MIN int_least8_tに格納できる最小値(C99準拠)
|
---|
946 | (3-3-32) UINT_LEAST8_MAX uint_least8_tに格納できる最大値(C99準拠)
|
---|
947 | (3-3-33) INT8_C(val) int_least8_t型の定数を作るマクロ(C99準拠)
|
---|
948 | (3-3-34) UINT8_C(val) uint_least8_t型の定数を作るマクロ(C99準拠)
|
---|
949 | (3-3-35) INT16_C(val) int16_t型の定数を作るマクロ(C99準拠)
|
---|
950 | (3-3-36) UINT16_C(val) uint16_t型の定数を作るマクロ(C99準拠)
|
---|
951 | (3-3-37) INT32_C(val) int32_t型の定数を作るマクロ(C99準拠)
|
---|
952 | (3-3-38) UINT32_C(val) uint32_t型の定数を作るマクロ(C99準拠)
|
---|
953 | (3-3-39) INT64_C(val) int64_t型の定数を作るマクロ(オプション,C99準拠)
|
---|
954 | (3-3-40) UINT64_C(val) uint64_t型の定数を作るマクロ(オプション,C99準拠)
|
---|
955 | (3-3-41) INT128_C(val) int128_t型の定数を作るマクロ(オプション,C99準拠)
|
---|
956 | (3-3-42) UINT128_C(val) uint128_t型の定数を作るマクロ(オプション,C99準拠)
|
---|
957 |
|
---|
958 | 指定されたサイズの整数型を,これらのシンボルに型定義する.また,データ
|
---|
959 | 型に格納できる最大値・最小値と,整数定数を作るマクロを,これらのシンボ
|
---|
960 | ルにマクロ定義する.
|
---|
961 |
|
---|
962 | これらのデータ型およびマクロは,C99に準拠したものである.開発環境にC99
|
---|
963 | に準拠したstdint.hが用意されている場合には,これらのデータ型およびマク
|
---|
964 | ロを定義することに代えて,stdint.hをインクルードすればよい.
|
---|
965 |
|
---|
966 | 上でオプションと記述したものは,該当するデータ型がコンパイラでサポート
|
---|
967 | されている場合にのみ定義することを示す.
|
---|
968 |
|
---|
969 | 3.4 サイズの指定された浮動小数点型,その最大値・最小値のマクロ
|
---|
970 |
|
---|
971 | (3-4-1) float32_t IEEE754準拠の32ビット単精度浮動小数点数(オプ
|
---|
972 | ション)
|
---|
973 | (3-4-2) double64_t IEEE754準拠の64ビット倍精度浮動小数点数(オプ
|
---|
974 | ション)
|
---|
975 | (3-4-3) FLOAT32_MIN float32_tに格納できる最小の正規化された正の浮
|
---|
976 | 動小数点数(オプション)
|
---|
977 | (3-4-4) FLOAT32_MAX float32_tに格納できる表現可能な最大の有限浮動
|
---|
978 | 小数点数(オプション)
|
---|
979 | (3-4-5) DOUBLE64_MIN double64_tに格納できる最小の正規化された正の浮
|
---|
980 | 動小数点数(オプション)
|
---|
981 | (3-4-6) DOUBLE64_MAX double64_tに格納できる表現可能な最大の有限浮動
|
---|
982 | 小数点数(オプション)
|
---|
983 |
|
---|
984 | 指定されたサイズ・表現形式の浮動小数点型を,これらのシンボルに型定義す
|
---|
985 | る.また,データ型に格納できる最大値・最小値を,これらのシンボルにマク
|
---|
986 | ロ定義する.
|
---|
987 |
|
---|
988 | いずれも,該当するデータ型がコンパイラでサポートされている場合にのみ定
|
---|
989 | 義する.
|
---|
990 |
|
---|
991 | 3.5 コンパイラの拡張機能のためのマクロ定義
|
---|
992 |
|
---|
993 | コンパイラの拡張機能を用いるためのマクロとして,必要に応じて,以下のマ
|
---|
994 | クロの定義を含める.
|
---|
995 |
|
---|
996 | (3-5-1) inline(オプション,デフォルトは未定義)
|
---|
997 | (3-5-2) Inline(オプション,デフォルトはstatic inline)
|
---|
998 |
|
---|
999 | インライン関数であることを示す指定.Inlineは,コンパイル単位にローカル
|
---|
1000 | なインライン関数であることを示す.
|
---|
1001 |
|
---|
1002 | (3-5-3) asm(オプション,デフォルトは未定義)
|
---|
1003 | (3-5-4) Asm(オプション,デフォルトは未定義)
|
---|
1004 |
|
---|
1005 | インラインアセンブラを記述するための指定.Asmは,最適化により削除しては
|
---|
1006 | ならないことを示す.これらは,ターゲット依存部でのみ使うマクロであるた
|
---|
1007 | め,ターゲット依存部で使わないなら定義する必要はない.
|
---|
1008 |
|
---|
1009 | (3-5-5) offsetof(structure, field)(オプション,デフォルトの定義あり)
|
---|
1010 |
|
---|
1011 | 構造体structureの中での,フィールドfieldのオフセットを求めるマクロ.
|
---|
1012 |
|
---|
1013 | (3-5-6) alignof(type)(オプション,デフォルトの定義あり)
|
---|
1014 |
|
---|
1015 | データ型typeのアラインメント単位を求めるマクロ.
|
---|
1016 |
|
---|
1017 | (3-5-7) NoReturn(オプション,デフォルトは未定義)
|
---|
1018 |
|
---|
1019 | リターンすることのない関数であることを示す指定.これは,ターゲット依存
|
---|
1020 | 部のみ使うマクロであるため,ターゲット依存部で使わないなら定義する必要
|
---|
1021 | はない.
|
---|
1022 |
|
---|
1023 | 3.6 標準的な定義の上書き
|
---|
1024 |
|
---|
1025 | t_stddef.hに含まれるTOPPERS共通定義の標準的な定義を上書きする場合には,
|
---|
1026 | 以下のマクロを定義する.
|
---|
1027 |
|
---|
1028 | (3-6-1) TOPPERS_bool(オプション,デフォルトはint)
|
---|
1029 | (3-6-2) TOPPERS_size(オプション,デフォルトはuintptr_t)
|
---|
1030 | (3-6-3) TOPPERS_fp(オプション,デフォルトは他と互換性のない関数ポインタ)
|
---|
1031 |
|
---|
1032 | それぞれ,bool_t,SIZE,FPに型定義すべきデータ型.
|
---|
1033 |
|
---|
1034 | (3-6-4) UINT_C(val)(オプション,デフォルトはUを付加)
|
---|
1035 | (3-6-5) ULONG_C(val)(オプション,デフォルトはULを付加)
|
---|
1036 |
|
---|
1037 | それぞれ,unsigned uint型,unsigned long型の定数を作るためのマクロ.
|
---|
1038 |
|
---|
1039 | (3-6-6) NULL(オプション,デフォルトは0)
|
---|
1040 |
|
---|
1041 | C90準拠のC言語環境では,NULLの定義はstddef.hに含まれているため,これを
|
---|
1042 | インクルードしてもよい.
|
---|
1043 |
|
---|
1044 | (3-6-7) ERCD(mercd, sercd)(オプション)
|
---|
1045 | (3-6-8) MERCD(ercd)(オプション)
|
---|
1046 | (3-6-9) SERCD(ercd)(オプション)
|
---|
1047 |
|
---|
1048 | ERCD,MERCD,SERCDの標準の定義は,符号付き整数が2の補数で表現されており,
|
---|
1049 | 右シフト演算子(>>)が算術シフトされることを仮定している.多くのコンパ
|
---|
1050 | イラでこの仮定が成り立つが,そうでない場合には,ターゲット依存部でこれ
|
---|
1051 | らの定義を上書きする必要がある.
|
---|
1052 |
|
---|
1053 | (3-6-10) ALIGN_TYPE(addr, type)(オプション)
|
---|
1054 |
|
---|
1055 | アドレスaddrが,データ型typeのアラインメント単位にアラインしているか
|
---|
1056 | チェックするマクロ.
|
---|
1057 |
|
---|
1058 | 3.7 アサーションのための定義
|
---|
1059 |
|
---|
1060 | t_stddef.hには,assertの定義が含まれる.assertが失敗した場合(assertの
|
---|
1061 | パラメータがfalseになった場合)の処理を,ターゲット依存に用意する必要が
|
---|
1062 | ある.これらの定義は,assertマクロを使用する前であれば,t_stddef.h以降
|
---|
1063 | にインクルードされるファイルに含まれていてもよい.なお,assertを無効に
|
---|
1064 | する(NDEBUGをマクロ定義してコンパイルする)場合には,これらを用意する
|
---|
1065 | 必要はない.
|
---|
1066 |
|
---|
1067 | (3-7-1) TOPPERS_assert_abort(void)
|
---|
1068 |
|
---|
1069 | assertが失敗した場合に,プログラムを停止させる関数.システム開発中はデ
|
---|
1070 | バッガに落とすのが理想的である.システム稼働時には例外処理を行わせるこ
|
---|
1071 | とになる.
|
---|
1072 |
|
---|
1073 | (3-7-2) TOPPERS_assert_fail(exp, file, line)
|
---|
1074 |
|
---|
1075 | assertが失敗した時の情報を表示/記録するためのマクロ.システムログ機能を
|
---|
1076 | 用いる場合には,t_syslog.hにシステムログ機能に記録するための定義が含ま
|
---|
1077 | れているので,ターゲット依存部で用意する必要はない.
|
---|
1078 |
|
---|
1079 |
|
---|
1080 | 4.システムインタフェースレイヤ(SIL)のターゲット依存部
|
---|
1081 |
|
---|
1082 | システムインタフェースレイヤ(SIL,sil.h)のターゲット依存部の定義は,
|
---|
1083 | target_sil.hまたはそこからインクルードされるファイル(プロセッサ・チッ
|
---|
1084 | プ・開発環境依存部で用意されるヘッダファイルなど)に含める.
|
---|
1085 |
|
---|
1086 | SILのサービスコールは,任意のシステム状態で呼び出すことができる.そのた
|
---|
1087 | め,SILのターゲット依存部の関数は,任意のシステム状態で呼び出せるように
|
---|
1088 | 実装しなければならない.
|
---|
1089 |
|
---|
1090 | 4.1 全割込みロック状態の管理
|
---|
1091 |
|
---|
1092 | SILのターゲット依存部では,全割込みロック状態へ遷移する機能と,元の状態
|
---|
1093 | へ戻す機能(元の状態を記憶するために変数を使う)を提供する.全割込みロッ
|
---|
1094 | ク状態であるかを判別する機能は提供する必要がない.
|
---|
1095 |
|
---|
1096 | SILの機能は,カーネルを使用しない場合にも使用できる必要がある.そのため,
|
---|
1097 | 全割込みロック状態への遷移と元の状態への復帰は,カーネルを用いず,プロ
|
---|
1098 | セッサのリソースを直接操作することによって実現する.また,全割込みロッ
|
---|
1099 | ク状態への遷移と元の状態への復帰は,全割込みロック状態やCPUロック状態で
|
---|
1100 | も行える必要がある.
|
---|
1101 |
|
---|
1102 | 保護機能を持ったカーネルでは,ユーザタスクからプロセッサのリソースを直
|
---|
1103 | 接操作することができないため,ユーザタスクからはこれらの機能を用いるこ
|
---|
1104 | とができない.用いた場合の振舞いはターゲットプロセッサに依存するが,典
|
---|
1105 | 型的には,特権命令違反などのCPU例外が発生することになる.
|
---|
1106 |
|
---|
1107 | (4-1-1) SIL_PRE_LOC
|
---|
1108 |
|
---|
1109 | 全割込みロックフラグの状態を保存するための変数を定義するマクロ.型名の
|
---|
1110 | 後に,変数名を続けたものに定義する.変数名は,他の名前と衝突しないよう
|
---|
1111 | に,"TOPPERS_"で始まる名前にする.
|
---|
1112 |
|
---|
1113 | (4-1-2) SIL_LOC_INT()
|
---|
1114 |
|
---|
1115 | 現在の全割込みロックフラグの状態をSIL_PRE_LOCで定義した変数に保存し,全
|
---|
1116 | 割込みロック状態に遷移させるマクロ.このマクロを実現する際には,「1.6
|
---|
1117 | クリティカルセクションの出入処理の実現に関する制約」の節に記述されてい
|
---|
1118 | る制約に従わなければならない.
|
---|
1119 |
|
---|
1120 | (4-1-3) SIL_UNL_INT()
|
---|
1121 |
|
---|
1122 | SIL_LOC_INT()によって変数に保存した状態に戻すマクロ.このマクロを実現す
|
---|
1123 | る際には,「1.6 クリティカルセクションの出入処理の実現に関する制約」の
|
---|
1124 | 節に記述されている制約に従わなければならない.
|
---|
1125 |
|
---|
1126 | 4.2 微少時間待ち
|
---|
1127 |
|
---|
1128 | (4-2-1) void sil_dly_nse(ulong_t dlytim)
|
---|
1129 |
|
---|
1130 | dlytimで指定された以上の時間(単位はナノ秒),ループなどによって待つ関
|
---|
1131 | 数.
|
---|
1132 |
|
---|
1133 | 以下の関数と等価な処理を,アセンブリ言語で記述する方法を,標準的な実装
|
---|
1134 | 方法とする.アセンブリ言語で記述するのは,コンパイラの最適化に依存しな
|
---|
1135 | いようにするためである.またこの関数は,キャッシュ等の影響を受けないよ
|
---|
1136 | うに,できる限りメモリアクセスを行わないように実装すべきである.
|
---|
1137 |
|
---|
1138 | void sil_dly_nse(ulong_t dlytim)
|
---|
1139 | {
|
---|
1140 | dlytim -= SIL_DLY_TIM1;
|
---|
1141 | if (結果が0より大きい) {
|
---|
1142 | do {
|
---|
1143 | dlytim -= SIL_DLY_TIM2;
|
---|
1144 | } while (結果が0より大きい);
|
---|
1145 | }
|
---|
1146 | }
|
---|
1147 |
|
---|
1148 | この関数の動作は次の通りである.dlytimがSIL_DLY_TIM1以下の場合には,最
|
---|
1149 | 初のif文の条件が成立せず,すぐに関数から抜ける.dlytimがSIL_DLY_TIM1よ
|
---|
1150 | り大きく,(SIL_DLY_TIM1+SIL_DLY_TIM2)以下の場合には,最初のif文の条件は
|
---|
1151 | 成立するが,doループは1回も回らずに関数から抜ける.dlytimが
|
---|
1152 | (SIL_DLY_TIM1+SIL_DLY_TIM2)より大きく,(SIL_DLY_TIM1+SIL_DLY_TIM2*2)以
|
---|
1153 | 下の場合には,doループを1回だけ回って関数から抜ける.その後,dlytimが
|
---|
1154 | SIL_DLY_TIM2大きくなる度に,whileループを回る回数が1回ずつ増える.
|
---|
1155 |
|
---|
1156 | なお,この関数をアセンブリ言語(または,C言語)で記述する場合,どのファ
|
---|
1157 | イルに記述するかが問題になる.SILのターゲット依存部には,標準では,アセ
|
---|
1158 | ンブリ言語(または,C言語)の関数定義を記述するためのファイルを用意して
|
---|
1159 | いない.ターゲット依存で用意してもよいが,例外的に,カーネル実装のター
|
---|
1160 | ゲット依存モジュール(target_support.Sまたはtarget_config.c)に記述して
|
---|
1161 | もよいことにする.
|
---|
1162 |
|
---|
1163 | (4-2-2) SIL_DLY_TIM1(オプション)
|
---|
1164 | (4-2-3) SIL_DLY_TIM2(オプション)
|
---|
1165 |
|
---|
1166 | sil_dly_nseを上記の標準的な方法で実現した場合,この2つの定数をターゲッ
|
---|
1167 | ト依存部でマクロ定義する.
|
---|
1168 |
|
---|
1169 | SIL_DLY_TIM2は,上記の関数において,doループ1回の実行時間(単位はナノ秒)
|
---|
1170 | に設定する.ターゲットプロセッサの命令セットにもよるが,おおよそ,減算
|
---|
1171 | 命令と条件分岐命令各1回の実行時間になる.SIL_DLY_TIM2が決まれば,関数呼
|
---|
1172 | 出しも含めた全体の時間がdlytimで指定された以上の時間になるように,
|
---|
1173 | SIL_DLY_TIM1を決める.
|
---|
1174 |
|
---|
1175 | この2つの定数値の決定を支援するプログラムとして,testディレクトリに,
|
---|
1176 | test_dlynseを用意している.test_dlynseを実行すると,次のような出力が得
|
---|
1177 | られる.
|
---|
1178 |
|
---|
1179 | -- for fitting parameters --
|
---|
1180 | sil_dly_nse(0): 430 OK
|
---|
1181 | sil_dly_nse(420): 430 OK
|
---|
1182 | sil_dly_nse(510): 520 OK
|
---|
1183 | sil_dly_nse(600): 610 OK
|
---|
1184 | <中略>
|
---|
1185 | -- for checking boundary conditions --
|
---|
1186 | sil_dly_nse(421): 520 OK
|
---|
1187 | sil_dly_nse(511): 610 OK
|
---|
1188 | sil_dly_nse(601): 700 OK
|
---|
1189 |
|
---|
1190 | "for fitting parameters"に続く出力は,sil_dly_nse(dlytim)を呼び出した場
|
---|
1191 | 合の待ち時間を測定した結果である.このプログラムを用いて,":"の右側の数
|
---|
1192 | 値が,dlytimよりも大きい範囲でなるべく近い値になるように,2つの定数値を
|
---|
1193 | 調整する."for checking boundary conditions"に続く出力は,プログラムの
|
---|
1194 | 妥当性をチェックするためのもので,":"の右側の数値が,dlytimよりも大きい
|
---|
1195 | ことを確認する(近い値になる必要はない).
|
---|
1196 |
|
---|
1197 | 4.3 プロセッサのエンディアン
|
---|
1198 |
|
---|
1199 | (4-3-1) SIL_ENDIAN_BIG
|
---|
1200 | (4-3-2) SIL_ENDIAN_LITTLE
|
---|
1201 |
|
---|
1202 | プロセッサのエンディアンにより,いずれか片方のシンボルをマクロ定義する.
|
---|
1203 |
|
---|
1204 | (4-3-3) TOPPERS_SIL_REV_ENDIAN_UINT16(オプション)
|
---|
1205 | (4-3-4) TOPPERS_SIL_REV_ENDIAN_UINT32(オプション)
|
---|
1206 |
|
---|
1207 | それぞれ,16ビット,32ビットの符号無し整数のエンディアンを反転させるマ
|
---|
1208 | クロ.プロセッサがエンディアン反転のための命令を持つ場合には,その命令
|
---|
1209 | を用いて実現する.これらのシンボルをマクロ定義しない場合には,デフォル
|
---|
1210 | トの定義が使われる.
|
---|
1211 |
|
---|
1212 | 4.4 メモリ空間アクセス関数
|
---|
1213 |
|
---|
1214 | (4-4-1) TOPPERS_OMIT_SIL_ACCESS
|
---|
1215 |
|
---|
1216 | 標準のメモリ空間アクセス関数を使用せず,ターゲット依存部で用意する場合
|
---|
1217 | には,このシンボルをマクロ定義する.
|
---|
1218 |
|
---|
1219 | (4-4-2) TOPPERS_OMIT_SIL_REH_LEM
|
---|
1220 | (4-4-3) TOPPERS_OMIT_SIL_WRH_LEM
|
---|
1221 | (4-4-4) TOPPERS_OMIT_SIL_REH_BEM
|
---|
1222 | (4-4-5) TOPPERS_OMIT_SIL_WRH_BEM
|
---|
1223 | (4-4-6) TOPPERS_OMIT_SIL_REW_LEM
|
---|
1224 | (4-4-7) TOPPERS_OMIT_SIL_WRW_LEM
|
---|
1225 | (4-4-8) TOPPERS_OMIT_SIL_REW_BEM
|
---|
1226 | (4-4-9) TOPPERS_OMIT_SIL_WRW_BEM
|
---|
1227 |
|
---|
1228 | それぞれ,標準のsil_reh_lem,sil_wrh_lem,sil_reh_bem,sil_wrh_bem,
|
---|
1229 | sil_rew_lem,sil_wrw_lem,sil_rew_bem,sil_wrw_bemを使用せず,ターゲッ
|
---|
1230 | ト依存部で用意する場合には,これらのシンボルをマクロ定義する.
|
---|
1231 |
|
---|
1232 | 4.5 I/O空間アクセス関数
|
---|
1233 |
|
---|
1234 | メモリ空間とは別にI/O空間を持つプロセッサでは,I/O空間にあるデバイスレ
|
---|
1235 | ジスタをアクセスするための関数として,sil_reb_iop,sil_wrb_iop,
|
---|
1236 | sil_reh_iop,sil_wrh_iop,sil_reh_lep,sil_wrh_lep,sil_reh_bep,
|
---|
1237 | sil_wrh_bep,sil_rew_iop,sil_wrw_iop,sil_rew_lep,sil_wrw_lep,
|
---|
1238 | sil_rew_bep,sil_wrw_bepの中で必要なものを,ターゲット依存部で用意する.
|
---|
1239 |
|
---|
1240 |
|
---|
1241 | 5.カーネルAPIのターゲット依存部
|
---|
1242 |
|
---|
1243 | カーネルAPI(kernel.h)のターゲット依存部の定義は,target_kernel.hまた
|
---|
1244 | はそこからインクルードされるファイル(プロセッサ・チップ・開発環境依存
|
---|
1245 | 部で用意されるヘッダファイルなど)に含める.
|
---|
1246 |
|
---|
1247 | 5.1 ターゲット定義でサポートする機能
|
---|
1248 |
|
---|
1249 | (5-1-1) TOPPERS_TARGET_SUPPORT_DIS_INT dis_intをサポートする
|
---|
1250 | (5-1-2) TOPPERS_TARGET_SUPPORT_ENA_INT ena_intをサポートする
|
---|
1251 | (5-1-3) TOPPERS_TARGET_SUPPORT_GET_UTM get_utmをサポートする
|
---|
1252 |
|
---|
1253 | dis_int,ena_int,get_utmをサポートする場合に,それぞれのシンボルをマク
|
---|
1254 | ロ定義する.
|
---|
1255 |
|
---|
1256 | 5.2 割込み優先度の範囲
|
---|
1257 |
|
---|
1258 | (5-2-1) TMIN_INTPRI 割込み優先度の最小値(最高値)
|
---|
1259 | (5-2-2) TMAX_INTPRI 割込み優先度の最大値(最低値)
|
---|
1260 |
|
---|
1261 | それぞれ,カーネル管理の割込み優先度の最小値(=優先度が最高),カーネ
|
---|
1262 | ル管理の割込み優先度の最大値(優先度が最低)に定義する.TMAX_INTPRIは-1
|
---|
1263 | に固定されているが,対称性のために,ターゲット依存部で定義することにし
|
---|
1264 | ている.
|
---|
1265 |
|
---|
1266 | 5.3 タイムティックの定義
|
---|
1267 |
|
---|
1268 | (5-3-1) TIC_NUME タイムティックの周期の分子
|
---|
1269 | (5-3-2) TIC_DENO タイムティックの周期の分母
|
---|
1270 |
|
---|
1271 | タイムティックの周期(signal_timeを呼び出す周期)を,ミリ秒単位で,
|
---|
1272 | TIC_NUME/TIC_DENOに定義する.例えば,タイムティックの周期が1/30秒の場合
|
---|
1273 | には,TIC_NUMEを100に,TIC_DENOを3に定義すればよい.
|
---|
1274 |
|
---|
1275 | タイムティックの周期は,1ミリ秒とする(つまり,TIC_NUME,TIC_DENOとも1
|
---|
1276 | に定義する)ことを推奨するが,シミュレーション環境や性能の低いプロセッ
|
---|
1277 | サでそれが適切でない場合には,それ以外の値としてもよい.その場合でも,
|
---|
1278 | 可能な限り,1ミリ秒の倍数である(つまり,TIC_DENOを1に定義する)ことが
|
---|
1279 | 望ましい.
|
---|
1280 |
|
---|
1281 | TIC_NUMEとTIC_DENOの定義を変更することで,タイムティックの周期を変更で
|
---|
1282 | きるようにタイマドライバを実装する場合には,この2つの定数の定義はデフォ
|
---|
1283 | ルト値を与えていることになる.そこで,これらの定義を「#ifndef TIC_NUME」
|
---|
1284 | 「#endif」で囲んで記述する.
|
---|
1285 |
|
---|
1286 | 5.4 メモリ領域確保のための型定義
|
---|
1287 |
|
---|
1288 | (5-4-1) TOPPERS_STK_T スタック領域を確保するための型(オプション)
|
---|
1289 | (5-4-2) TOPPERS_MPF_T 固定長メモリプール領域を確保するための型(オプション)
|
---|
1290 |
|
---|
1291 | スタック領域と固定長メモリプール領域は,標準では,intptr_t型の配列とし
|
---|
1292 | て確保するが,より大きい単位でアラインさせたいなどの理由で,それ以外の
|
---|
1293 | 型の配列として確保する場合には,それぞれTOPPERS_STK_TとTOPPERS_MPF_Tを,
|
---|
1294 | 配列のベースとなるデータ型にマクロ定義する.
|
---|
1295 |
|
---|
1296 | 5.5 ビットパターンのビット数
|
---|
1297 |
|
---|
1298 | (5-5-1) TBIT_TEXPTN タスク例外要因のビット数(オプション)
|
---|
1299 | (5-5-2) TBIT_FLGPTN イベントフラグのビット数(オプション)
|
---|
1300 |
|
---|
1301 | TBIT_TEXPTN,TBIT_FLGPTNの標準の定義では,整数型の有効ビット数が,その
|
---|
1302 | 型のsizeofにCHAR_BITを乗じたものと一致していることを仮定している.多く
|
---|
1303 | のコンパイラでこの仮定が成り立つが,そうでない場合には,ターゲット依存
|
---|
1304 | 部でこれらの定義を上書きする必要がある.ただし,これらの値は16以上でな
|
---|
1305 | ければならない.
|
---|
1306 |
|
---|
1307 | 5.6 メモリ領域確保のためのマクロ
|
---|
1308 |
|
---|
1309 | (5-6-1) TOPPERS_ROUND_SZ(オプション)
|
---|
1310 | (5-6-2) TOPPERS_COUNT_SZ(オプション)
|
---|
1311 |
|
---|
1312 | TOPPERS_COUNT_SZ(sz, unit)は,sz/unitを切り上げた値を求めるマクロで,サ
|
---|
1313 | イズがszのメモリ領域をサイズがunitのデータ型の配列で確保する場合の要素
|
---|
1314 | 数を求めるために用いる.TOPPERS_ROUND_SZ(sz, unit)は,sz/unitを切り上げ
|
---|
1315 | たものにunitをかけた値を求めるマクロで,サイズがszのメモリ領域をサイズ
|
---|
1316 | がunitのデータ型の配列で確保する場合のトータルサイズを求めるために用い
|
---|
1317 | る.
|
---|
1318 |
|
---|
1319 | それぞれ,標準のTOPPERS_ROUND_SZ,TOPPERS_COUNT_SZが適切でなく,ターゲッ
|
---|
1320 | ト依存部で用意する場合には,これらのシンボルを適切な値にマクロ定義する.
|
---|
1321 |
|
---|
1322 | 5.7 オーバランハンドラ機能拡張のための定義(オプション)
|
---|
1323 |
|
---|
1324 | オーバランハンドラ機能拡張パッケージをサポートする(使用できるようにす
|
---|
1325 | る)場合には,次の3つを実施することが必要である.
|
---|
1326 |
|
---|
1327 | ・この節で説明する定義を行う.
|
---|
1328 | ・6章に示すコード中で,TOPPERS_SUPPORT_OVRHDRがマクロ定義されている場
|
---|
1329 | 合にのみ有効となるコードを実装する.
|
---|
1330 | ・オーバランタイマドライバを用意する.オーバランタイマドライバについて
|
---|
1331 | は,「6.14 オーバランタイマドライバ」の節を参照すること.
|
---|
1332 |
|
---|
1333 | (5-7-1) TOPPERS_TARGET_SUPPORT_OVRHDR
|
---|
1334 |
|
---|
1335 | オーバランハンドラ機能拡張パッケージをサポートする場合には,このシンボ
|
---|
1336 | ルをマクロ定義する.
|
---|
1337 |
|
---|
1338 | (5-7-2) TMAX_OVRTIM(オプション,デフォルトはULONG_MAX)
|
---|
1339 |
|
---|
1340 | プロセッサ時間としてオーバランタイマに設定できる最大値(単位はマイクロ
|
---|
1341 | 秒)にマクロ定義する.
|
---|
1342 |
|
---|
1343 |
|
---|
1344 | 6.カーネル実装のターゲット依存部
|
---|
1345 |
|
---|
1346 | 6.1 カーネル実装のターゲット依存部の共通事項
|
---|
1347 |
|
---|
1348 | 6.1.1 カーネル実装のターゲット依存部の構成要素
|
---|
1349 |
|
---|
1350 | カーネル実装のターゲット依存部は,以下の要素で構成される.
|
---|
1351 |
|
---|
1352 | (a) カーネル実装のターゲット依存の定義
|
---|
1353 |
|
---|
1354 | カーネル実装のターゲット非依存部から参照されるターゲット依存の定義は,
|
---|
1355 | target_config.hまたはそこからインクルードされるファイル(プロセッサ・チッ
|
---|
1356 | プ・開発環境依存部で用意されるヘッダファイルなど)に含める.
|
---|
1357 |
|
---|
1358 | ターゲットのハードウェア資源(割込みハンドラ番号やCPU例外ハンドラ番号,
|
---|
1359 | デバイスレジスタの番地など)の定義は,システムサービスやアプリケーショ
|
---|
1360 | ンにも有用であるため,カーネル実装のみに有用な定義を含むファイルとは切
|
---|
1361 | り分けて,独立したヘッダファイルに含める.このヘッダファイルの標準的な
|
---|
1362 | 名称を,システム略称.h(または,チップ略称.h,プロセッサ略称.h)とする.
|
---|
1363 |
|
---|
1364 | (b) カーネル実装のターゲット依存モジュール
|
---|
1365 |
|
---|
1366 | カーネル実装のターゲット依存の変数定義や関数を含むモジュール.C言語で記
|
---|
1367 | 述される部分をtarget_config.c,アセンブリ言語で記述される部分を
|
---|
1368 | target_support.Sに含める.プロセッサ・チップ・開発環境依存部を切り分け
|
---|
1369 | ることや,ファイルが大きくなる場合に複数のファイルに分割することも可能
|
---|
1370 | である.
|
---|
1371 |
|
---|
1372 | (c) カーネル実装のターゲット依存部のためのリネーム記述
|
---|
1373 |
|
---|
1374 | カーネル実装のターゲット依存部の変数名や関数名を,先頭に_kernel_を付与
|
---|
1375 | した名前にリネームするためのモジュール.target_rename.defを用意し,ツー
|
---|
1376 | ル(utils/genrename)により,target_rename.hとtarget_unrename.hを生成す
|
---|
1377 | る.プロセッサ・チップ・開発環境依存部を切り分ける場合には,リネーム記
|
---|
1378 | 述も切り分ける.
|
---|
1379 |
|
---|
1380 | (d) タイマドライバ
|
---|
1381 |
|
---|
1382 | カーネルにタイムティックを通知する(signal_timeを周期的に呼び出す)ため
|
---|
1383 | のタイマドライバのヘッダファイル,実装ファイル,システムコンフィギュレー
|
---|
1384 | ションファイルを,それぞれ,target_timer.h,target_timer.c,
|
---|
1385 | target_timer.cfgに含める.プロセッサ・チップ・開発環境依存部を切り分け
|
---|
1386 | ることも可能である.
|
---|
1387 |
|
---|
1388 | また,オーバランハンドラ機能拡張パッケージをサポートする場合には,オー
|
---|
1389 | バランハンドラを起動する(call_ovrhdrを呼び出す)ためのオーバランタイマ
|
---|
1390 | ドライバも,同じファイルに含める.
|
---|
1391 |
|
---|
1392 | なお,この章に示すコード中で,TOPPERS_SUPPORT_OVRHDRがマクロ定義されて
|
---|
1393 | いる場合にのみ有効となるコードは,オーバランハンドラ機能拡張パッケージ
|
---|
1394 | をサポートしない場合には,実装する必要がない.
|
---|
1395 |
|
---|
1396 | (e) コンフィギュレータ設定ファイル
|
---|
1397 |
|
---|
1398 | コンフィギュレータの設定ファイルのターゲット依存部を,target_def.csv,
|
---|
1399 | target.tf,target_check.tfに用意する.コンフィギュレータ設定ファイルの
|
---|
1400 | 記述方法については,7章で説明する.
|
---|
1401 |
|
---|
1402 | 6.1.2 ターゲット依存部の関数の命名規則
|
---|
1403 |
|
---|
1404 | カーネル実装のターゲット依存部を構成する関数の中で,t_で始まるものはタ
|
---|
1405 | スクコンテキスト専用,i_で始まるものは非タスクコンテキスト専用,x_で始
|
---|
1406 | まるものはいずれのコンテキストからでも呼び出すことができる関数である.
|
---|
1407 |
|
---|
1408 | 6.2 トレースログ機能への対応
|
---|
1409 |
|
---|
1410 | カーネルのトレースログ機能の中で,ディスパッチャ,割込みハンドラ,CPU例
|
---|
1411 | 外ハンドラの開始・終了のトレースログ取得は,ターゲット依存部で実装する
|
---|
1412 | 必要がある.ほとんどのターゲットシステムにおいて,それらの処理はアセン
|
---|
1413 | ブリ言語で記述されており,ターゲット非依存部向けのトレースログマクロと
|
---|
1414 | 同じ方法(トレースログマクロを,トレースログ取得処理のC言語記述にマクロ
|
---|
1415 | 定義する方法)は,用いることができない.
|
---|
1416 |
|
---|
1417 | そこで,アセンブリ言語で記述されている処理中にトレースログ取得を埋め込
|
---|
1418 | む場合には,トレースログマクロが定義されていれば,それが何に定義されて
|
---|
1419 | いるかは無視して,標準的なトレースログ関数がC言語で記述されていると想定
|
---|
1420 | して,それを呼び出すようにコーディングする.
|
---|
1421 |
|
---|
1422 | 具体的には,下の表の左側に示したトレースログマクロが定義されていれば,
|
---|
1423 | 表の右側に示したC言語記述と同等の処理を行うようにコーディングする.
|
---|
1424 |
|
---|
1425 | トレースログマクロ トレースログ取得処理
|
---|
1426 | -----------------------------------------------
|
---|
1427 | LOG_DSP_ENTER log_dsp_enter(p_runtsk)
|
---|
1428 | LOG_DSP_LEAVE log_dsp_leave(p_runtsk)
|
---|
1429 | LOG_INH_ENTER log_inh_enter(inhno)
|
---|
1430 | LOG_INH_LEAVE log_inh_leave(inhno)
|
---|
1431 | LOG_EXC_ENTER log_exc_enter(excno)
|
---|
1432 | LOG_EXC_LEAVE log_exc_leave(excno)
|
---|
1433 |
|
---|
1434 | 6.3 システム状態の管理
|
---|
1435 |
|
---|
1436 | ASPカーネルを新たなターゲットシステムにポーティングする際に,最も重要な
|
---|
1437 | 作業は,カーネルが定義するシステム状態を,ハードウェア(プロセッサ)上
|
---|
1438 | でどのように実現するかである.以下の説明は,TOPPERS新世代カーネルにおけ
|
---|
1439 | るシステム状態の定義・意味を知っていることを前提に記述している.
|
---|
1440 |
|
---|
1441 | 6.3.1 全割込みロック状態の管理
|
---|
1442 |
|
---|
1443 | 全割込みロック状態は,NMIを除くすべての割込みをマスクした状態である.全
|
---|
1444 | 割込みロック状態を管理する機能は,システムインタフェースレイヤ(SIL)に
|
---|
1445 | よって提供され,カーネルは全割込みロック状態を管理しない.
|
---|
1446 |
|
---|
1447 | 全割込みロック状態では,sns_kerとext_ker以外のカーネルのサービスコール
|
---|
1448 | を呼ぶことはできないものとしており,呼んだ場合には何が起こるか保証して
|
---|
1449 | いない.sns_kerとext_kerから呼び出す処理は,トレースログ取得処理とSILの
|
---|
1450 | サービスコールを除くと,call_exit_kernelのみである.そのため,
|
---|
1451 | call_exit_kernelから呼び出すものを除いて,カーネルのターゲット依存部の
|
---|
1452 | 関数が,全割込みロック状態で呼び出される状況は考える必要がない.
|
---|
1453 |
|
---|
1454 | 6.3.2 コンテキストの管理
|
---|
1455 |
|
---|
1456 | 処理単位が実行されるコンテキストは,タスクコンテキストと非タスクコンテ
|
---|
1457 | キストに分類される.
|
---|
1458 |
|
---|
1459 | ターゲット依存部は,実行中の処理単位が,タスクコンテキストで実行されて
|
---|
1460 | いるか非タスクコンテキストで実行されているかを判別する機能を提供する.
|
---|
1461 | また,CPU例外が発生したコンテキストについて判別する機能を提供する.
|
---|
1462 |
|
---|
1463 | ターゲット依存部では,割込みハンドラとCPU例外ハンドラの入口処理で非タス
|
---|
1464 | クコンテキストに切り換え,それらの出口処理で元のコンテキストに戻す.ま
|
---|
1465 | た,ディスパッチャの内部で一時的に非タスクコンテキストに切り換える.
|
---|
1466 |
|
---|
1467 | (6-3-2-1) bool_t sense_context(void)
|
---|
1468 |
|
---|
1469 | 実行中の処理単位が,タスクコンテキストで実行されている場合にはfalse,非
|
---|
1470 | タスクコンテキストで実行されている場合にはtrueを返す関数.この関数は,
|
---|
1471 | CPUロック状態でもCPUロック解除状態でも呼び出せるように実装しなければな
|
---|
1472 | らない.
|
---|
1473 |
|
---|
1474 | 6.3.3 CPUロック状態の管理
|
---|
1475 |
|
---|
1476 | ターゲット依存部は,CPUロック状態へ遷移する機能,CPUロック解除状態へ遷
|
---|
1477 | 移する機能,CPUロック状態であるかを判別する機能を提供する.
|
---|
1478 |
|
---|
1479 | (6-3-3-1) void t_lock_cpu(void)
|
---|
1480 | (6-3-3-2) void i_lock_cpu(void)
|
---|
1481 | (6-3-3-3) void x_lock_cpu(void)
|
---|
1482 |
|
---|
1483 | CPUロック解除状態から,CPUロック状態へ遷移させる関数.これらの関数は,
|
---|
1484 | CPUロック状態で呼び出されることはなく,呼び出された場合の動作は保証する
|
---|
1485 | 必要がない.
|
---|
1486 |
|
---|
1487 | これらの関数を実現する際には,「1.6 クリティカルセクションの出入処理の
|
---|
1488 | 実現に関する制約」の節に記述されている制約に従わなければならない.
|
---|
1489 |
|
---|
1490 | (6-3-3-4) void t_unlock_cpu(void)
|
---|
1491 | (6-3-3-5) void i_unlock_cpu(void)
|
---|
1492 | (6-3-3-6) void x_unlock_cpu(void)
|
---|
1493 |
|
---|
1494 | CPUロック状態から,CPUロック解除状態へ遷移させる関数.これらの関数は,
|
---|
1495 | CPUロック解除状態で呼び出されることはなく,呼び出された場合の動作は保証
|
---|
1496 | する必要がない.
|
---|
1497 |
|
---|
1498 | タスクコンテキストでCPUロック状態に遷移した場合には,CPUロック解除状態
|
---|
1499 | に戻るのはタスクコンテキストに限られ,非タスクコンテキストでCPUロック解
|
---|
1500 | 除状態に戻ることはない.言い換えると,t_unlock_cpuが呼び出されるのは,
|
---|
1501 | t_lock_cpuによってCPUロック状態になっている時である.i_lock_cpuによって
|
---|
1502 | CPUロック状態になっている時には,t_unlock_cpuが呼び出されることはない.
|
---|
1503 |
|
---|
1504 | 同様に,非タスクコンテキストでCPUロック状態に遷移した場合には,CPUロッ
|
---|
1505 | ク解除状態に戻るのは非タスクコンテキストに限られ,タスクコンテキストで
|
---|
1506 | CPUロック解除状態に戻ることはない.言い換えると,i_unlock_cpuが呼び出さ
|
---|
1507 | れるのは,i_lock_cpuによってCPUロック状態になっている時である.
|
---|
1508 | t_lock_cpuによってCPUロック状態になっている時には,i_unlock_cpuが呼び出
|
---|
1509 | されることはない.
|
---|
1510 |
|
---|
1511 | これらの関数を実現する際には,「1.6 クリティカルセクションの出入処理の
|
---|
1512 | 実現に関する制約」の節に記述されている制約に従わなければならない.
|
---|
1513 |
|
---|
1514 | (6-3-3-7) bool_t t_sense_lock(void)
|
---|
1515 | (6-3-3-8) bool_t i_sense_lock(void)
|
---|
1516 | (6-3-3-9) bool_t x_sense_lock(void)
|
---|
1517 |
|
---|
1518 | 現在のシステム状態が,CPUロック状態の場合はtrue,CPUロック解除状態の場
|
---|
1519 | 合にはfalseを返す関数.
|
---|
1520 |
|
---|
1521 | これらの関数が全割込みロック状態で呼び出される状況は考える必要がないこ
|
---|
1522 | とから,全割込みロック状態とCPUロック状態を区別できる必要はない.NMI以
|
---|
1523 | 外にカーネルの管理外の割込みを設けない場合には,全割込みロック状態と
|
---|
1524 | CPUロック状態が全く同一の状態でもかまわない.
|
---|
1525 |
|
---|
1526 | 6.4 割込みに関連するシステム状態の管理
|
---|
1527 |
|
---|
1528 | 6.4.1 割込み優先度マスクの管理
|
---|
1529 |
|
---|
1530 | ターゲット依存部は,割込み優先度マスクを設定する機能と,割込み優先度マ
|
---|
1531 | スクを参照する機能を提供する.
|
---|
1532 |
|
---|
1533 | (6-4-1-1) bool_t VALID_INTPRI_CHGIPM(PRI intpri)(オプション)
|
---|
1534 |
|
---|
1535 | intpriが,chg_ipmに対する割込み優先度として有効な値である場合にtrue,そ
|
---|
1536 | うでない場合にfalseを返すマクロ.標準では,TMIN_INTPRI以上,TIPM_ENAALL
|
---|
1537 | (=0)以下の値がchg_ipmに対する割込み優先度として有効であるが,ターゲッ
|
---|
1538 | ト依存部でこのマクロを定義することで,TMIN_INTPRIよりも小さい値を有効と
|
---|
1539 | することができる(有効な値の範囲を狭めてはならない).
|
---|
1540 |
|
---|
1541 | (6-4-1-2) void x_set_ipm(PRI intpri)
|
---|
1542 | (6-4-1-3) void t_set_ipm(PRI intpri)
|
---|
1543 | (6-4-1-4) void i_set_ipm(PRI intpri)
|
---|
1544 |
|
---|
1545 | 割込み優先度マスクの値をintpriに設定する関数.
|
---|
1546 |
|
---|
1547 | これらの関数は,CPUロック状態でもCPUロック解除状態でも呼び出せるように
|
---|
1548 | 実装するのが望ましい.ただし,x_set_ipmとt_set_ipmは,ターゲット非依存
|
---|
1549 | 部がCPUロック解除状態で呼び出すことはないため,CPUロック解除状態で呼び
|
---|
1550 | 出された場合の動作は保証する必要がない.i_set_ipmは,CPUロック状態でも
|
---|
1551 | CPUロック解除状態でも呼び出せるように実装しなければならない.
|
---|
1552 |
|
---|
1553 | また,これらの関数は,VALID_INTPRI_CHGIPM(intpri)がtrueを返すintpriに対
|
---|
1554 | してのみ呼ばれる.intpriにそうでない値が渡された場合の動作は保証する必
|
---|
1555 | 要がない.
|
---|
1556 |
|
---|
1557 | (6-4-1-5) PRI x_get_ipm(void)
|
---|
1558 | (6-4-1-6) PRI t_get_ipm(void)
|
---|
1559 | (6-4-1-7) PRI i_get_ipm(void)
|
---|
1560 |
|
---|
1561 | 割込み優先度マスクの値を参照して返す関数.
|
---|
1562 |
|
---|
1563 | これらの関数は,CPUロック状態でもCPUロック解除状態でも呼び出せるように
|
---|
1564 | 実装するのが望ましい.ただし,x_get_ipmとt_get_ipmは,ターゲット非依存
|
---|
1565 | 部がCPUロック解除状態で呼び出すことはないため,CPUロック解除状態で呼び
|
---|
1566 | 出された場合の動作は保証する必要がない.i_get_ipmは,CPUロック状態でも
|
---|
1567 | CPUロック解除状態でも呼び出せるように実装しなければならない.
|
---|
1568 |
|
---|
1569 | 割込み優先度マスクを用いてカーネル管理の割込みをすべてマスクした状態は,
|
---|
1570 | CPUロック状態と区別できることが必要である.具体的には,CPUロック解除状
|
---|
1571 | 態において,x_set_ipmを用いてカーネル管理の割込みをすべてマスクした場合
|
---|
1572 | でも,x_sense_lockはfalseを返す.
|
---|
1573 |
|
---|
1574 | それに対して,割込み優先度マスクを用いてNMIを除くすべての割込みをマスク
|
---|
1575 | できる場合,その状態と全割込みロック状態を区別できる必要はなく,全く同
|
---|
1576 | 一の状態でもかまわない.
|
---|
1577 |
|
---|
1578 | 6.4.2 割込み要求禁止フラグの管理
|
---|
1579 |
|
---|
1580 | ターゲット依存部は,割込み要求禁止フラグをセットする機能とクリアする機
|
---|
1581 | 能を提供する.
|
---|
1582 |
|
---|
1583 | (6-4-2-1) bool_t VALID_INTNO_DISINT(INTNO intno)
|
---|
1584 |
|
---|
1585 | intnoが,dis_int/ena_intに対する割込み番号として有効な値である場合に
|
---|
1586 | true,そうでない場合にfalseを返すマクロ.割込み要求禁止フラグがセット/
|
---|
1587 | クリアできないintnoに対しては,このマクロがfalseを返すようにする.
|
---|
1588 |
|
---|
1589 | (6-4-2-2) bool_t x_disable_int(INTNO intno)
|
---|
1590 | (6-4-2-3) bool_t t_disable_int(INTNO intno)
|
---|
1591 | (6-4-2-4) bool_t i_disable_int(INTNO intno)
|
---|
1592 |
|
---|
1593 | intnoで指定された割込み要求ラインに対する割込み要求禁止フラグをセットし,
|
---|
1594 | trueを返す関数.指定された割込み要求ラインに対して,割込み属性が設定さ
|
---|
1595 | れていない場合には,falseを返す.
|
---|
1596 |
|
---|
1597 | これらの関数は,ターゲット非依存部がCPUロック解除状態で呼び出すことはな
|
---|
1598 | いため,CPUロック解除状態で呼び出された場合の動作は保証する必要がない.
|
---|
1599 | ただし,ターゲット依存部からCPUロック解除状態で呼び出す場合には,保証す
|
---|
1600 | る必要がある.
|
---|
1601 |
|
---|
1602 | また,これらの関数は,VALID_INTNO_DISINT(intno)がtrueとなるintnoに対し
|
---|
1603 | てのみ呼ばれる.intnoにそうでない値が渡された場合の動作は保証する必要が
|
---|
1604 | ない.
|
---|
1605 |
|
---|
1606 | dis_intサービスコールをサポートする場合(TOPPERS_SUPPORT_DIS_INTをマク
|
---|
1607 | ロ定義する場合)には,t_disable_intが用意されていなければならない.
|
---|
1608 |
|
---|
1609 | (6-4-2-5) bool_t x_enable_int(INTNO intno)
|
---|
1610 | (6-4-2-6) bool_t t_enable_int(INTNO intno)
|
---|
1611 | (6-4-2-7) bool_t i_enable_int(INTNO intno)
|
---|
1612 |
|
---|
1613 | intnoで指定された割込み要求ラインに対する割込み要求禁止フラグをクリアし,
|
---|
1614 | trueを返す関数.指定された割込み要求ラインに対して,割込み属性が設定さ
|
---|
1615 | れていない場合には,falseを返す.
|
---|
1616 |
|
---|
1617 | これらの関数は,ターゲット非依存部がCPUロック解除状態で呼び出すことはな
|
---|
1618 | いため,CPUロック解除状態で呼び出された場合の動作は保証する必要がない.
|
---|
1619 | ただし,ターゲット依存部からCPUロック解除状態で呼び出す場合には,保証す
|
---|
1620 | る必要がある.
|
---|
1621 |
|
---|
1622 | また,これらの関数は,VALID_INTNO_DISINT(intno)がtrueとなるintnoに対し
|
---|
1623 | てのみ呼ばれる.intnoにそうでない値が渡された場合の動作は保証する必要が
|
---|
1624 | ない.
|
---|
1625 |
|
---|
1626 | ena_intサービスコールをサポートする場合(TOPPERS_SUPPORT_ENA_INTをマク
|
---|
1627 | ロ定義する場合)には,t_enable_intが用意されていなければならない.
|
---|
1628 |
|
---|
1629 | 6.4.3 割込み要求のクリア
|
---|
1630 |
|
---|
1631 | (6-4-3-1) void x_clear_int(INTNO intno)
|
---|
1632 | (6-4-3-2) void t_clear_int(INTNO intno)
|
---|
1633 | (6-4-3-3) void i_clear_int(INTNO intno)
|
---|
1634 |
|
---|
1635 | intnoで指定された割込み要求ラインがエッジトリガである場合に,トリガされ
|
---|
1636 | た割込み要求をクリアする関数.intnoで指定された割込み要求ラインがレベル
|
---|
1637 | トリガである場合には何もしない.
|
---|
1638 |
|
---|
1639 | ASPカーネルのターゲット非依存部では,これらの関数を呼び出していないが,
|
---|
1640 | ターゲット依存部やシステムサービスで呼び出す可能性が高いため,用意する
|
---|
1641 | こととしている.そのため,これらの関数がどのようなシステム状態で呼び出
|
---|
1642 | せるかは,ターゲット依存部内で一貫していればよい.
|
---|
1643 |
|
---|
1644 | 6.4.4 割込み要求のプローブ
|
---|
1645 |
|
---|
1646 | (6-4-4-1) bool_t x_probe_int(INTNO intno)
|
---|
1647 | (6-4-4-2) bool_t t_probe_int(INTNO intno)
|
---|
1648 | (6-4-4-3) bool_t i_probe_int(INTNO intno)
|
---|
1649 |
|
---|
1650 | intnoで指定された割込み要求ラインに対して,割込みが要求されている場合に
|
---|
1651 | true,そうでない場合にfalseを返す関数.
|
---|
1652 |
|
---|
1653 | ASPカーネルのターゲット非依存部では,これらの関数を呼び出していないが,
|
---|
1654 | ターゲット依存部やシステムサービスで呼び出す可能性が高いため,用意する
|
---|
1655 | こととしている.そのため,これらの関数がどのようなシステム状態で呼び出
|
---|
1656 | せるかは,ターゲット依存部内で一貫していればよい.
|
---|
1657 |
|
---|
1658 | 6.4.5 割込みハンドラの先頭処理と末尾処理
|
---|
1659 |
|
---|
1660 | (6-4-5-1) void i_begin_int(INTNO intno)
|
---|
1661 |
|
---|
1662 | intnoで指定された割込み要求ラインに対する割込みハンドラの先頭で行うべき
|
---|
1663 | 処理を行う関数.ここで行うべき処理としては,割込み要求ラインがエッジト
|
---|
1664 | リガである場合のトリガされた割込み要求のクリアが挙げられる.
|
---|
1665 |
|
---|
1666 | intnoに対して登録された割込みサービスルーチンを呼び出す割込みハンドラの
|
---|
1667 | 先頭で呼び出される.そのためこの関数は,割込みハンドラの先頭(通常は
|
---|
1668 | CPUロック解除状態)で呼び出せるように実装しなければならない.
|
---|
1669 |
|
---|
1670 | (6-4-5-2) void i_end_int(INTNO intno)
|
---|
1671 |
|
---|
1672 | intnoで指定された割込み要求ラインに対する割込みハンドラの末尾で行うべき
|
---|
1673 | 処理を行う関数.ここで行うべき処理としては,割込みコントローラ(IRC)に
|
---|
1674 | 対する割込み処理の終了通知が挙げられる.
|
---|
1675 |
|
---|
1676 | intnoに対して登録された割込みサービスルーチンを呼び出す割込みハンドラの
|
---|
1677 | 末尾で呼び出される.そのためこの関数は,割込みハンドラの末尾(通常は
|
---|
1678 | CPUロック解除状態)で呼び出せるように実装しなければならない.
|
---|
1679 |
|
---|
1680 | ターゲットによっては,IRCに対する割込み処理の終了通知を行う前に,すべて
|
---|
1681 | の割込みを禁止しなければならない場合がある.この場合には,この関数の中
|
---|
1682 | で割込みを禁止し,その状態のまま,割込みハンドラからリターンする.割込
|
---|
1683 | みハンドラからのリターン前には,割込み禁止を解除するのが原則であるが,
|
---|
1684 | 割込みハンドラの出口処理で元に戻す処理を行うので差し支えないはずである.
|
---|
1685 | 割込みハンドラの出口処理が,これで差し支えない実装になっていることを確
|
---|
1686 | 認するべきである.
|
---|
1687 |
|
---|
1688 | 6.5 タスクディスパッチャ
|
---|
1689 |
|
---|
1690 | 6.5.1 タスクコンテキストブロックとタスク初期化コンテキストブロック
|
---|
1691 |
|
---|
1692 | (6-5-1-1) TSKCTXB
|
---|
1693 |
|
---|
1694 | ターゲット依存のタスクコンテキストを保存するために,TCB中に持つことが必
|
---|
1695 | 要なデータ構造の型を,TSKCTXBに定義する.標準的には,TSKCTXBには,タス
|
---|
1696 | クのスタックポインタと実行再開番地を格納する.
|
---|
1697 |
|
---|
1698 | (6-5-1-2) USE_TSKINICTXB(オプション)
|
---|
1699 | (6-5-1-3) TSKINICTXB(オプション)
|
---|
1700 |
|
---|
1701 | ターゲット依存の情報をタスク初期化ブロック(TINIB)に入れたい場合や,
|
---|
1702 | TINIB中のスタック領域のサイズと先頭番地の持ち方をターゲット依存に変更し
|
---|
1703 | たい場合には,USE_TSKINICTXBをマクロ定義し,TINIB中に持つことが必要なデー
|
---|
1704 | タ構造の型を,TSKINICTXBに定義する.
|
---|
1705 |
|
---|
1706 | USE_TSKINICTXBをマクロ定義すると,TINIB中にスタック領域とサイズと先頭番
|
---|
1707 | 地が含まれなくなるため,それに代わる情報をTSKINICTXB中に持つ必要がある.
|
---|
1708 | また,コンフィギュレータのパス2のテンプレートファイルのターゲット非依存
|
---|
1709 | 部で,TSKINICTXBの初期化情報を生成するためのGENERATE_TSKINICTXBを,パス
|
---|
1710 | 3のテンプレートファイルのターゲット非依存部で,TINIBからスタック領域の
|
---|
1711 | 先頭番地を取り出すためのGET_STK_TSKINICTXBを定義する必要がある.
|
---|
1712 |
|
---|
1713 | 6.5.2 ディスパッチャ本体
|
---|
1714 |
|
---|
1715 | ディスパッチャ本体(dispatcher)は,ターゲット非依存部から直接呼び出さ
|
---|
1716 | れることはなく,カーネルのターゲット依存部の内部からのみ呼び出される.
|
---|
1717 | dispatcherは,タスクコンテキスト・CPUロック状態・割込み優先度マスク全解
|
---|
1718 | 除状態・ディスパッチ許可状態で呼び出される.
|
---|
1719 |
|
---|
1720 | dispatcherの処理内容は次の通り.
|
---|
1721 |
|
---|
1722 | ----------------------------------------
|
---|
1723 | void
|
---|
1724 | dispatcher(void)
|
---|
1725 | {
|
---|
1726 | #ifdef LOG_DSP_ENTER
|
---|
1727 | log_dsp_enter(p_runtsk);
|
---|
1728 | #endif /* LOG_DSP_ENTER */
|
---|
1729 | dispatcher_0:
|
---|
1730 | while ((p_runtsk = p_schedtsk) == NULL) {
|
---|
1731 | 割込みを許可したらCPUロック解除状態になるよう準備する
|
---|
1732 | 非タスクコンテキストに切り換える … (*1)
|
---|
1733 | do {
|
---|
1734 | 割込みをすべて許可し,割込み発生を待つ … (*2)
|
---|
1735 | 割込み許可前の状態に戻す(=カーネル管理の割込みを禁止する)
|
---|
1736 | } while (!reqflg);
|
---|
1737 | reqflg = false;
|
---|
1738 | タスクコンテキストに戻す … (*1)
|
---|
1739 | CPUロック状態に戻す ... (*3)
|
---|
1740 | }
|
---|
1741 | 自タスク(p_runtsk)のTCBからスタックポインタを復帰する
|
---|
1742 | #ifdef LOG_DSP_LEAVE
|
---|
1743 | log_dsp_leave(p_runtsk);
|
---|
1744 | #endif /* LOG_DSP_LEAVE */
|
---|
1745 | 自タスクのTCBから実行再開番地を復帰し,そこへ分岐する … (*a)
|
---|
1746 | }
|
---|
1747 | ----------------------------------------
|
---|
1748 |
|
---|
1749 | 割込み発生を待つ間に非タスクコンテキストに切り換えるのは,この間に実行
|
---|
1750 | される割込みハンドラ内で,タスクディスパッチをしないようにするためであ
|
---|
1751 | る.この時,割込みハンドラが,非タスクコンテキスト用のスタックを使うよ
|
---|
1752 | うにしなければならない.通常は,非タスクコンテキストに切り換える際に非
|
---|
1753 | タスクコンテキスト用のスタックに切り換え,タスクコンテキストに戻す際に
|
---|
1754 | 元のスタックに切り換える.
|
---|
1755 |
|
---|
1756 | ターゲットによっては(特に,シミュレーション環境の場合),強制的に非タ
|
---|
1757 | スクコンテキストに切り換えることが難しい場合がある.その場合には,この
|
---|
1758 | 間に実行される割込みハンドラ内でタスクディスパッチをしないような仕組み
|
---|
1759 | を実装することで,非タスクコンテキストへの切換えを省略することができる.
|
---|
1760 |
|
---|
1761 | (*1)の非タスクコンテキストに切り換える処理とタスクコンテキストに戻す処
|
---|
1762 | 理は,doループの中で行ってもよい(ターゲットによっては,割込みの許可/
|
---|
1763 | 禁止とまとめて処理した方が効率が良い).
|
---|
1764 |
|
---|
1765 | (*2)において,割込みを許可する処理と,割込み発生を待つ処理とは,不可分
|
---|
1766 | に行なう必要がある.これを不可分に行なわない場合,割込みを許可した直後
|
---|
1767 | に割込みが入り,その中でタスクが実行可能状態になると,実行すべきタスク
|
---|
1768 | があるにもかかわらずプロセッサが割込み待ちになってしまう.
|
---|
1769 |
|
---|
1770 | また,(*2)において,割込み発生を待つ命令が用意されていない場合や,それ
|
---|
1771 | を発行するのが不都合な場合には,割込みをすべて許可して割込みを受け付け
|
---|
1772 | られる状態になった後に,割込み発生を待たずに次に進んでもよい.この場合,
|
---|
1773 | その外側のdoループによって,割込み発生を待つことになる.
|
---|
1774 |
|
---|
1775 | CPUロックを解除するための情報(例えば,CPUロック前の割込み優先度マスク)
|
---|
1776 | を変数に保持している場合には,(*3)でCPUロック状態に戻す際に,その変数の
|
---|
1777 | 値も元に戻っている必要がある.特に,その変数が,割込み待ちの間に実行し
|
---|
1778 | た割込みハンドラ内で書き換えられる場合は,元の値に戻すことが必要である.
|
---|
1779 |
|
---|
1780 | 割込み待ちの間は,p_runtskをNULL(=0)に設定しなければならない(上の処
|
---|
1781 | 理内容をそのまま実装すればこうなる).このように設定しないと,割込みハ
|
---|
1782 | ンドラからiget_tidを呼び出した際の動作が仕様に合致しなくなる.
|
---|
1783 |
|
---|
1784 | (*a)において,実行再開番地は,TCBではなく,スタックに保存/復帰する方法
|
---|
1785 | もある.この場合,タスクの実行開始前にスタックを使ってはならないため,
|
---|
1786 | タスクの起動処理を例外扱いする必要がある.
|
---|
1787 |
|
---|
1788 | dispatcherをアセンブリ言語で記述する場合には,トレースログ取得処理は,
|
---|
1789 | 「6.2 トレースログ機能への対応」の節で記述した方法でコーディングするこ
|
---|
1790 | と.なお,log_dsp_enterは切換え前のタスクのスタックで,log_dsp_leave は
|
---|
1791 | 切換え後のタスクのスタックで実行する.
|
---|
1792 |
|
---|
1793 | 6.5.3 タスクコンテキストからのディスパッチ
|
---|
1794 |
|
---|
1795 | (6-5-3-1) void dispatch(void)
|
---|
1796 | (6-5-3-2) OMIT_CALLTEX(オプション)
|
---|
1797 |
|
---|
1798 | タスクコンテキストからのディスパッチ(dispatch)は,タスクコンテキスト
|
---|
1799 | 用のサービスコール処理においてタスク切換えが必要になった場合に,ターゲッ
|
---|
1800 | ト非依存部のサービスコール処理関数から呼び出される.
|
---|
1801 |
|
---|
1802 | dispatchは,タスクコンテキスト・CPUロック状態・割込み優先度マスク全解除
|
---|
1803 | 状態・ディスパッチ許可状態で呼び出される.
|
---|
1804 |
|
---|
1805 | dispatchの処理内容は次の通り.
|
---|
1806 |
|
---|
1807 | ----------------------------------------
|
---|
1808 | void
|
---|
1809 | dispatch(void)
|
---|
1810 | {
|
---|
1811 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1812 | ovrtimer_stop(); /* オーバランタイマの停止 */
|
---|
1813 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1814 | スクラッチレジスタ(*)を除くすべてのレジスタをスタックに保存する
|
---|
1815 | スタックポインタを自タスク(p_runtsk)のTCBに保存する
|
---|
1816 | dispatch_rを,実行再開番地として自タスクのTCBに保存する … (*a)
|
---|
1817 | dispatcherに分岐する
|
---|
1818 |
|
---|
1819 | dispatch_r:
|
---|
1820 | スクラッチレジスタを除くすべてのレジスタをスタックから復帰する
|
---|
1821 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1822 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
1823 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1824 | calltex(); … (*b)
|
---|
1825 | }
|
---|
1826 | ----------------------------------------
|
---|
1827 |
|
---|
1828 | ここでスクラッチレジスタ(*)とは,関数呼出しにより保存されないレジスタの
|
---|
1829 | ことである.必要な場合には,関数を呼び出す側で保存しなければならないた
|
---|
1830 | め,caller saved registerと呼ばれる場合もある.
|
---|
1831 |
|
---|
1832 | dispatchを呼び出したタスクが次に実行される時には,実行再開番地として登
|
---|
1833 | 録したdispatch_rに戻ってくる.dispatch_rには,dispatcherのみから分岐し,
|
---|
1834 | その時の状態は,タスクコンテキスト・CPUロック状態・割込み優先度マスク全
|
---|
1835 | 解除状態・ディスパッチ許可状態である.
|
---|
1836 |
|
---|
1837 | (*b)でcalltexを呼ぶ代わりに,calltexの処理内容(p_runtsk->enatexがtrue
|
---|
1838 | で,p_runtsk->texptnが0でなく,ipmflgがtrueの場合に,call_texrtnを呼ぶ)
|
---|
1839 | をここにインライン展開した方が効率がよい.ターゲット非依存部のcalltexを
|
---|
1840 | 使わない場合には,OMIT_CALLTEXをマクロ定義することで,ターゲット非依存
|
---|
1841 | 部からcalltexを取り除くことができる.
|
---|
1842 |
|
---|
1843 | 6.5.4 ディスパッチャの動作開始
|
---|
1844 |
|
---|
1845 | (6-5-4-1) void start_dispatch(void)
|
---|
1846 |
|
---|
1847 | ディスパッチャの動作開始(start_dispatch)は,カーネル起動時に,カーネ
|
---|
1848 | ルの初期化処理から呼び出される.start_dispatchは,リターンすることのな
|
---|
1849 | い関数である.
|
---|
1850 |
|
---|
1851 | start_dispatchは,非タスクコンテキストで,NMIを除くすべての割込みをマス
|
---|
1852 | クした状態(全割込みロック状態と同等の状態)で呼び出される.start_dispatch
|
---|
1853 | 内で,タスクコンテキストに切り換え,CPUロック状態・割込み優先度マスク全
|
---|
1854 | 解除状態にしなければならない.
|
---|
1855 |
|
---|
1856 | start_dispatchの処理内容は次の通り.
|
---|
1857 |
|
---|
1858 | ----------------------------------------
|
---|
1859 | void
|
---|
1860 | start_dispatch(void)
|
---|
1861 | {
|
---|
1862 | タスクコンテキストに切り換える
|
---|
1863 | CPUロック状態・割込み優先度マスク全解除状態にする
|
---|
1864 | dispatcher_0に分岐する
|
---|
1865 | }
|
---|
1866 | ----------------------------------------
|
---|
1867 |
|
---|
1868 | 6.5.5 現在のコンテキストを捨ててディスパッチ
|
---|
1869 |
|
---|
1870 | (6-5-5-1) void exit_and_dispatch(void)
|
---|
1871 |
|
---|
1872 | 現在のコンテキストを捨ててディスパッチ(exit_and_dispatch)は,自タスク
|
---|
1873 | を終了させるサービスコール処理関数から呼び出される.exit_and_dispatchは,
|
---|
1874 | リターンすることのない関数である.
|
---|
1875 |
|
---|
1876 | exit_and_dispatchは,タスクコンテキスト・CPUロック状態・割込み優先度マ
|
---|
1877 | スク全解除状態・ディスパッチ許可状態で呼び出される.
|
---|
1878 |
|
---|
1879 | exit_and_dispatchの処理内容は次の通り.
|
---|
1880 |
|
---|
1881 | ----------------------------------------
|
---|
1882 | void
|
---|
1883 | exit_and_dispatch(void)
|
---|
1884 | {
|
---|
1885 | dispatcherに分岐する
|
---|
1886 | }
|
---|
1887 | ----------------------------------------
|
---|
1888 |
|
---|
1889 | 6.5.6 タスクの起動処理
|
---|
1890 |
|
---|
1891 | (6-5-6-1) void activate_context(TCB *p_tcb)
|
---|
1892 |
|
---|
1893 | タスクの起動処理(activate_context)は,タスクを休止状態から実行できる
|
---|
1894 | 状態にする時に呼ばれ,指定されたタスクのTCB中のスタックポインタを初期化
|
---|
1895 | し,実行再開番地をタスク開始時処理(start_r)に設定する.この時点では,
|
---|
1896 | 指定されたタスクのスタック領域を使ってはならない.
|
---|
1897 |
|
---|
1898 | 指定されたタスクが最初に実行される時には,指定されたタスクを自タスクと
|
---|
1899 | して,実行再開番地として登録したstart_rに分岐してくる.start_rには,
|
---|
1900 | dispatcherのみから分岐し,その時の状態は,タスクコンテキスト・CPUロック
|
---|
1901 | 状態・割込み優先度マスク全解除状態・ディスパッチ許可状態である.
|
---|
1902 |
|
---|
1903 | start_rは,CPUロック状態を解除した後,タスクの起動番地を呼び出す.さら
|
---|
1904 | に,タスクの起動番地から戻ってきた場合には,ext_tskを呼び出す.
|
---|
1905 |
|
---|
1906 | activate_contextとstart_rの処理内容は次の通り.
|
---|
1907 |
|
---|
1908 | ----------------------------------------
|
---|
1909 | void
|
---|
1910 | activate_context(TCB *p_tcb)
|
---|
1911 | {
|
---|
1912 | 指定されたタスク(p_tcb)のTCB中のスタックポインタを初期化する
|
---|
1913 | start_rを,実行再開番地として自タスクのTCBに保存する … (*a)
|
---|
1914 | return;
|
---|
1915 |
|
---|
1916 | start_r:
|
---|
1917 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1918 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
1919 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1920 | CPUロック解除状態にする
|
---|
1921 | 自タスク(p_runtsk)の起動番地を,拡張情報をパラメータとして呼び出す
|
---|
1922 | ext_tskに分岐する ... (*c)
|
---|
1923 | }
|
---|
1924 | ----------------------------------------
|
---|
1925 |
|
---|
1926 | (*c)でext_tskを呼ぶ代わりに,自タスクの起動番地を呼び出す時の返り番地を
|
---|
1927 | ext_tskの番地としておく方法がある.
|
---|
1928 |
|
---|
1929 | (*a)において,実行再開番地をスタックに保存/復帰する方法をとる場合には,
|
---|
1930 | この時点でスタックを使ってはならないため,この処理を例外扱いしなければ
|
---|
1931 | ならない.
|
---|
1932 |
|
---|
1933 | 6.6 割込みハンドラ
|
---|
1934 |
|
---|
1935 | 6.6.1 割込みハンドラの出入口処理
|
---|
1936 |
|
---|
1937 | カーネル管理の割込みの出入口処理の方法は,プロセッサによって大きく異な
|
---|
1938 | るが,おおよその処理内容は次の通り.
|
---|
1939 |
|
---|
1940 | ----------------------------------------
|
---|
1941 | void
|
---|
1942 | <割込みの出入口処理>(void)
|
---|
1943 | {
|
---|
1944 | 割込み優先度マスクを,受け付けた割込み要求の割込優先度に設定する … (*i)
|
---|
1945 | 少なくともカーネル管理の割込みを禁止した状態にする … (*f)
|
---|
1946 | スクラッチレジスタをスタックに保存する
|
---|
1947 | if (タスクコンテキストで割込み発生) {
|
---|
1948 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1949 | ovrtimer_stop(); /* オーバランタイマの停止 */
|
---|
1950 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1951 | スタックを非タスクコンテキスト用のスタックに切り換え,
|
---|
1952 | 非タスクコンテキストに切り換える
|
---|
1953 | }
|
---|
1954 |
|
---|
1955 | この割込みよりも優先度の高い割込みのみを受け付けられるようにして,
|
---|
1956 | CPUロック解除状態にする
|
---|
1957 | #ifdef LOG_INH_ENTER
|
---|
1958 | log_inh_enter(割込みハンドラ番号);
|
---|
1959 | #endif /* LOG_INH_ENTER */
|
---|
1960 | 割込みハンドラを呼び出す
|
---|
1961 | #ifdef LOG_INH_LEAVE
|
---|
1962 | log_inh_leave(割込みハンドラ番号);
|
---|
1963 | #endif /* LOG_INH_LEAVE */
|
---|
1964 |
|
---|
1965 | ret_int:
|
---|
1966 | if (タスクコンテキストで割込み発生) {
|
---|
1967 | (少なくとも)カーネル管理の割込みを禁止した状態にする … (*d)
|
---|
1968 | スタックをタスク用のスタックに戻し,タスクコンテキストに切り換える
|
---|
1969 | … (*g)
|
---|
1970 | if (reqflg) {
|
---|
1971 | reqflg = false;
|
---|
1972 | CPUロック状態にする … (*e)
|
---|
1973 | 割込み優先度マスクを,全解除状態(TIPM_ENAALL)に設定する … (*h)
|
---|
1974 | if (dspflg && p_runtsk != p_schedtsk) {
|
---|
1975 | スクラッチレジスタを除くすべてのレジスタをスタックに保存する
|
---|
1976 | スタックポインタを自タスク(p_runtsk)のTCBに保存する
|
---|
1977 | ret_int_rを,実行再開番地として自タスクのTCBに保存する … (*a)
|
---|
1978 | dispatcherに分岐する
|
---|
1979 |
|
---|
1980 | ret_int_r:
|
---|
1981 | スクラッチレジスタを除くすべてのレジスタをスタックから復帰する
|
---|
1982 | }
|
---|
1983 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1984 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
1985 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1986 | calltex(); … (*b)
|
---|
1987 | }
|
---|
1988 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
1989 | else {
|
---|
1990 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
1991 | }
|
---|
1992 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
1993 | }
|
---|
1994 | 割込み処理からのリターン後に,CPUロック解除状態に戻るように準備する
|
---|
1995 | スクラッチレジスタをスタックから復帰する
|
---|
1996 | 割込み処理からのリターン
|
---|
1997 | }
|
---|
1998 | ----------------------------------------
|
---|
1999 |
|
---|
2000 | (*i)の割込み優先度マスクを設定する処理は,プロセッサがハードウェアで実
|
---|
2001 | 現している場合も多い.
|
---|
2002 |
|
---|
2003 | 割込みの受付けにより,スタックポインタが切り換わらず,すべての割込みが
|
---|
2004 | 禁止されないプロセッサでは,(*f)において,少なくともカーネル管理の割込
|
---|
2005 | みを禁止する.この理由は次の通りである.
|
---|
2006 |
|
---|
2007 | 割込みの入口処理において,スタックを非タスクコンテキスト用のスタックに
|
---|
2008 | 切り換える前に多重割込みが発生すると,タスクのスタック領域が使用される.
|
---|
2009 | 上記のようなプロセッサでは,スタックの切換え前に,最大で割込み優先度の
|
---|
2010 | 段数分の多重割込みが発生することを防ぐことはできず,各タスクのスタック
|
---|
2011 | 領域を確保する際に,その分を見込んで確保しなければならない.各タスクの
|
---|
2012 | スタック領域をなるべく小さくするためには,スタックをなるべく使用しない
|
---|
2013 | 内に,多重割込みを禁止するのが望ましい.そのため,スクラッチレジスタを
|
---|
2014 | スタックに保存する前に,割込みを禁止する.ただし,割込みの禁止処理に必
|
---|
2015 | 要な最低限のレジスタについては,割込みの禁止に先立ってスタックに保存す
|
---|
2016 | る必要がある.
|
---|
2017 |
|
---|
2018 | 同様のことは,カーネル管理外の割込みにも当てはまる.すなわち,カーネル
|
---|
2019 | 管理外の割込みについても,スタックをなるべく使用しない内に禁止するのが
|
---|
2020 | 望ましい.このことから,カーネル管理外の割込みを使用する場合には,(*f)
|
---|
2021 | において,すべての割込みを禁止した状態にするのが望ましいことになる.一
|
---|
2022 | 方で,カーネル管理外の割込みの禁止時間が長くなると,カーネル管理外の割
|
---|
2023 | 込みの応答性が低下するため,ユーザに注意を促す必要がある.また,カーネ
|
---|
2024 | ル管理外の割込み処理においても,非タスクコンテキスト用のスタック(また
|
---|
2025 | は,カーネル管理外の割込み処理用のスタック)に切り換えることが望ましい
|
---|
2026 | が,これはカーネルの管轄外である.
|
---|
2027 |
|
---|
2028 | (*d)においては,カーネル管理の割込みを禁止するだけで,CPUロック状態にす
|
---|
2029 | る必要はない.例えば,CPUロック状態であることを示す変数を用意している場
|
---|
2030 | 合には,(*d)の時点ではその変数をCPUロック状態を示す値に変更する必要はな
|
---|
2031 | く,(*e)において変更すればよい.
|
---|
2032 |
|
---|
2033 | (*g)においてタスクコンテキストに切り換える処理は,割込み処理からのリター
|
---|
2034 | ンによりスタックとコンテキストが元に戻るプロセッサでは,reqflgがtrueの
|
---|
2035 | 場合にのみ行えばよい.reqflgがfalseの時は,非タスクコンテキストのまま処
|
---|
2036 | 理を続け,割込み処理からのリターンでタスクコンテキストに戻ることになる.
|
---|
2037 |
|
---|
2038 | (*e)においてCPUロック状態にするのは,dispatcherに分岐する際と,(*b)にお
|
---|
2039 | いてcalltex(または,それを展開した場合にはcall_texrtn)を呼び出す際に,
|
---|
2040 | CPUロック状態になっている必要があるためである.
|
---|
2041 |
|
---|
2042 | (*h)の処理が実行されるのは,割込み処理前に割込み優先度マスクが全解除状
|
---|
2043 | 態(TIPM_ENAALL)であった場合に限られ,ここで割込み優先度マスクを全解除
|
---|
2044 | 状態に設定するのは,割込み処理前の値に戻すのと等価である.ここでこの処
|
---|
2045 | 理を行うのは,dispatcherに分岐する際と,(*b)においてcalltex(または,そ
|
---|
2046 | れを展開した場合にはcall_texrtn)を呼び出す際には,割込み優先度マスク全
|
---|
2047 | 解除状態になっている必要があるためである.
|
---|
2048 |
|
---|
2049 | タスクの実行中に割込みが発生し,上の処理中でdispatcherに分岐した場合,
|
---|
2050 | そのタスクが次に実行される時には,実行再開番地として登録したret_int_rに
|
---|
2051 | 戻ってくる.ret_int_rには,dispatcherのみから分岐し,その時の状態は,タ
|
---|
2052 | スクコンテキスト・CPUロック状態・割込み優先度マスク全解除状態・ディスパッ
|
---|
2053 | チ許可状態である.
|
---|
2054 |
|
---|
2055 | 割込みの出入口処理をアセンブリ言語で記述する場合には,トレースログ取得
|
---|
2056 | 処理は,「6.2 トレースログ機能への対応」の節で記述した方法でコーディン
|
---|
2057 | グすること.
|
---|
2058 |
|
---|
2059 | 6.6.2 割込みハンドラ毎の出入口処理の生成
|
---|
2060 |
|
---|
2061 | 割込みベクトルをハードウェアで実現している場合など,割込みハンドラ毎に
|
---|
2062 | 出入口処理を用意した方が効率が良いターゲットのために,割込みハンドラ毎
|
---|
2063 | に出入口処理を生成する機構を用意している.
|
---|
2064 |
|
---|
2065 | 以下のマクロは,標準の割込み管理機能の初期化処理を用いた場合のみ,ター
|
---|
2066 | ゲット非依存部で使われる.割込み管理機能の初期化処理をターゲット依存部
|
---|
2067 | で用意し,その中でこれらのマクロを使わない場合には,これらのマクロを用
|
---|
2068 | 意する必要はない.
|
---|
2069 |
|
---|
2070 | (6-6-2-1) INT_ENTRY(inhno, inthdr)
|
---|
2071 |
|
---|
2072 | 割込みハンドラ番号がinhno,割込みハンドラの関数名がinthdrである割込みハ
|
---|
2073 | ンドラの出入口処理のラベルを作るマクロ.INTHDR_ENTRYを用いて割込みハン
|
---|
2074 | ドラ毎に出入口処理を生成する場合には,次のように定義する.
|
---|
2075 |
|
---|
2076 | #define INT_ENTRY(inhno, inthdr) _kernel_##inthdr##_##inhno
|
---|
2077 |
|
---|
2078 | 割込みハンドラ毎に出入口処理を作る必要がない場合には,次のように定義し
|
---|
2079 | て,割込みハンドラの関数名をそのまま返す.
|
---|
2080 |
|
---|
2081 | #define INT_ENTRY(inhno, inthdr) inthdr
|
---|
2082 |
|
---|
2083 | (6-6-2-2) INTHDR_ENTRY(inhno, inhno_num, inthdr)
|
---|
2084 |
|
---|
2085 | 割込みハンドラ番号がinhno,割込みハンドラの関数名がinthdrである割込みハ
|
---|
2086 | ンドラの出入口処理を生成するマクロ.inhno_numには,アセンブリ言語記述用
|
---|
2087 | に,割込みハンドラ番号が数値で渡される.割込みハンドラ毎に出入口処理を
|
---|
2088 | 作る必要がない場合には,空に定義する.
|
---|
2089 |
|
---|
2090 | 6.6.3 割込みハンドラの設定
|
---|
2091 |
|
---|
2092 | (6-6-3-1) bool_t VALID_INHNO_DEFINH(INHNO inhno)(オプション)
|
---|
2093 |
|
---|
2094 | inhnoが,DEF_INHに対する割込みハンドラ番号として有効な値である場合に
|
---|
2095 | true,そうでない場合にfalseを返すマクロ.
|
---|
2096 |
|
---|
2097 | ASPカーネルのターゲット非依存部では,このマクロは使われていないため,ター
|
---|
2098 | ゲット依存部で使わないなら,用意する必要がない.
|
---|
2099 |
|
---|
2100 | (6-6-3-2) void x_define_inh(INHNO inhno, FP int_entry)
|
---|
2101 |
|
---|
2102 | inhnoで指定された割込みハンドラの出入口処理の番地をint_entryに設定する.
|
---|
2103 |
|
---|
2104 | この関数は,標準の割込み管理機能の初期化処理を用いた場合のみ,ターゲッ
|
---|
2105 | ト非依存部から呼び出される.割込み管理機能の初期化処理をターゲット依存
|
---|
2106 | 部で用意し,その中でこの関数を呼び出さない場合には,この関数を用意する
|
---|
2107 | 必要はない.
|
---|
2108 |
|
---|
2109 | この関数は,ターゲット非依存部のカーネル初期化処理から呼び出されるため,
|
---|
2110 | カーネルの初期化処理(NMIを除くすべての割込みがマスクされている)から呼
|
---|
2111 | び出せるように実装すればよい.
|
---|
2112 |
|
---|
2113 | 指定された割込みハンドラ番号がDEF_INHに対するものとして有効な値でない場
|
---|
2114 | 合の動作は保証する必要がない(assertでエラーとするのが望ましい).これ
|
---|
2115 | は,コンフィギュレータが,パス2のテンプレートファイルのターゲット依存部
|
---|
2116 | で定義するINHNO_DEFINH_VALIDを用いてエラーを検出するためである.
|
---|
2117 |
|
---|
2118 | 6.6.4 割込み要求ラインの属性の設定
|
---|
2119 |
|
---|
2120 | (6-6-4-1) bool_t VALID_INTNO_CFGINT(INTNO intno)(オプション)
|
---|
2121 |
|
---|
2122 | intnoが,割込み番号として有効な値である場合にtrue,そうでない場合に
|
---|
2123 | falseを返すマクロ.CFG_INTには,すべての割込み番号を指定することができ
|
---|
2124 | るため,このマクロは,intnoが有効な値の場合にはtrue,intnoが無効の値の
|
---|
2125 | 場合にはfalseを返すようにする.
|
---|
2126 |
|
---|
2127 | ASPカーネルのターゲット非依存部では,このマクロは使われていないため,ター
|
---|
2128 | ゲット依存部で使わないなら,用意する必要がない.
|
---|
2129 |
|
---|
2130 | (6-6-4-2) void x_config_int(INTNO intno, ATR intatr, PRI intpri)
|
---|
2131 |
|
---|
2132 | intnoで指定された割込み要求ラインの割込み属性を,intatrで指定された通り
|
---|
2133 | に設定する.また,割込み優先度を,intpriで指定された値に設定する.
|
---|
2134 |
|
---|
2135 | この関数は,標準の割込み管理機能の初期化処理を用いた場合のみ,ターゲッ
|
---|
2136 | ト非依存部から呼び出される.割込み管理機能の初期化処理をターゲット依存
|
---|
2137 | 部で用意し,その中でこの関数を呼び出さない場合には,この関数を用意する
|
---|
2138 | 必要はない.
|
---|
2139 |
|
---|
2140 | この関数は,ターゲット非依存部のカーネル初期化処理から呼び出されるため,
|
---|
2141 | カーネルの初期化処理(NMIを除くすべての割込みがマスクされている)から呼
|
---|
2142 | び出せるように実装すればよい.
|
---|
2143 |
|
---|
2144 | intatrとして設定できる割込み属性は次の通り.
|
---|
2145 |
|
---|
2146 | TA_ENAINT 0x01 割込み要求禁止フラグをクリア
|
---|
2147 | TA_EDGE 0x02 エッジトリガ
|
---|
2148 |
|
---|
2149 | この他に,ターゲット定義で割込み属性を追加してもよい.ターゲット定義で
|
---|
2150 | 追加するために,以下の属性名が予約されている.
|
---|
2151 |
|
---|
2152 | TA_POSEDGE ポジティブエッジトリガ
|
---|
2153 | TA_NEGEDGE ネガティブエッジトリガ
|
---|
2154 | TA_BOTHEDGE 両エッジトリガ
|
---|
2155 | TA_LOWLEVEL ローレベルトリガ
|
---|
2156 | TA_HIGHLEVEL ハイレベルトリガ
|
---|
2157 |
|
---|
2158 | これらの属性名をターゲット定義で追加する場合には,その属性値を決定し,
|
---|
2159 | 定義をtarget_kernel.h(または,そこからインクルードされるファイル)に含
|
---|
2160 | める.また,コンフィギュレータテンプレートファイルから参照できるように,
|
---|
2161 | target_def.csv(または,同等の役割を持つファイル)に含め,コンフィギュ
|
---|
2162 | レータテンプレートファイルのターゲット非依存部でエラーとならないように,
|
---|
2163 | target.tf(または,そこからインクルードされるファイル)でTARGET_INTATR
|
---|
2164 | に設定する.
|
---|
2165 |
|
---|
2166 | 指定された割込み番号が有効な値でない場合や,その割込み要求ラインに対し
|
---|
2167 | て設定できない属性を指定した場合,設定できない割込み優先度を指定した場
|
---|
2168 | 合の動作は保証する必要がない(assertでエラーとするのが望ましい).この
|
---|
2169 | ようなケースは,コンフィギュレータでエラーを検出すべきである.コンフィ
|
---|
2170 | ギュレータテンプレートファイルのターゲット非依存部は,パス2のテンプレー
|
---|
2171 | トファイルのターゲット依存部で定義するINTNO_CFGINT_VALID,
|
---|
2172 | TARGET_INTATR,INTPRI_CFGINT_VALIDを用いてエラーを検出するが,標準の割
|
---|
2173 | 込み属性(TA_ENAINT,TA_EDGE)が設定できない場合や,設定できない属性や
|
---|
2174 | 割込み優先度が割込み要求ラインによって異なる場合には,コンフィギュレー
|
---|
2175 | タテンプレートファイルのターゲット依存部で検出しなければならない.
|
---|
2176 |
|
---|
2177 | 6.6.5 割込み管理機能の初期化処理の変更
|
---|
2178 |
|
---|
2179 | (6-6-5-1) OMIT_INITIALIZE_INTERRUPT(オプション)
|
---|
2180 |
|
---|
2181 | 割込み管理機能の初期化処理をターゲット依存部で用意し,ターゲット非依存
|
---|
2182 | 部に含まれる標準の割込み管理機能の初期化処理を用いない場合には,このシ
|
---|
2183 | ンボルをマクロ定義する.
|
---|
2184 |
|
---|
2185 | このシンボルをマクロ定義すると,INHINIB,INTINIB,initialize_interrupt
|
---|
2186 | の定義が,カーネルのターゲット非依存部から取り除かれる.また,
|
---|
2187 | TNUM_INHNO,tnum_inhno,inhinib_table,TNUM_INTNO,tnum_intno,
|
---|
2188 | intinib_tableの定義と,割込みハンドラ毎の出入口処理を生成するための記述
|
---|
2189 | (INTHDR_ENTRYマクロのリスト)が,コンフィギュレータのパス2のテンプレー
|
---|
2190 | トファイルのターゲット非依存部によってkernel_cfg.cに生成されなくなる.
|
---|
2191 | ただし,コンフィギュレータのパス2のテンプレートファイルのターゲット依存
|
---|
2192 | 部で,USE_INHINIB_TABLEとUSE_INTINIB_TABLEを設定することで,その一部
|
---|
2193 | 分をkernel_cfg.cに生成することが可能である.
|
---|
2194 |
|
---|
2195 | (6-6-5-2) void initialize_interrupt(void)(オプション)
|
---|
2196 |
|
---|
2197 | OMIT_INITIALIZE_INTERRUPTをマクロ定義した場合には,この関数をターゲット
|
---|
2198 | 依存部で用意する.OMIT_INITIALIZE_INTERRUPTをマクロ定義することにより取
|
---|
2199 | り除かれるその他のデータ型,変数,マクロは,この関数で使用する場合にの
|
---|
2200 | み用意すればよい.
|
---|
2201 |
|
---|
2202 | 6.6.6 デフォルトの割込みハンドラ
|
---|
2203 |
|
---|
2204 | (6-6-6-1) default_int_handler(void)(オプション)
|
---|
2205 |
|
---|
2206 | コンフィギュレータにより割込みハンドラのテーブルを生成する場合などには,
|
---|
2207 | 割込みハンドラを登録しなかった割込みハンドラ番号に対して,デフォルトの
|
---|
2208 | 割込みハンドラとして,default_int_handlerを登録する.
|
---|
2209 |
|
---|
2210 | default_int_handlerは,標準のものをターゲット依存部で用意するが,ユーザ
|
---|
2211 | が用意したもので置き換えられるように,OMIT_DEFAULT_INT_HANDLERをマクロ
|
---|
2212 | 定義した場合には,ターゲット依存部で定義しないようにする.なお,ユーザ
|
---|
2213 | が用意する場合の名称は,_kernel_default_int_handlerとなる.
|
---|
2214 |
|
---|
2215 | 6.6.7 カーネル管理外の割込み
|
---|
2216 |
|
---|
2217 | カーネル管理外の割込みハンドラは,カーネル内の割込み出入口処理を経由せ
|
---|
2218 | ずに実行するのが基本である.
|
---|
2219 |
|
---|
2220 | ただし,すべての割込みで同じアドレスに分岐するプロセッサでは,カーネル
|
---|
2221 | 内の割込み出入口処理を全く経由せずにカーネル管理外の割込みハンドラを実
|
---|
2222 | 行することができないため,割込み出入口処理のなるべく早いタイミングで,
|
---|
2223 | カーネル管理外の割込みであるかを判別し,処理内容を分ける必要がある.具
|
---|
2224 | 体的には,カーネル管理外の割込みの出入口処理では,オーバランハンドラの
|
---|
2225 | 停止と動作開始を行ってはならない.また,reqflgをチェックし,タスク切換
|
---|
2226 | えやタスク例外処理ルーチンの呼出しを行う必要がない.さらに,NMIの出入口
|
---|
2227 | 処理では,トレースログ取得処理(log_inh_enterおよびlog_inh_leave)を呼
|
---|
2228 | び出してはならない.
|
---|
2229 |
|
---|
2230 | カーネル管理外の割込みハンドラを実行する際に,カーネル内の割込み出入口
|
---|
2231 | 処理の一部分を経由する場合には,CPU例外が起こる可能性を極力減らすととも
|
---|
2232 | に,CPU例外を起こす可能性がある場合には,その可能性をターゲット依存部の
|
---|
2233 | ユーザーズマニュアルに記載しなければならない.
|
---|
2234 |
|
---|
2235 | 次に,カーネル管理外の割込みの設定方法に関して,「TOPPERS新世代カーネル
|
---|
2236 | 統合仕様書」の「2.7.8 カーネル管理外の割込みの設定方法」の節の3つの方法
|
---|
2237 | のいずれを採用するかを決定する.
|
---|
2238 |
|
---|
2239 | (a-1)または(a-2)を採用し,カーネル管理外とした割込みに対して,カーネル
|
---|
2240 | のAPIによる割込みハンドラの登録と割込み要求ラインの属性の設定をサポート
|
---|
2241 | しない場合には,それに代わる方法をターゲット依存部のユーザーズマニュア
|
---|
2242 | ルに記述する.
|
---|
2243 |
|
---|
2244 | (a-1)または(a-2)を採用してカーネルのAPIによる割込みハンドラの登録や割込
|
---|
2245 | み要求ラインの属性の設定をサポートする場合や,(b)を採用した場合には,ター
|
---|
2246 | ゲット依存部においてそれを実現する必要がある.
|
---|
2247 |
|
---|
2248 | カーネル管理外の割込みに対して,DEF_INHによる割込みハンドラの登録をサポー
|
---|
2249 | トするには,次の設定が必要になる.
|
---|
2250 |
|
---|
2251 | ・TARGET_INHATRに,TA_NONKERNELを設定する.
|
---|
2252 |
|
---|
2253 | ・(a-1)または(a-2)を採用した場合には,INHNO_DEFINH_VALIDに,カーネル管
|
---|
2254 | 理外とした割込みに対応する割込みハンドラ番号を含める.また,
|
---|
2255 | VALID_INHNO_DEFINHを,カーネル管理外とした割込みハンドラ番号を有効な
|
---|
2256 | 値と判定するようにする.
|
---|
2257 |
|
---|
2258 | ・(a-1)または(a-2)を採用した場合には,INHNO_FIX_KERNELにカーネル管理と
|
---|
2259 | した割込みハンドラ番号のリストを,INHNO_FIX_NONKERNELにカーネル管理外
|
---|
2260 | とした割込みハンドラ番号のリスト設定する.
|
---|
2261 |
|
---|
2262 | ・DEF_INHがカーネル管理外の割込みに対応できるようにする.標準の割込み管
|
---|
2263 | 理機能の初期化処理を用いる場合には,x_define_inhをカーネル管理外の割
|
---|
2264 | 込みに対応させる.
|
---|
2265 |
|
---|
2266 | ・必要な場合には,TA_NONKERNEL属性が設定された割込みハンドラをカーネル
|
---|
2267 | 管理外と扱うように,カーネル内の割込み出入口処理を修正する.標準の割
|
---|
2268 | 込み管理機能の初期化処理を用いる場合,カーネル管理外の割込みに対して
|
---|
2269 | は,カーネル内の割込み出入口処理を生成せず,アプリケーションが登録し
|
---|
2270 | た割込みハンドラを直接呼び出すように,ターゲット非依存部により設定さ
|
---|
2271 | れるため,ターゲット依存部では対応する必要がない.
|
---|
2272 |
|
---|
2273 | カーネル管理外の割込みに対して,CFG_INTによる割込み要求ラインの属性の設
|
---|
2274 | 定をサポートするには,次の設定が必要になる.
|
---|
2275 |
|
---|
2276 | ・(a-1)または(a-2)を採用した場合には,INTNO_CFGINT_VALIDに,カーネル管
|
---|
2277 | 理外とした割込みに対応する割込み番号を含める.また,VALID_INTNO_CFGINT
|
---|
2278 | を,カーネル管理外とした割込み番号を有効な値と判定するようにする.
|
---|
2279 |
|
---|
2280 | ・(a-1)または(a-2)を採用した場合には,INTNO_FIX_KERNELにカーネル管理と
|
---|
2281 | した割込み番号のリストを,INTNO_FIX_NONKERNELにカーネル管理外とした割
|
---|
2282 | 込み番号のリスト設定する.
|
---|
2283 |
|
---|
2284 | ・INTPRI_CFGINT_VALIDに,カーネル管理外の割込みとなる優先度を含める.
|
---|
2285 |
|
---|
2286 | ・CFG_INTがカーネル管理外の割込みに対応できるようにする.標準の割込み管
|
---|
2287 | 理機能の初期化処理を用いる場合には,x_config_intをカーネル管理外の割
|
---|
2288 | 込みに対応させる.
|
---|
2289 |
|
---|
2290 | chg_ipmにより,(NMI以外の)カーネル管理外の割込みをマスクできるように
|
---|
2291 | する場合には,次の設定が必要になる.
|
---|
2292 |
|
---|
2293 | ・VALID_INTPRI_CHGIPMを,カーネル管理外の割込みとなる優先度を有効な値と
|
---|
2294 | 判定するようにする.
|
---|
2295 |
|
---|
2296 | ・t_set_ipmを,カーネル管理外の割込みとなる優先度を扱えるようにする.
|
---|
2297 |
|
---|
2298 | 6.6.8 割込みサービスルーチンの生成
|
---|
2299 |
|
---|
2300 | (6-6-8-1) bool_t VALID_INTNO_CREINT(INTNO intno)
|
---|
2301 |
|
---|
2302 | intnoが,acre_isrに対する割込み番号として有効な値である場合にtrue,そう
|
---|
2303 | でない場合にfalseを返すマクロ.動的生成機能拡張パッケージを使用しない場
|
---|
2304 | 合には,定義する必要がない.
|
---|
2305 |
|
---|
2306 | 6.7 CPU例外ハンドラとCPU例外発生時のシステム状態の参照
|
---|
2307 |
|
---|
2308 | 6.7.1 CPU例外ハンドラの出入口処理
|
---|
2309 |
|
---|
2310 | CPU例外の出入口処理の方法はプロセッサによって大きく異なるが,おおよその
|
---|
2311 | 処理内容は次の通り.
|
---|
2312 |
|
---|
2313 | ----------------------------------------
|
---|
2314 | void
|
---|
2315 | <CPU例外の出入口処理>(void)
|
---|
2316 | {
|
---|
2317 | スクラッチレジスタをスタックに保存する
|
---|
2318 | if (カーネル管理外のCPU例外) {
|
---|
2319 | if (タスクコンテキストでCPU例外発生) {
|
---|
2320 | スタックを非タスクコンテキスト用のスタックに切り換え,
|
---|
2321 | 非タスクコンテキストに切り換える
|
---|
2322 | }
|
---|
2323 | システム状態(コンテキストは除く)を,CPU例外発生時の状態にする
|
---|
2324 | CPU例外ハンドラを,CPU例外の情報を記憶している領域の先頭番地を
|
---|
2325 | パラメータ(p_excinf)として呼び出す
|
---|
2326 | if (タスクコンテキストでCPU例外発生) {
|
---|
2327 | スタックをタスク用のスタックに戻し,タスクコンテキストに切り換える
|
---|
2328 | }
|
---|
2329 | CPU例外処理からのリターン後に,CPU例外発生時のシステム状態に
|
---|
2330 | 戻るように準備する
|
---|
2331 | }
|
---|
2332 | else {
|
---|
2333 | if (タスクコンテキストでCPU例外発生) {
|
---|
2334 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
2335 | (少なくとも)カーネル管理の割込みを禁止した状態にする
|
---|
2336 | ovrtimer_stop(); /* オーバランタイマの停止 */
|
---|
2337 | (必要なら)元の状態に戻す
|
---|
2338 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
2339 | スタックを非タスクコンテキスト用のスタックに切り換え,
|
---|
2340 | 非タスクコンテキストに切り換える
|
---|
2341 | }
|
---|
2342 | システム状態(コンテキストは除く)を,CPU例外発生時の状態にする
|
---|
2343 | (CPU例外発生時の割込み優先度マスクよりも優先度の高い割込み
|
---|
2344 | のみを受け付けられるようにして,CPUロック解除状態にする)
|
---|
2345 |
|
---|
2346 | #ifdef LOG_EXC_ENTER
|
---|
2347 | log_exc_enter(CPU例外ハンドラ番号);
|
---|
2348 | #endif /* LOG_EXC_ENTER */
|
---|
2349 | CPU例外ハンドラを,CPU例外の情報を記憶している領域の先頭番地を
|
---|
2350 | パラメータ(p_excinf)として呼び出す
|
---|
2351 | #ifdef LOG_EXC_LEAVE
|
---|
2352 | log_exc_leave(CPU例外ハンドラ番号);
|
---|
2353 | #endif /* LOG_EXC_LEAVE */
|
---|
2354 |
|
---|
2355 | ret_exc:
|
---|
2356 | if (タスクコンテキストでCPU例外発生) {
|
---|
2357 | (少なくとも)カーネル管理の割込みを禁止した状態にする … (*d)
|
---|
2358 | スタックをタスク用のスタックに戻し,タスクコンテキストに切り換える
|
---|
2359 | … (*g)
|
---|
2360 | if (reqflg) {
|
---|
2361 | reqflg = false;
|
---|
2362 | CPUロック状態にする … (*e)
|
---|
2363 | if (dspflg && p_runtsk != p_schedtsk) {
|
---|
2364 | スクラッチレジスタを除くすべてのレジスタをスタックに保存する
|
---|
2365 | スタックポインタを自タスク(p_runtsk)のTCBに保存する
|
---|
2366 | ret_exc_rを,実行再開番地として自タスクのTCBに保存する
|
---|
2367 | … (*a)
|
---|
2368 | dispatcherに分岐する
|
---|
2369 |
|
---|
2370 | ret_exc_r:
|
---|
2371 | スクラッチレジスタを除くすべてのレジスタを
|
---|
2372 | スタックから復帰する
|
---|
2373 | }
|
---|
2374 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
2375 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
2376 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
2377 | calltex(); … (*b)
|
---|
2378 | }
|
---|
2379 | #ifdef TOPPERS_SUPPORT_OVRHDR
|
---|
2380 | else {
|
---|
2381 | ovrtimer_start(); /* オーバランタイマの動作開始 */
|
---|
2382 | }
|
---|
2383 | #endif /* TOPPERS_SUPPORT_OVRHDR */
|
---|
2384 | }
|
---|
2385 | CPU例外処理からのリターン後に,CPUロック解除状態に戻るように準備する
|
---|
2386 | }
|
---|
2387 | スクラッチレジスタをスタックから復帰する
|
---|
2388 | CPU例外処理からのリターン
|
---|
2389 | }
|
---|
2390 | ----------------------------------------
|
---|
2391 |
|
---|
2392 | CPU例外ハンドラは,非コンテキストに切り換えることを除いては,CPU例外発
|
---|
2393 | 生時と同じシステム状態で呼び出さなければならない.例えば,CPU例外がCPU
|
---|
2394 | ロック状態で発生した場合にはCPUロック状態,CPUロック解除状態で発生した
|
---|
2395 | 場合にはCPUロック解除状態で,CPU例外ハンドラを呼び出さなければならない.
|
---|
2396 | CPUロック状態で発生したCPU例外は,カーネル管理外のCPU例外となるため,カー
|
---|
2397 | ネル管理のCPU例外ハンドラについては,CPUロック解除状態で呼び出すことに
|
---|
2398 | なる.
|
---|
2399 |
|
---|
2400 | ターゲットによっては,カーネル管理外のCPU例外を正確に判定するのが難しい
|
---|
2401 | 場合がある.このような場合には,割込み優先度マスクが全解除でない状態で
|
---|
2402 | 発生したCPU例外を,カーネル管理外のCPU例外と扱っても支障がない.これは,
|
---|
2403 | 割込み優先度マスクが全解除でない場合には,xsns_dpn,xsns_xpnともtrueを
|
---|
2404 | 返すため,アプリケーションからはカーネル管理外のCPU例外と区別できないた
|
---|
2405 | めである.
|
---|
2406 |
|
---|
2407 | 具体的には,全割込みロック(またはCPUロック)を小さいオーバヘッドで実現
|
---|
2408 | しようとすると,CPU例外ハンドラの中で,全割込みロック状態(またはCPUロッ
|
---|
2409 | ク状態)と割込み優先度マスクを高いレベルに設定した状態を区別できない場
|
---|
2410 | 合がある.また,カーネル管理外の割込み処理中やカーネル実行中であること
|
---|
2411 | を正確に判断することも難しい場合がある.
|
---|
2412 |
|
---|
2413 | 上のコードでは,カーネル管理外のCPU例外に対して,トレースログ取得処理
|
---|
2414 | (log_exc_enterおよびlog_exc_leave)を呼び出していないが,全割込みロッ
|
---|
2415 | ク状態かNMIの処理中にCPU例外が発生した場合を除外すれば,呼び出してもか
|
---|
2416 | まわない.全割込みロック状態かNMIの処理中に発生したCPU例外の場合には,
|
---|
2417 | トレースログ取得処理を呼び出してはならない.
|
---|
2418 |
|
---|
2419 | CPU例外ハンドラを実行する際に経由する部分では,CPU例外が起こる可能性を
|
---|
2420 | 極力減らすとともに,CPU例外を起こす可能性がある場合(例えば,スクラッチ
|
---|
2421 | レジスタをスタックに保存する時に,バスエラーなどのCPU例外が発生する可能
|
---|
2422 | 性が考えられる)には,その可能性をターゲット依存部のユーザーズマニュア
|
---|
2423 | ルに記載しなければならない.
|
---|
2424 |
|
---|
2425 | ret_exc以降の処理は,割込みの出入口処理のret_int以降の処理とほぼ同じで
|
---|
2426 | あるため,ターゲットによっては,共通のルーチンを用いることができる可能
|
---|
2427 | 性がある.
|
---|
2428 |
|
---|
2429 | CPU例外の出入口処理をアセンブリ言語で記述する場合には,トレースログ取得
|
---|
2430 | 処理は,「6.2 トレースログ機能への対応」の節で記述した方法でコーディン
|
---|
2431 | グすること.
|
---|
2432 |
|
---|
2433 | 6.7.2 CPU例外ハンドラの出入口処理の生成
|
---|
2434 |
|
---|
2435 | CPU例外ベクトルをハードウェアで実現している場合など,CPU例外ハンドラ毎
|
---|
2436 | に出入口処理を用意した方が効率が良いターゲットのために,CPU例外ハンドラ
|
---|
2437 | 毎に出入口処理を生成する機構を用意している.
|
---|
2438 |
|
---|
2439 | 以下のマクロは,標準のCPU例外管理機能の初期化処理を用いた場合のみ,ター
|
---|
2440 | ゲット非依存部で使われる.CPU例外管理機能の初期化処理をターゲット依存部
|
---|
2441 | で用意し,その中でこれらのマクロを使わない場合には,これらのマクロを用
|
---|
2442 | 意する必要はない.
|
---|
2443 |
|
---|
2444 | (6-7-2-1) EXC_ENTRY(excno, exchdr)
|
---|
2445 |
|
---|
2446 | CPU例外ハンドラ番号がexcno,CPU例外ハンドラの関数名がexchdrであるCPU例
|
---|
2447 | 外ハンドラの出入口処理のラベルを作るマクロ.EXCHDR_ENTRYを用いてCPU例外
|
---|
2448 | ハンドラ毎に出入口処理を生成する場合には,次のように定義する.
|
---|
2449 |
|
---|
2450 | #define EXC_ENTRY(excno, exchdr) _kernel_##exchdr##_##excno
|
---|
2451 |
|
---|
2452 | CPU例外ハンドラ毎に出入口処理を作る必要がない場合には,次のように定義し
|
---|
2453 | て,CPU例外ハンドラの関数名をそのまま返す.
|
---|
2454 |
|
---|
2455 | #define EXC_ENTRY(excno, exchdr) exchdr
|
---|
2456 |
|
---|
2457 | (6-7-2-2) EXCHDR_ENTRY(excno, excno_num, exchdr)
|
---|
2458 |
|
---|
2459 | CPU例外ハンドラ番号がexcno,CPU例外ハンドラの関数名がexchdrであるCPU例
|
---|
2460 | 外ハンドラの出入口処理を生成するマクロ.excno_numには,アセンブリ言語記
|
---|
2461 | 述用に,CPU例外ハンドラ番号が数値で渡される.CPU例外ハンドラ毎に出入口
|
---|
2462 | 処理を作る必要がない場合には,空に定義する.
|
---|
2463 |
|
---|
2464 | 6.7.3 CPU例外ハンドラの設定
|
---|
2465 |
|
---|
2466 | (6-7-3-1) bool_t VALID_EXCNO_DEFEXC(EXCNO excno)(オプション)
|
---|
2467 |
|
---|
2468 | excnoが,DEF_EXCに対するCPU例外ハンドラ番号として有効な値である場合に
|
---|
2469 | true,そうでない場合にfalseを返すマクロ.
|
---|
2470 |
|
---|
2471 | ASPカーネルのターゲット非依存部では,このマクロは使われていないため,ター
|
---|
2472 | ゲット依存部で使わないなら,用意する必要がない.
|
---|
2473 |
|
---|
2474 | (6-7-3-2) void x_define_exc(EXCNO excno, FP exc_entry)
|
---|
2475 |
|
---|
2476 | excnoで指定されたCPU例外ハンドラの出入口処理の番地をexc_entryに設定する.
|
---|
2477 |
|
---|
2478 | この関数は,標準のCPU例外管理機能の初期化処理を用いた場合のみ,ターゲッ
|
---|
2479 | ト非依存部から呼び出される.CPU例外管理機能の初期化処理をターゲット依存
|
---|
2480 | 部で用意し,その中でこの関数を呼び出さない場合には,この関数を用意する
|
---|
2481 | 必要はない.
|
---|
2482 |
|
---|
2483 | この関数は,ターゲット非依存部のカーネル初期化処理から呼び出されるため,
|
---|
2484 | カーネルの初期化処理(NMIを除くすべての割込みがマスクされている)から呼
|
---|
2485 | び出せるように実装すればよい.
|
---|
2486 |
|
---|
2487 | 指定されたCPU例外ハンドラ番号がDEF_EXCに対するものとして有効な値でない
|
---|
2488 | 場合の動作は保証する必要がない(assertでエラーとするのが望ましい).こ
|
---|
2489 | れは,コンフィギュレータが,パス2のテンプレートファイルのターゲット依存
|
---|
2490 | 部で定義するEXCNO_DEFEXC_VALIDを用いてエラーを検出するためである.
|
---|
2491 |
|
---|
2492 | 6.7.4 CPU例外管理機能の初期化処理の変更
|
---|
2493 |
|
---|
2494 | (6-7-4-1) OMIT_INITIALIZE_EXCEPTION(オプション)
|
---|
2495 |
|
---|
2496 | CPU例外管理機能の初期化処理をターゲット依存部で用意し,ターゲット非依存
|
---|
2497 | 部に含まれる標準の割込み管理機能の初期化処理を用いない場合には,このシ
|
---|
2498 | ンボルをマクロ定義する.
|
---|
2499 |
|
---|
2500 | このシンボルをマクロ定義すると,EXCINIBとinitialize_exceptionの定義が,
|
---|
2501 | カーネルのターゲット非依存部から取り除かれる.また,TNUM_EXCNO,
|
---|
2502 | tnum_excno,excinib_tableの定義と,CPU例外ハンドラ毎の出入口処理を生成
|
---|
2503 | するための記述(EXCHDR_ENTRYマクロのリスト)を,コンフィギュレータのパ
|
---|
2504 | ス2のテンプレートファイルのターゲット非依存部によってkernel_cfg.cに生成
|
---|
2505 | されなくなる.
|
---|
2506 |
|
---|
2507 | (6-7-4-2) void initialize_exception(void)(オプション)
|
---|
2508 |
|
---|
2509 | OMIT_INITIALIZE_EXCEPTIONをマクロ定義した場合には,この関数をターゲット
|
---|
2510 | 依存部で用意する.OMIT_INITIALIZE_EXCEPTIONをマクロ定義することにより取
|
---|
2511 | り除かれるその他のデータ型,変数,マクロは,この関数で使用する場合にの
|
---|
2512 | み用意すればよい.
|
---|
2513 |
|
---|
2514 | 6.7.5 デフォルトのCPU例外ハンドラ
|
---|
2515 |
|
---|
2516 | (6-7-5-1) default_exc_handler(void)(オプション)
|
---|
2517 |
|
---|
2518 | コンフィギュレータによりCPU例外ハンドラのテーブルを生成する場合などには,
|
---|
2519 | CPU例外ハンドラを登録しなかったCPU例外ハンドラ番号に対して,デフォルト
|
---|
2520 | のCPU例外ハンドラとして,default_exc_handlerを登録する.
|
---|
2521 |
|
---|
2522 | default_exc_handlerは,標準のものをターゲット依存部で用意するが,ユーザ
|
---|
2523 | が用意したもので置き換えられるように,OMIT_DEFAULT_EXC_HANDLERをマクロ
|
---|
2524 | 定義した場合には,ターゲット依存部で定義しないようにする.なお,ユーザ
|
---|
2525 | が用意する場合の名称は,_kernel_default_exc_handlerとなる.
|
---|
2526 |
|
---|
2527 | 6.7.6 CPU例外発生時のシステム状態の参照
|
---|
2528 |
|
---|
2529 | (6-7-6-1) bool_t exc_sense_intmask(void *p_excinf)
|
---|
2530 |
|
---|
2531 | CPU例外の発生した時のシステム状態が,カーネル実行中でなく,タスクコンテ
|
---|
2532 | キストであり,全割込みロック状態でなく,CPUロック状態でなく,割込み優先
|
---|
2533 | 度マスク全解除状態である時にtrue,そうでない時にfalseを返す関数.
|
---|
2534 |
|
---|
2535 | p_excinfには,CPU例外の情報を記憶している領域の先頭番地が渡される.
|
---|
2536 |
|
---|
2537 | CPU例外がカーネル管理外の割込み処理中で発生した場合にもfalseを返さなけ
|
---|
2538 | ればならないことに注意すること.
|
---|
2539 |
|
---|
2540 | 6.8 カーネルの起動・終了とスタック領域など
|
---|
2541 |
|
---|
2542 | (6-8-1) スタートアップモジュール
|
---|
2543 |
|
---|
2544 | カーネルのスタートアップモジュールは,システムのリセット後に最初に実行
|
---|
2545 | されるプログラムである.スタートアップモジュールは,標準的には,プロセッ
|
---|
2546 | サ依存部またはチップ依存部で用意し以下の処理を行うが,それにこだわる必
|
---|
2547 | 要はない.具体的には,開発環境に用意されているスタートアップモジュール
|
---|
2548 | を用いる方法(この場合,ターゲット依存部でmain関数を用意する必要がある)
|
---|
2549 | や,アプリケーションで用意する場合が考えられる.
|
---|
2550 |
|
---|
2551 | (a) プロセッサ状態の初期化
|
---|
2552 |
|
---|
2553 | プロセッサモード,スタックポインタ,フレームポインタ等,プロセッサの状
|
---|
2554 | 態を初期化する.また,NMIを除くすべての割込みをマスクした状態(全割込み
|
---|
2555 | ロック状態と同等の状態)とする.DRAMコントローラの初期化など,メモリを
|
---|
2556 | アクセスするために必要な初期化処理をここで行ってもよい(次の
|
---|
2557 | hardware_init_hookで行ってもよい).
|
---|
2558 |
|
---|
2559 | (b) hardware_init_hookを呼び出す
|
---|
2560 |
|
---|
2561 | システムのリセット後すぐに行う必要のあるターゲットシステム依存の初期化
|
---|
2562 | 処理を行うために,hardware_init_hookを呼び出す.hardware_init_hookが用
|
---|
2563 | 意されていない場合は,何もしない.GNU開発環境では,リンカスクリプト中の
|
---|
2564 | weak definitionにより,hardware_init_hookが用意されていない場合の値を0
|
---|
2565 | とすることで,これを実現できる.weak definitionの機能を持たない開発環境
|
---|
2566 | では,hardware_init_hookを必ず呼び出すことにする.
|
---|
2567 |
|
---|
2568 | hardware_init_hookは,ターゲット依存部で用意するのが標準であるが,シス
|
---|
2569 | テムのリセット後すぐに行う必要のある初期化処理を追加するために,アプリ
|
---|
2570 | ケーションで用意したものを用いる場合もある.
|
---|
2571 |
|
---|
2572 | メモリアクセスに必要な初期化処理をhardware_init_hookで行う場合には,こ
|
---|
2573 | れを呼び出す時点でメモリにアクセスすることができないため,関数(サブルー
|
---|
2574 | チン)を呼び出すためにスタックを使用するプロセッサでは,戻り番地を汎用
|
---|
2575 | レジスタに入れて呼び出すといった工夫が必要である.この場合,
|
---|
2576 | hardware_init_hookをC言語で記述することはできなくなるが,やむをえない.
|
---|
2577 |
|
---|
2578 | (c) bssセクションとdataセクションの初期化
|
---|
2579 |
|
---|
2580 | bssセクションをクリアし,dataセクションに初期値を設定する.
|
---|
2581 |
|
---|
2582 | ただし,カーネル本体は,kerflgがfalse(=0)に初期化されること以外に,
|
---|
2583 | これらのセクションが初期化されることに依存していないため,スタートアッ
|
---|
2584 | プモジュールをアプリケーションで用意する場合で,システムサービスやアプ
|
---|
2585 | リケーションがこれらのセクションが初期化されることに依存していない場合
|
---|
2586 | には,システムの起動時間を短縮するために,kerflgをfalseに初期化するだけ
|
---|
2587 | で十分である.
|
---|
2588 |
|
---|
2589 | (d) software_init_hookを呼び出す
|
---|
2590 |
|
---|
2591 | 開発環境(特にライブラリ)に依存して必要な初期化処理を行うために,
|
---|
2592 | software_init_hookを呼び出す.software_init_hookが用意されていない場合
|
---|
2593 | は,何もしない.GNU開発環境では,リンカスクリプト中のweak definitionに
|
---|
2594 | より,software_init_hookが用意されていない場合の値を0とすることで,これ
|
---|
2595 | を実現できる.weak definitionの機能を持たない開発環境では,
|
---|
2596 | software_init_hookを必ず呼び出すことにする.
|
---|
2597 |
|
---|
2598 | software_init_hookは,ターゲット依存部で用意するのが標準である.
|
---|
2599 |
|
---|
2600 | (e) sta_kerへ分岐
|
---|
2601 |
|
---|
2602 | sta_kerを呼び出す.sta_kerは,NMIを除くすべての割込みをマスクした状態
|
---|
2603 | (全割込みロック状態と同等の状態)で呼び出さなければならない.sta_kerか
|
---|
2604 | らはリターンすることがないため,スタートアップモジュールに戻ってくるこ
|
---|
2605 | とは考える必要がない.
|
---|
2606 |
|
---|
2607 | (6-8-2) void target_initialize(void)
|
---|
2608 |
|
---|
2609 | ターゲット依存部の初期化を行う関数.sta_kerの最初で呼び出される.プロセッ
|
---|
2610 | サ・チップ・開発環境依存の初期化処理を,それらの依存部に切り分けること
|
---|
2611 | も可能である.
|
---|
2612 |
|
---|
2613 | この関数は,あくまでもカーネルのターゲット依存部の初期化処理を行うため
|
---|
2614 | のものである.アプリケーションに必要な初期化処理は,初期化ルーチンで行
|
---|
2615 | うのが基本であるが,システムのリセット後すぐに行う必要がある場合には,
|
---|
2616 | hardware_init_hookを用いる.
|
---|
2617 |
|
---|
2618 | (6-8-3) void call_exit_kernel(void)
|
---|
2619 |
|
---|
2620 | 非タスクコンテキストに切り換えて,exit_kernelへ分岐する関数.ext_kerか
|
---|
2621 | ら呼び出される.exit_kernelからはリターンすることがないため,この関数に
|
---|
2622 | 戻ってくることは考える必要がない.
|
---|
2623 |
|
---|
2624 | 非タスクコンテキストに切り換えるのは,終了処理ルーチンを,非タスクコン
|
---|
2625 | テキスト用のスタックで実行するためである.終了処理ルーチンをタスク用の
|
---|
2626 | スタックで実行すると,各タスクのスタック領域のサイズを決定する際に,終
|
---|
2627 | 了処理ルーチンが使用するスタック領域を考慮しなければならない.これには,
|
---|
2628 | 終了処理ルーチンが使用するスタック領域が大きい場合に各タスクのスタック
|
---|
2629 | 領域を無駄に大きくしなければならないことに加えて,意図しないスタックオー
|
---|
2630 | バーフローが発生する可能性を高めるという問題がある.
|
---|
2631 |
|
---|
2632 | この関数は,全割込みロック状態で呼ばれるため,全割込みロック状態から呼
|
---|
2633 | び出すことができない関数を呼ばないように実装しなければならない.
|
---|
2634 |
|
---|
2635 | (6-8-4) void target_exit(void)
|
---|
2636 |
|
---|
2637 | ターゲット依存部の終了処理を行う関数.この関数は,カーネル終了処理の最
|
---|
2638 | 後に呼び出され,リターンしてはならない.プロセッサ・チップ・開発環境依
|
---|
2639 | 存の終了処理を,それらの依存部に切り分けることも可能である.
|
---|
2640 |
|
---|
2641 | この関数では,最初に,atexitによって登録された関数とデストラクタを呼び
|
---|
2642 | 出すことを意図しており,標準的には,software_term_hookを呼び出す.
|
---|
2643 | software_term_hookが用意されていない場合は,何もしない.GNU開発環境では,
|
---|
2644 | リンカスクリプト中のweak definitionにより,software_term_hookが用意され
|
---|
2645 | ていない場合の値を0とすることで,これを実現できる.weak definitionの機
|
---|
2646 | 能を持たない開発環境では,software_term_hookを必ず呼び出すことにする.
|
---|
2647 |
|
---|
2648 | この関数は,全割込みロック状態で呼ばれるため,全割込みロック状態から呼
|
---|
2649 | び出すことができない関数を呼ばないように実装しなければならない.
|
---|
2650 |
|
---|
2651 | 6.9 カーネル内部のチューニング
|
---|
2652 |
|
---|
2653 | 6.9.1 ビットマップサーチ
|
---|
2654 |
|
---|
2655 | (6-9-1-1) OMIT_BITMAP_SEARCH(オプション)
|
---|
2656 | (6-9-1-2) uint_t bitmap_search(uint16_t bitmap)(オプション)
|
---|
2657 |
|
---|
2658 | ターゲット非依存部で,uint16_t型の整数値(bitmap)中の1のビットの内,最
|
---|
2659 | も下位(右)のものをサーチし,そのビット番号を返す関数bitmap_searchを用
|
---|
2660 | 意している.ここで,ビット番号は最下位ビットを0とし,bitmapに0を指定し
|
---|
2661 | てはならないものとしている.
|
---|
2662 |
|
---|
2663 | ビットサーチ命令を持つプロセッサでは,bitmap_searchを,ビットサーチ命令
|
---|
2664 | を使うように書き直した方が効率が良い場合がある.このような場合には,ター
|
---|
2665 | ゲット依存部でビットサーチ命令を使ったbitmap_searchを定義し,
|
---|
2666 | OMIT_BITMAP_SEARCHをマクロ定義する.
|
---|
2667 |
|
---|
2668 | 標準ライブラリにビットサーチ命令を用いたffsがある場合,bitmap_searchを
|
---|
2669 | (ffs(bitmap) - 1)に定義するとよい.
|
---|
2670 |
|
---|
2671 | (6-9-1-3) uint16_t PRIMAP_BIT(PRI pri)(オプション)
|
---|
2672 |
|
---|
2673 | ビットサーチ命令のサーチ方向が逆などの理由で,優先度とビットとの対応を
|
---|
2674 | 変更したい場合には,PRIMAP_BITをマクロ定義する.
|
---|
2675 |
|
---|
2676 | 6.9.2 ビットフィールド
|
---|
2677 |
|
---|
2678 | (6-9-2-1) BIT_FIELD_UINT(オプション)
|
---|
2679 |
|
---|
2680 | 8ビット以下の幅のビットフィールドで,符号無し整数値を保持したい場合に用
|
---|
2681 | いるべきデータ型.デフォルトの定義はunsigned intとなっているが,ターゲッ
|
---|
2682 | トやツール依存で,unsigned charまたはunsigned shortに定義した方が効率が
|
---|
2683 | 良い場合がある.
|
---|
2684 |
|
---|
2685 | (6-9-2-2) BIT_FIELD_BOOL(オプション)
|
---|
2686 |
|
---|
2687 | 1ビット幅のビットフィールドで,ブール値を保持したい場合に用いるべきデー
|
---|
2688 | タ型.デフォルトではBIT_FIELD_UINTと同一に定義しているが,ブール値を保
|
---|
2689 | 持することを明示するために別の名前としている.
|
---|
2690 |
|
---|
2691 | (6-9-2-3) TBIT_TCB_PRIORITY(オプション)
|
---|
2692 |
|
---|
2693 | 現在優先度(および,ミューテックス拡張におけるベース優先度)を保持する
|
---|
2694 | ためのTCB中のフィールドのビット数.デフォルトでは8ビットに定義している
|
---|
2695 | が,それ以外に定義したい場合に,ビット数をこの名前にマクロ定義する.
|
---|
2696 |
|
---|
2697 | 6.10 カーネル実装に関するその他の定義
|
---|
2698 |
|
---|
2699 | 6.10.1 ターゲット依存のオブジェクト属性
|
---|
2700 |
|
---|
2701 | (6-10-1) TARGET_TSKATR(オプション) ターゲット定義のタスク属性
|
---|
2702 | (6-10-2) TARGET_ISRATR(オプション) ターゲット定義のISR属性
|
---|
2703 | (6-10-3) TARGET_INHATR(オプション) ターゲット定義の割込みハンドラ属性
|
---|
2704 | (6-10-4) TARGET_INTATR(オプション) ターゲット定義の割込み属性
|
---|
2705 | (6-10-5) TARGET_EXCATR(オプション) ターゲット定義のCPU例外ハンドラ属性
|
---|
2706 |
|
---|
2707 | 各オブジェクトの属性を,ターゲット定義に拡張する場合に,該当するオブジェ
|
---|
2708 | クト属性を示す変数に,拡張に使用するビットの論理和を定義する.これによ
|
---|
2709 | り,拡張に使用するビットが設定されている場合に,エラーになるのを防ぐ.
|
---|
2710 |
|
---|
2711 | なお,TOPPERS新世代カーネル統合仕様書では,割込みサービスルーチン(ISR)
|
---|
2712 | 属性をターゲット定義で拡張できる仕様とはなっていない.
|
---|
2713 |
|
---|
2714 | 6.10.2 エラーチェック方法の指定
|
---|
2715 |
|
---|
2716 | (6-10-1) TARGET_MIN_STKSZ(オプション)
|
---|
2717 |
|
---|
2718 | ターゲット定義で,タスクのスタックサイズの最小値を設定する場合には,こ
|
---|
2719 | の変数をスタックサイズの最小値に定義する.
|
---|
2720 |
|
---|
2721 | (6-10-2) CHECK_STKSZ_ALIGN(オプション)
|
---|
2722 |
|
---|
2723 | スタック領域のサイズがある値(アライン単位)の倍数でなければならない場
|
---|
2724 | 合に,この変数をアライン単位に定義する.この変数を定義することで,
|
---|
2725 | kernel.tfおよびacre_tsk(動的生成機能拡張パッケージのみ)において,スタッ
|
---|
2726 | ク領域のサイズが正しくない(この変数に定義した値の倍数でない)場合のエ
|
---|
2727 | ラーをチェックするようになる.チェックが必要ない場合には,この変数を定
|
---|
2728 | 義しない.
|
---|
2729 |
|
---|
2730 | (6-10-3) CHECK_FUNC_ALIGN(オプション) 処理単位のアライン単位
|
---|
2731 | (6-10-4) CHECK_FUNC_NONNULL(オプション)処理単位の非NULLチェック
|
---|
2732 | (6-10-5) CHECK_STACK_ALIGN(オプション)スタック領域のアライン単位
|
---|
2733 | (6-10-6) CHECK_STACK_NONNULL(オプション)スタック領域の非NULLチェック
|
---|
2734 | (6-10-7) CHECK_MPF_ALIGN(オプション) 固定長メモリプール領域のアライン単位
|
---|
2735 | (6-10-8) CHECK_MPF_NONNULL(オプション)固定長メモリプール領域の非NULLチェック
|
---|
2736 |
|
---|
2737 | 処理単位/スタック領域/固定長メモリプール領域の先頭番地がある値(アラ
|
---|
2738 | イン単位)の倍数でなければならない場合に,それぞれ,CHECK_FUNC_ALIGN/
|
---|
2739 | CHECK_STACK_ALIGN/CHECK_MPF_ALIGNをアライン単位に定義する.処理単位/
|
---|
2740 | スタック領域/固定長メモリプール領域の先頭番地がNULLでないかのチェック
|
---|
2741 | を行う場合には,それぞれCHECK_FUNC_NONNULL/CHECK_STACK_NONNULL/
|
---|
2742 | CHECK_MPF_NONNULLを定義する.
|
---|
2743 |
|
---|
2744 | (6-10-9) CHECK_MB_ALIGN(オプション) 管理領域のアライン単位
|
---|
2745 |
|
---|
2746 | カーネル内の管理領域(具体的には,データキュー管理領域,優先度データ
|
---|
2747 | キュー管理領域,固定長メモリプール管理領域)の先頭番地がある値(アライ
|
---|
2748 | ン単位)の倍数でなければならない場合に,この変数をアライン単位に定義す
|
---|
2749 | る.動的生成機能拡張パッケージを使用しない場合には,定義する必要がない.
|
---|
2750 |
|
---|
2751 | 6.10.3 非タスクコンテキスト用のスタック領域
|
---|
2752 |
|
---|
2753 | (6-10-3-1) DEFAULT_ISTKSZ
|
---|
2754 |
|
---|
2755 | DEF_ICSにより非タスクコンテキスト用のスタック領域が指定されない場合の,
|
---|
2756 | デフォルトのスタック領域のサイズ.
|
---|
2757 |
|
---|
2758 | (6-10-3-2) DEFAULT_ISTK(オプション)
|
---|
2759 |
|
---|
2760 | DEF_ICSにより非タスクコンテキスト用のスタック領域が指定されない場合の,
|
---|
2761 | デフォルトのスタック領域の先頭番地.このマクロが定義されない場合には,
|
---|
2762 | サイズがDEFAULT_ISTKSZのスタック領域が,配列により確保される.
|
---|
2763 |
|
---|
2764 | (6-10-3-3) STK_T *TOPPERS_ISTKPT(STK_T *istk, SIZE istksz)(オプション)
|
---|
2765 |
|
---|
2766 | 非タスクコンテキスト用のスタックポインタの初期値を保持する変数(istkpt)
|
---|
2767 | を用いる場合に,このシンボルに,スタック領域の先頭番地(istk)とスタッ
|
---|
2768 | ク領域のサイズ(istksz)から,スタックポインタの初期値を求めるマクロを
|
---|
2769 | 定義する.
|
---|
2770 |
|
---|
2771 | 6.10.4 空ラベルの定義
|
---|
2772 |
|
---|
2773 | (6-10-4-1) TOPPERS_EMPTY_LABEL(type, symbol)(オプション)
|
---|
2774 |
|
---|
2775 | リンクエラーを防ぐために,データ型typeの配列である変数symbolに定義を与
|
---|
2776 | えるためのマクロ.与えた定義が参照されることはないため,どのような定義
|
---|
2777 | を与えてもよい.
|
---|
2778 |
|
---|
2779 | デフォルトでは,symbolを,要素型がtypeでサイズが0の配列に定義している.
|
---|
2780 | サイズが0の配列がエラーとならないコンパイラ(GCCはこれに該当)を用いる
|
---|
2781 | 場合には,ターゲット依存部で定義する必要はない.
|
---|
2782 |
|
---|
2783 | 6.11 トレースログ機能に関する設定
|
---|
2784 |
|
---|
2785 | ASPカーネルのソースコードには,カーネルの実行トレースログを取得するため
|
---|
2786 | のマクロ等が埋め込んである.デフォルトでは,これらのマクロは空に定義さ
|
---|
2787 | れてトレースログの取得は行わないが,これらのマクロを適切に定義すること
|
---|
2788 | でトレースログの取得を行うことができる.
|
---|
2789 |
|
---|
2790 | 6.11.1 取得できるトレースログの種類とマクロ
|
---|
2791 |
|
---|
2792 | 取得できるトレースログの種類と,それを取得するために定義するマクロは次
|
---|
2793 | の通りである.
|
---|
2794 |
|
---|
2795 | (a) カーネルの動作開始と終了
|
---|
2796 |
|
---|
2797 | 次のマクロを定義することで,カーネルの動作開始時と終了時のトレースログ
|
---|
2798 | を取得することができる.
|
---|
2799 |
|
---|
2800 | LOG_KER_ENTER カーネルが動作を開始する直前(初期化の完了後)
|
---|
2801 | LOG_KER_LEAVE カーネルの終了(ext_ker)が呼ばれた直後(終了処
|
---|
2802 | 理の実行前)
|
---|
2803 |
|
---|
2804 | (b) 処理単位の実行開始と終了
|
---|
2805 |
|
---|
2806 | 次のマクロを定義することで,割込みハンドラ(INH),割込みサービスルーチ
|
---|
2807 | ン(ISR),周期ハンドラ(CYC),アラームハンドラ(ALM),CPU例外ハンド
|
---|
2808 | ラ(EXC),タスク例外処理ルーチン(TEX)の実行開始前と終了後のトレース
|
---|
2809 | ログを取得することができる.
|
---|
2810 |
|
---|
2811 | LOG_<処理単位略号>_ENTER 処理単位の実行開始直前
|
---|
2812 | LOG_<処理単位略号>_LEAVE 処理単位の終了直後
|
---|
2813 |
|
---|
2814 | 割込みハンドラは,アプリケーションが登録したもののみを対象とし,割込み
|
---|
2815 | サービスルーチンを呼び出すためにカーネル内に生成されるものは対象としな
|
---|
2816 | い.タスクの実行開始と終了は,他の方法で取得できるため,この方法は用意
|
---|
2817 | していない.
|
---|
2818 |
|
---|
2819 | なお,割込みハンドラとCPU例外ハンドラの実行開始と終了のトレースログ取得
|
---|
2820 | は,ターゲット依存部で実装する必要がある.詳しくは,「6.2 トレースログ
|
---|
2821 | 機能への対応」「6.6.1 割込みハンドラの出入口処理」「6.7.1 CPU例外ハンド
|
---|
2822 | ラの出入口処理」の節を参照すること.
|
---|
2823 |
|
---|
2824 | (c) タスク状態の変化
|
---|
2825 |
|
---|
2826 | 次のマクロを定義することで,タスク状態が変化した時のトレースログを取得
|
---|
2827 | することができる.ただし,実行状態と実行可能状態の間の遷移は,他の方法
|
---|
2828 | で取得できるため,このマクロでは取得できない.
|
---|
2829 |
|
---|
2830 | LOG_TSKSTAT タスク状態の変化
|
---|
2831 |
|
---|
2832 | (d) ディスパッチャの実行開始と終了
|
---|
2833 |
|
---|
2834 | 次のマクロを定義することで,ディスパッチャが実行開始する時と,終了する
|
---|
2835 | 時のトレースログを取得することができる.
|
---|
2836 |
|
---|
2837 | LOG_DSP_ENTER ディスパッチャの実行開始
|
---|
2838 | LOG_DSP_LEAVE ディスパッチャの終了
|
---|
2839 |
|
---|
2840 | ディスパッチャの実行開始は,タスクが実行状態から実行可能状態に遷移する
|
---|
2841 | タイミングであるため,実行可能状態へ遷移するタスクのTCBへのポインタをパ
|
---|
2842 | ラメータとする.逆に,ディスパッチャの終了は,タスクが実行可能状態から
|
---|
2843 | 実行状態に遷移するタイミングであるため,実行状態へ遷移するタスクのTCBへ
|
---|
2844 | のポインタをパラメータとする.
|
---|
2845 |
|
---|
2846 | ASPカーネルでは,実行できるタスクがなく,カーネルがアイドル状態になる場
|
---|
2847 | 合には,ディスパッチャの中に留まる.そのため,アイドル状態への遷移とア
|
---|
2848 | イドル状態から他の状態への遷移は,このマクロでは取得できない.
|
---|
2849 |
|
---|
2850 | なお,ディスパッチャの実行開始と終了のトレースログ取得は,ターゲット依
|
---|
2851 | 存部で実装する必要がある.詳しくは,「6.2 トレースログ機能への対応」と
|
---|
2852 | 「6.5.2 ディスパッチャ本体」の節を参照すること.
|
---|
2853 |
|
---|
2854 | (e) サービスコールの入口と出口
|
---|
2855 |
|
---|
2856 | 次のマクロを定義することで,各サービスコールの入口と出口のトレースログ
|
---|
2857 | を取得することができる.
|
---|
2858 |
|
---|
2859 | LOG_<サービスコールの大文字表記>_ENTER サービスコール名の入口
|
---|
2860 | LOG_<サービスコールの大文字表記>_LEAVE サービスコール名の出口
|
---|
2861 |
|
---|
2862 | それぞれのマクロの名称やパラメータの詳細については,カーネルのソースコー
|
---|
2863 | ドを参照すること.
|
---|
2864 |
|
---|
2865 | 6.11.2 トレースログ記録のサンプルコード
|
---|
2866 |
|
---|
2867 | トレースログを記録する方法の一例として,メモリ上にトレースログを記録す
|
---|
2868 | るためのサンプルコードをarch/logtraceディレクトリに用意している.このサ
|
---|
2869 | ンプルコードは,システムログ機能と同様のトレースログ機能を用意し,トレー
|
---|
2870 | スログ情報をメモリ上に記録するとともに,それを読み出して表示する機能を
|
---|
2871 | 実現している.
|
---|
2872 |
|
---|
2873 | このサンプルコードを組み込む方法は次の通りである.
|
---|
2874 |
|
---|
2875 | (1) target_config.hおよびtarget_syssvc.hに,次の記述を追加する.
|
---|
2876 |
|
---|
2877 | #ifdef TOPPERS_ENABLE_TRACE
|
---|
2878 | #include "logtrace/trace_config.h"
|
---|
2879 | #endif /* TOPPERS_ENABLE_TRACE */
|
---|
2880 |
|
---|
2881 | (2) Makefile.targetに,次の記述を追加する.
|
---|
2882 |
|
---|
2883 | ifeq ($(ENABLE_TRACE),true)
|
---|
2884 | COPTS := $(COPTS) -DTOPPERS_ENABLE_TRACE
|
---|
2885 | KERNEL_DIR := $(KERNEL_DIR) $(SRCDIR)/arch/logtrace
|
---|
2886 | KERNEL_COBJS := $(KERNEL_COBJS) trace_config.o trace_dump.o
|
---|
2887 | endif
|
---|
2888 |
|
---|
2889 | (3) スタートアップモジュールで,bssセクションのクリアを省略している場合
|
---|
2890 | には,trace_modeをTRACE_STOP(=0)に初期化するコードを追加する.こ
|
---|
2891 | れは,トレースログ機能が初期化される前に書き込まれるトレースログを
|
---|
2892 | 無視するためである.
|
---|
2893 |
|
---|
2894 | このサンプルコードを用いて,トレースログを記録・ダンプする方法の例につ
|
---|
2895 | いては,「TOPPERS/ASPカーネル ユーザーズマニュアル」の「11.6 トレースロ
|
---|
2896 | グ記録のサンプルコードの使用方法」の節を参照すること.
|
---|
2897 |
|
---|
2898 | なお,このサンプルコードでは,ディスパッチャの出口,タスクの状態遷移,
|
---|
2899 | システムログの出力の3つのトレースログのみを記録している.他のトレースロ
|
---|
2900 | グを記録したい場合には,trace_config.h(およびtrace_dump.c)を修正する
|
---|
2901 | 必要がある.なお,カーネルのトレースログを網羅的に記録するためのコード
|
---|
2902 | は,TLV(TraceLogVisualizer)の配布パッケージに含まれている.
|
---|
2903 |
|
---|
2904 | 6.12 カーネル実装のターゲット依存部のためのリネーム記述
|
---|
2905 |
|
---|
2906 | カーネル内部に閉じて使われる関数や変数などの名称で,オブジェクトファイ
|
---|
2907 | ルのシンボル表に登録されて外部から参照できる名称は,C言語レベルで,先頭
|
---|
2908 | が"_kernel_"または"_KERNEL_"である名称としなければならないが,ASPカーネ
|
---|
2909 | ルでは,ソースコードをコンパクトに保ちつつこれを実現するために,リネー
|
---|
2910 | ム記述ファイルを導入している.
|
---|
2911 |
|
---|
2912 | 具体的には,リネームすべき名称をリストアップしたxxx_rename.defを用意し,
|
---|
2913 | このファイルからツール(utils/genrename)により,名称をリネームするため
|
---|
2914 | のマクロ定義を含むxxx_rename.hと,それらのマクロ定義を解除するための
|
---|
2915 | xxx_unrename.hを生成する.ツールの起動方法は次の通りである.
|
---|
2916 |
|
---|
2917 | % genrename xxx
|
---|
2918 |
|
---|
2919 | xxx_rename.defには,リネームすべき名称を1行に1つ記述する.xxxxという名
|
---|
2920 | 称が記述されている場合,xxx_rename.hには次のような記述が生成される.
|
---|
2921 |
|
---|
2922 | #define xxxx _kernel_xxxx
|
---|
2923 | #ifdef TOPPERS_LABEL_ASM
|
---|
2924 | #define _xxxx __kernel_xxxx
|
---|
2925 | #endif /* TOPPERS_LABEL_ASM */
|
---|
2926 |
|
---|
2927 | また,xxx_unrename.hには次のような記述が生成される.
|
---|
2928 |
|
---|
2929 | #undef xxxx
|
---|
2930 | #ifdef TOPPERS_LABEL_ASM
|
---|
2931 | #undef _xxxx
|
---|
2932 | #endif /* TOPPERS_LABEL_ASM */
|
---|
2933 |
|
---|
2934 | xxx_rename.defの中には,他のリネーム記述を取り込むために,「INCLUDE
|
---|
2935 | "yyy"」または「INCLUDE <yyy>」という記述を含めることができる.この記述
|
---|
2936 | がされている場合,xxx_rename.hには「#include "yyy_rename.h"」または
|
---|
2937 | 「#include <yyy_rename.h>」という記述が,xxx_unrename.hには「#include
|
---|
2938 | "yyy_unrename.h"」または「#include <yyy_unrename.h>」という記述が生成さ
|
---|
2939 | れる.
|
---|
2940 |
|
---|
2941 | xxx_rename.defの中の"#"で始まる行はコメントとして読み飛ばされる.また,
|
---|
2942 | 空行も無視される.
|
---|
2943 |
|
---|
2944 | カーネルのターゲット非依存部で使われる名称をリネームするために,kernel
|
---|
2945 | ディレクトリに,kernel_rename.defと,そこから生成したkernel_rename.hお
|
---|
2946 | よびkernel_unrename.hが用意されている.kernel_rename.defには,
|
---|
2947 | 「INCLUDE "target"」という記述が含まれており,ターゲット依存部のリネー
|
---|
2948 | ム記述を取り込むようになっている.ターゲット依存部で定義し,ターゲット
|
---|
2949 | 非依存部で参照される名称は,ターゲット依存部のリネーム記述に含める.
|
---|
2950 |
|
---|
2951 | ターゲット依存部では,ターゲット依存部で使われる名称をリネームするため
|
---|
2952 | に,target_rename.defと,そこから生成したtarget_rename.hおよび
|
---|
2953 | target_unrename.hを用意する.ターゲット依存部からプロセッサ・チップ・開
|
---|
2954 | 発環境依存部を切り分ける場合には,target_rename.defにINCLUDE記述を入れ,
|
---|
2955 | プロセッサ・チップ・開発環境依存部のリネーム記述を取り込むようにする.
|
---|
2956 |
|
---|
2957 | 6.13 タイマドライバ
|
---|
2958 |
|
---|
2959 | タイマドライバは,カーネルにタイムティックを通知するためのタイマドライ
|
---|
2960 | バである.
|
---|
2961 |
|
---|
2962 | 6.13.1 タイマドライバのファイル構成
|
---|
2963 |
|
---|
2964 | タイマドライバを組み込むための静的APIを記述したシステムコンフィギュレー
|
---|
2965 | ションファイルを,target_timer.cfgに用意する.このファイルには,タイマ
|
---|
2966 | ドライバを初期化するための初期化ルーチンの追加,タイマドライバを終了さ
|
---|
2967 | せるための終了処理ルーチンの追加,タイマ割込みのための割込みハンドラの
|
---|
2968 | 定義(または,割込みサービスルーチンの追加),タイマ割込みのための割込
|
---|
2969 | み要求ラインの属性の設定の静的APIなどを含むことになる.
|
---|
2970 |
|
---|
2971 | タイマドライバを呼び出すために必要な定義を含むヘッダファイルを,
|
---|
2972 | target_timer.hに用意する.また,タイマドライバの実装ファイルを
|
---|
2973 | target_timer.cに用意する.
|
---|
2974 |
|
---|
2975 | タイムティックの通知により行う処理の多くは,タスクの起動や待ち解除を行
|
---|
2976 | うものであるため,タイマ割込みの割込み優先度は,割込みの中で最低の優先
|
---|
2977 | 度で十分である.ただし,周期ハンドラやアラームハンドラの実行開始遅れが
|
---|
2978 | 問題になる場合には,タイマ割込みの割込み優先度をより高い値に設定したい.
|
---|
2979 | そこで,タイマ割込みの割込み優先度を変更する方法を,ターゲット依存部の
|
---|
2980 | ユーザーズマニュアルに記載すべきである.
|
---|
2981 |
|
---|
2982 | 6.13.2 タイマの初期化・終了処理・割込み処理
|
---|
2983 |
|
---|
2984 | (6-13-2-1) void target_timer_initialize(intptr_t exinf)
|
---|
2985 |
|
---|
2986 | タイマを初期化し,タイマ割込みを周期的に発生させる関数.タイマ割込みの
|
---|
2987 | 周期は,TIC_NUMEとTIC_DENOで指定された時間と一致させる(「5.2 タイム
|
---|
2988 | ティックの定義」の節を参照).
|
---|
2989 |
|
---|
2990 | この関数は,target_timer.cfg中に記述する静的APIにより,初期化ルーチンと
|
---|
2991 | してカーネルに登録することを想定している.
|
---|
2992 |
|
---|
2993 | (6-13-2-2) void target_timer_terminate(intptr_t exinf)
|
---|
2994 |
|
---|
2995 | タイマの動作を停止させ,タイマ割込みを発生しないようにする関数.
|
---|
2996 |
|
---|
2997 | この関数は,target_timer.cfg中に記述する静的APIにより,終了処理ルーチン
|
---|
2998 | としてカーネルに登録することを想定している.
|
---|
2999 |
|
---|
3000 | (6-13-2-3) void target_timer_handler(void)
|
---|
3001 | または void target_timer_isr(intptr_t exinf)
|
---|
3002 |
|
---|
3003 | タイマ割込みにより起動される割込み処理プログラム.割込みハンドラとして
|
---|
3004 | 実現する場合にはtarget_timer_handler,割込みサービスルーチンとして実現
|
---|
3005 | する場合にはtarget_timer_isrの名称とする.ターゲット非依存部の
|
---|
3006 | signal_timeを呼び出す.
|
---|
3007 |
|
---|
3008 | target_timer_handlerは,標準的には次のように定義する.
|
---|
3009 |
|
---|
3010 | ----------------------------------------
|
---|
3011 | void
|
---|
3012 | target_timer_handler(void)
|
---|
3013 | {
|
---|
3014 | i_begin_int(<タイマ割込みの割込み番号>);
|
---|
3015 | signal_time();
|
---|
3016 | i_end_int(<タイマ割込みの割込み番号>);
|
---|
3017 | }
|
---|
3018 | ----------------------------------------
|
---|
3019 |
|
---|
3020 | この関数は,target_timer.cfg中に記述する静的APIにより,割込みハンドラま
|
---|
3021 | たは割込みサービスルーチンとしてカーネルに登録することを想定している.
|
---|
3022 |
|
---|
3023 | 6.13.3 性能評価用システム時刻の参照のための機能
|
---|
3024 |
|
---|
3025 | 性能評価用システム時刻の参照機能(get_utm)をサポートする場合には,タイ
|
---|
3026 | マドライバで,以下のデータ型や関数などを用意する.
|
---|
3027 |
|
---|
3028 | (6-13-3-1) OMIT_GET_UTM(オプション)
|
---|
3029 |
|
---|
3030 | ターゲット非依存部のget_utmの実装を使用せず,ターゲット依存部でget_utm
|
---|
3031 | を用意する場合には,このシンボルをマクロ定義する.このシンボルをマクロ
|
---|
3032 | 定義した場合,以下のデータ型や関数などを用意する必要はない.
|
---|
3033 |
|
---|
3034 | (6-13-3-2) CLOCK
|
---|
3035 |
|
---|
3036 | タイマ値の内部表現のためのデータ型.
|
---|
3037 |
|
---|
3038 | (6-13-3-3) CLOCK target_timer_get_current(void)
|
---|
3039 |
|
---|
3040 | タイマの現在値を読み出し,内部表現で返す関数.タイマ値は,時間の経過と
|
---|
3041 | ともに増加することを想定している.ハードウェアのタイマが,タイマ値が減
|
---|
3042 | 少するものである場合には,この関数内で増加する値となるように変換する.
|
---|
3043 |
|
---|
3044 | (6-13-3-4) bool_t target_timer_probe_int(void)
|
---|
3045 |
|
---|
3046 | タイマ割込み要求をチェックする関数.タイマ割込みが要求されている場合に
|
---|
3047 | true,要求されていない場合にfalseを返す.
|
---|
3048 |
|
---|
3049 | (6-13-3-5) TO_USEC(clock)
|
---|
3050 |
|
---|
3051 | タイマ値の内部表現を,1μ秒単位に変換するためのマクロ(または関数).
|
---|
3052 | targettimer_get_currentで読み出した値を,タイマ割込み発生からの経過時間
|
---|
3053 | (単位: 1μ秒)に変換するために用いる.
|
---|
3054 |
|
---|
3055 | 6.14 オーバランタイマドライバ(オプション)
|
---|
3056 |
|
---|
3057 | オーバランタイマドライバは,オーバランハンドラを起動するためのタイマの
|
---|
3058 | ドライバである.オーバランハンドラ機能拡張パッケージをサポートしない場
|
---|
3059 | 合には,オーバランタイマドライバを用意する必要はない.
|
---|
3060 |
|
---|
3061 | 6.14.1 オーバランタイマドライバのファイル構成
|
---|
3062 |
|
---|
3063 | オーバランタイマドライバは,タイマドライバと同じファイルの中に記述する.
|
---|
3064 | オーバランタイマドライバのための記述は,TOPPERS_SUPPORT_OVRHDRがマクロ
|
---|
3065 | 定義されている場合にのみ有効になるようにする.
|
---|
3066 |
|
---|
3067 | すなわち,オーバランタイマドライバを組み込むための静的APIは
|
---|
3068 | target_timer.cfgの中に記述する.このファイルには,オーバランタイマドラ
|
---|
3069 | イバを初期化するための初期化ルーチンの追加,オーバランタイマドライバを
|
---|
3070 | 終了させるための終了処理ルーチンの追加,オーバランタイマ割込みのための
|
---|
3071 | 割込みハンドラの定義(または,割込みサービスルーチンの追加),オーバラ
|
---|
3072 | ンタイマ割込みのための割込み要求ラインの属性の設定の静的APIなどを含むこ
|
---|
3073 | とになる.
|
---|
3074 |
|
---|
3075 | また,オーバランタイマドライバを呼び出すために必要な定義は
|
---|
3076 | target_timer.hの中に,オーバランタイマドライバの実装はtarget_timer.cの
|
---|
3077 | 中に記述する.
|
---|
3078 |
|
---|
3079 | オーバランハンドラは,タスクのオーバランに対する処理を行うものであるた
|
---|
3080 | め,オーバランタイマ割込みの割込み優先度は,割込みの中で最低の優先度で
|
---|
3081 | 十分である.ただし,オーバランタイマ割込みの割込み優先度をより高い値に
|
---|
3082 | 設定したい場合もないとは言えないため,オーバランタイマ割込みの割込み優
|
---|
3083 | 先度を変更する方法を,ターゲット依存部のユーザーズマニュアルに記載すべ
|
---|
3084 | きである.
|
---|
3085 |
|
---|
3086 | 6.14.2 オーバランタイマの操作と割込み処理
|
---|
3087 |
|
---|
3088 | (6-14-2-1) void target_ovrtimer_initialize(intptr_t exinf)
|
---|
3089 |
|
---|
3090 | オーバランタイマの初期化処理を行う.タイマの動作開始は行わない.
|
---|
3091 |
|
---|
3092 | この関数は,target_timer.cfg中に記述する静的APIにより,初期化ルーチンと
|
---|
3093 | してカーネルに登録することを想定している.
|
---|
3094 |
|
---|
3095 | (6-14-2-2) void target_ovrtimer_terminate(intptr_t exinf)
|
---|
3096 |
|
---|
3097 | オーバランタイマを停止させ,オーバランタイマ割込みを発生しないようにす
|
---|
3098 | る.
|
---|
3099 |
|
---|
3100 | この関数は,target_timer.cfg中に記述する静的APIにより,終了処理ルーチン
|
---|
3101 | としてカーネルに登録することを想定している.
|
---|
3102 |
|
---|
3103 | (6-14-2-3) void target_ovrtimer_start(OVRTIM ovrtim)
|
---|
3104 |
|
---|
3105 | オーバランタイマに,残り時間ovrtimを設定し,動作開始する.ovrtimの単位
|
---|
3106 | はマイクロ秒とする.
|
---|
3107 |
|
---|
3108 | (6-14-2-4) OVRTIM target_ovrtimer_stop(void)
|
---|
3109 |
|
---|
3110 | オーバランタイマを停止し,タイマの残り時間を読み出す.もし残り時間が
|
---|
3111 | 0(またはそれ未満)になっていた場合には,1を返す.また,オーバランタイ
|
---|
3112 | マからの割込みをクリアする.
|
---|
3113 |
|
---|
3114 | (6-14-2-5) OVRTIM target_ovrtimer_get_current(void)
|
---|
3115 |
|
---|
3116 | オーバランタイマの残り時間を読み出す.もし残り時間が0(またはそれ未満)
|
---|
3117 | になっていた場合には,0を返す.オーバランタイマからの割込みはクリアしな
|
---|
3118 | い.
|
---|
3119 |
|
---|
3120 | (6-14-2-6) void target_ovrtimer_handler(void)
|
---|
3121 | または void target_ovrtimer_isr(intptr_t exinf)
|
---|
3122 |
|
---|
3123 | オーバランタイマ割込みにより起動される割込み処理プログラム.割込みハン
|
---|
3124 | ドラとして実現する場合にはtarget_ovrtimer_handler,割込みサービスルーチ
|
---|
3125 | ンとして実現する場合にはtarget_ovrtimer_isrの名称とする.ターゲット非依
|
---|
3126 | 存部のcall_ovrhdrを呼び出す.
|
---|
3127 |
|
---|
3128 | target_timer_handlerは,標準的には次のように定義する.
|
---|
3129 |
|
---|
3130 | ----------------------------------------
|
---|
3131 | void
|
---|
3132 | target_ovrtimer_handler(void)
|
---|
3133 | {
|
---|
3134 | i_begin_int(<オーバランタイマ割込みの割込み番号>);
|
---|
3135 | call_ovrhdr();
|
---|
3136 | i_end_int(<オーバランタイマ割込みの割込み番号>);
|
---|
3137 | }
|
---|
3138 | ----------------------------------------
|
---|
3139 |
|
---|
3140 | この関数は,target_timer.cfg中に記述する静的APIにより,割込みハンドラま
|
---|
3141 | たは割込みサービスルーチンとしてカーネルに登録することを想定している.
|
---|
3142 |
|
---|
3143 | 6.15 動的メモリ管理
|
---|
3144 |
|
---|
3145 | 動的生成機能拡張パッケージを使用する場合には,カーネル内での動的メモリ
|
---|
3146 | 管理の方法を決める必要がある.
|
---|
3147 |
|
---|
3148 | 動的生成機能拡張パッケージのターゲット非依存部では,メモリ領域を先頭か
|
---|
3149 | ら順に割り当て,解放されたメモリ領域を再利用しないメモリ管理モジュール
|
---|
3150 | のみを実装している.デフォルトでは,このメモリ管理モジュールが使用され
|
---|
3151 | る.
|
---|
3152 |
|
---|
3153 | 本格的な動的メモリ管理を行いたい場合には,ターゲット依存部またはユーザ
|
---|
3154 | 側で,以下の関数を定義したメモリ管理モジュールを用意する必要がある.
|
---|
3155 |
|
---|
3156 | (6-15-1) OMIT_KMM_ALLOCONLY(オプション)
|
---|
3157 |
|
---|
3158 | ターゲット非依存部のメモリ管理モジュールを使用せず,ターゲット依存部ま
|
---|
3159 | たはユーザ側で用意する場合には,このシンボルをマクロ定義する.
|
---|
3160 |
|
---|
3161 | (6-15-2) void initialize_kmm(void)(オプション)
|
---|
3162 |
|
---|
3163 | メモリ管理モジュールを初期化する関数.カーネルの割り付けるメモリ領域の
|
---|
3164 | サイズと先頭番地は,それぞれkmmszとkmmによって参照できる.
|
---|
3165 |
|
---|
3166 | (6-15-3) void *kernel_malloc(SIZE size)(オプション)
|
---|
3167 |
|
---|
3168 | sizeで指定されたサイズのメモリ領域を割り付け,その先頭番地を返す関数.
|
---|
3169 | 割り付けることができない場合には,NULLを返す.
|
---|
3170 |
|
---|
3171 | (6-15-4) void kernel_free(void *ptr)(オプション)
|
---|
3172 |
|
---|
3173 | ptrで指定されたメモリ領域を解放する関数.
|
---|
3174 |
|
---|
3175 | 6.15.1 TLSFを用いたメモリ管理モジュールの例
|
---|
3176 |
|
---|
3177 | オープンソースのメモリ割付けライブラリであるTLSFを用いて動的メモリ管理
|
---|
3178 | を実現するには,OMIT_KMM_ALLOCONLYをマクロ定義し,以下の関数定義等をC言
|
---|
3179 | 語ソースファイルに含めればよい.
|
---|
3180 |
|
---|
3181 | ----------------------------------------
|
---|
3182 | #include "tlsf.h"
|
---|
3183 |
|
---|
3184 | static bool_t tlsf_initialized = false;
|
---|
3185 |
|
---|
3186 | void
|
---|
3187 | initialize_kmm(void)
|
---|
3188 | {
|
---|
3189 | if (init_memory_pool(kmmsz, kmm) >= 0) {
|
---|
3190 | tlsf_initialized = true;
|
---|
3191 | }
|
---|
3192 | }
|
---|
3193 |
|
---|
3194 | void *
|
---|
3195 | kernel_malloc(SIZE size)
|
---|
3196 | {
|
---|
3197 | if (tlsf_initialized) {
|
---|
3198 | return(malloc_ex(size, kmm));
|
---|
3199 | }
|
---|
3200 | else {
|
---|
3201 | return(NULL);
|
---|
3202 | }
|
---|
3203 | }
|
---|
3204 |
|
---|
3205 | void
|
---|
3206 | kernel_free(void *ptr)
|
---|
3207 | {
|
---|
3208 | if (tlsf_initialized) {
|
---|
3209 | free_ex(ptr, kmm);
|
---|
3210 | }
|
---|
3211 | }
|
---|
3212 | ----------------------------------------
|
---|
3213 |
|
---|
3214 |
|
---|
3215 | 7.コンフィギュレータ設定ファイルのターゲット依存部
|
---|
3216 |
|
---|
3217 | 7.1 設定ファイルとターゲット依存部の位置付け
|
---|
3218 |
|
---|
3219 | ASPカーネルのコンフィギュレータは,設定ファイルの記述に従ってファイルの
|
---|
3220 | 生成およびエラーチェックを行う.コンフィギュレータの設定ファイルには,
|
---|
3221 | 以下の4つがある.
|
---|
3222 |
|
---|
3223 | (a) 静的APIテーブル
|
---|
3224 |
|
---|
3225 | 静的APIの一覧と,各静的APIのパラメータについて記述したファイル.静的
|
---|
3226 | APIを拡張する場合以外は変更する必要がないため,ターゲット非依存部で用意
|
---|
3227 | している(kernel/kernel_api.csv).
|
---|
3228 |
|
---|
3229 | (b) 値取得シンボルテーブル
|
---|
3230 |
|
---|
3231 | コンフィギュレータのパス1において,パラメータ計算用C言語ファイルに出力
|
---|
3232 | し,値を求めたいシンボル(一般には式)を記述するためのファイル.ターゲッ
|
---|
3233 | ト非依存部では,ターゲットに依存せずに必要となるシンボルを記述したファ
|
---|
3234 | イルを用意している(kernel/kernel_def.csv).
|
---|
3235 |
|
---|
3236 | ターゲットに依存して必要となるシンボルがある場合には,targetディレクト
|
---|
3237 | リに置かれたtarget_def.csv中に記述する.target_def.csv中に記述して値を
|
---|
3238 | 求めることができるシンボルは,kernel/kernel_int.hおよびそこからインクルー
|
---|
3239 | ドされるファイルで定義されていなければならない.kernel_int.hからは,
|
---|
3240 | target_stddef.h,target_kernel.h,target_config.hを(間接的に)インクルー
|
---|
3241 | ドしているため,これらのファイルおよびそこからインクルードされるファイ
|
---|
3242 | ルで定義されるターゲット依存のシンボルは,target_def.csv中に記述するこ
|
---|
3243 | とができる.
|
---|
3244 |
|
---|
3245 | ここで値を求めたシンボルの値は,コンフィギュレータのパス2およびパス3の
|
---|
3246 | テンプレートファイル中で参照することができる.
|
---|
3247 |
|
---|
3248 | (c) パス2のテンプレートファイル
|
---|
3249 |
|
---|
3250 | コンフィギュレータのパス2は,テンプレートファイルに従って,カーネルの構
|
---|
3251 | 成・初期化ファイル(kernel_cfg.c),構成・初期化ヘッダファイル
|
---|
3252 | (kernel_cfg.h)などを生成する.このテンプレートファイルは,ターゲット
|
---|
3253 | 非依存部とターゲット依存部に切り分けてあるが,他のファイルのターゲット
|
---|
3254 | 依存部とは逆に,ターゲット依存部からターゲット非依存部をインクルードす
|
---|
3255 | る形になっている.
|
---|
3256 |
|
---|
3257 | 具体的には,targetディレクトリに置かれたtarget.tfで,必要な変数を定義し
|
---|
3258 | た後,テンプレートファイルのターゲット非依存部(kernel/kernel.tf)をイ
|
---|
3259 | ンクルードする.kernel.tfでは,カーネルのターゲット非依存部で使用する変
|
---|
3260 | 数定義等を生成する.kernel.tfをインクルードした後,target.tfでは,カー
|
---|
3261 | ネルのターゲット依存部で使用する変数定義等を生成する.target.tfから,プ
|
---|
3262 | ロセッサ依存部,チップ依存部を,開発環境依存部を切り分けてもよい.
|
---|
3263 |
|
---|
3264 | (d) パス3のテンプレートファイル
|
---|
3265 |
|
---|
3266 | コンフィギュレータのパス3は,テンプレートファイルに従って,静的APIの一
|
---|
3267 | 般定数式パラメータのチェックを行う.このテンプレートファイルも,ターゲッ
|
---|
3268 | ト非依存部とターゲット依存部に切り分けてあり,ターゲット依存部からター
|
---|
3269 | ゲット非依存部をインクルードする形になっている.
|
---|
3270 |
|
---|
3271 | 具体的には,targetディレクトリに置かれたtarget_check.tfで,必要な変数を
|
---|
3272 | 定義した後,テンプレートファイルのターゲット非依存部
|
---|
3273 | (kernel/kernel_check.tf)をインクルードする.kernel_check.tfでは,カー
|
---|
3274 | ネルのターゲット非依存部で初期化ブロックに出力した一般定数式パラメータ
|
---|
3275 | のチェックを行う.kernel_check.tfをインクルードした後,target_check.tf
|
---|
3276 | では,ターゲットに依存するチェックを行う.target_check.tfから,プロセッ
|
---|
3277 | サ依存部,チップ依存部を,開発環境依存部を切り分けてもよい.
|
---|
3278 |
|
---|
3279 | なお,コンフィギュレータの詳細仕様と設定ファイルの記述方法については,
|
---|
3280 | 別途PDFファイルの形で配布している「TOPPERS新世代カーネル用コンフィギュ
|
---|
3281 | レータ仕様」および「TOPPERS新世代カーネル用コンフィギュレータ内蔵マクロ
|
---|
3282 | プロセッサ仕様」を参照すること.
|
---|
3283 |
|
---|
3284 | 7.2 パス2のテンプレートファイルのターゲット依存部
|
---|
3285 |
|
---|
3286 | 以下では,パス2のテンプレートファイルのターゲット依存部を記述する上で必
|
---|
3287 | 要な事項について説明する.
|
---|
3288 |
|
---|
3289 | 7.2.1 ターゲット非依存部をインクルードする前に定義すべき変数
|
---|
3290 |
|
---|
3291 | target.tfからkernel.tfをインクルードする前に,次の変数を定義しておかな
|
---|
3292 | ければならない.
|
---|
3293 |
|
---|
3294 | (7-2-1) INTNO_ATTISR_VALID ATT_ISRで使用できる割込み番号
|
---|
3295 | (7-2-2) INHNO_ATTISR_VALID INTNO_ATTISR_VALIDに対応する割込ハンドラ番号
|
---|
3296 | (7-2-3) INHNO_DEFINH_VALID DEF_INTで使用できる割込みハンドラ番号
|
---|
3297 | (7-2-4) EXCNO_DEFEXC_VALID DEF_EXCで使用できるCPU例外ハンドラ番号
|
---|
3298 | (7-2-5) INTNO_CFGINT_VALID CFG_INTで使用できる割込み番号
|
---|
3299 | (7-2-6) INTPRI_CFGINT_VALID CFG_INTで使用できる割込み優先度
|
---|
3300 |
|
---|
3301 | APIで使用できる割込み番号/割込みハンドラ番号/CPU例外ハンドラ番号/割
|
---|
3302 | 込み優先度のリストを,各変数に定義する.INHNO_ATTISR_VALIDには,
|
---|
3303 | INTNO_ATTISR_VALIDにリストアップした割込み番号に対応する割込みハンドラ
|
---|
3304 | 番号のリストを定義する.CFG_INTには,すべての割込み番号を指定することが
|
---|
3305 | できるため,INTNO_CFGINT_VALIDには,有効な割込み番号をすべてリストアッ
|
---|
3306 | プする.
|
---|
3307 |
|
---|
3308 | (7-2-7) INTNO_FIX_KERNEL(オプション) カーネル管理に固定されている
|
---|
3309 | 割込み番号
|
---|
3310 | (7-2-8) INHNO_FIX_KERNEL(オプション) カーネル管理に固定されている
|
---|
3311 | 割込みハンドラ番号
|
---|
3312 | (7-2-9) INHNO_FIX_NONKERNEL(オプション) カーネル管理外に固定されている
|
---|
3313 | 割込み番号
|
---|
3314 | (7-2-10) INHNO_FIX_NONKERNEL(オプション) カーネル管理外に固定されている
|
---|
3315 | 割込みハンドラ番号
|
---|
3316 |
|
---|
3317 | カーネル管理またはカーネル管理外に固定されている割込みがある場合には,
|
---|
3318 | それらの割込み番号と割込みハンドラ番号のリストを,各変数に定義する.
|
---|
3319 |
|
---|
3320 | (7-2-11) USE_INHINIB_TABLE(オプション)
|
---|
3321 |
|
---|
3322 | OMIT_INITIALIZE_INTERRUPTを定義したが,割込みハンドラの初期化に必要な情
|
---|
3323 | 報をkernel_cfg.cに生成したい場合には,この変数を1に設定する.具体的には,
|
---|
3324 | TNUM_INHNO,tnum_inhno,inhinib_tableの定義と,割込みハンドラ毎の出入口
|
---|
3325 | 処理を生成するための記述(INTHDR_ENTRYマクロのリスト)が,ターゲット非
|
---|
3326 | 依存部によって生成される.
|
---|
3327 |
|
---|
3328 | (7-2-12) USE_INTINIB_TABLE(オプション)
|
---|
3329 |
|
---|
3330 | OMIT_INITIALIZE_INTERRUPTを定義したが,割込み要求ラインの初期化に必要な
|
---|
3331 | 情報をkernel_cfg.cに生成したい場合には,この変数を1に設定する.具体的に
|
---|
3332 | は,TNUM_INTNO,tnum_intno,intinib_tableの定義が,ターゲット非依存部に
|
---|
3333 | よって生成される.
|
---|
3334 |
|
---|
3335 | (7-2-13) GENERATE_TSKINICTXB(オプション)
|
---|
3336 |
|
---|
3337 | USE_TSKINICTXBをマクロ定義した場合,TSKINICTXBの初期化情報を生成するた
|
---|
3338 | めテンプレートファイル関数GENERATE_TSKINICTXBを定義する.
|
---|
3339 | GENERATE_TSKINICTXBには,タスクIDがパラメータとして渡される.
|
---|
3340 |
|
---|
3341 | 7.2.2 ターゲット非依存部で定義される変数
|
---|
3342 |
|
---|
3343 | kernel.tfの中では次の変数が定義されるため,kernel.tfをインクルードした
|
---|
3344 | 後,target.tfの中でこれらを参照することができる.
|
---|
3345 |
|
---|
3346 | (7-3-1) INTNO[inhno] inhnoを対応するintnoに変換するための連想配列
|
---|
3347 | (7-3-2) INHNO[intno] intnoを対応するinhnoに変換するための連想配列
|
---|
3348 |
|
---|
3349 | 7.3 パス3のテンプレートファイルのターゲット依存部
|
---|
3350 |
|
---|
3351 | 以下では,パス3のテンプレートファイルのターゲット依存部を記述する上で必
|
---|
3352 | 要な事項について説明する.
|
---|
3353 |
|
---|
3354 | 7.3.1 ターゲット非依存部をインクルードする前に定義すべき変数
|
---|
3355 |
|
---|
3356 | target_check.tfからkernel_check.tfをインクルードする前に,必要に応じて,
|
---|
3357 | 次の変数を定義しておかなければならない.
|
---|
3358 |
|
---|
3359 | (7-3-1) GET_STK_TSKINICTXB(オプション)
|
---|
3360 |
|
---|
3361 | USE_TSKINICTXBをマクロ定義した場合,TINIBからスタック領域の先頭番地を取
|
---|
3362 | り出すためのテンプレートファイル関数GET_STK_TSKINICTXBを定義する.
|
---|
3363 | GET_STK_TSKINICTXBには,タスク初期化ブロック(TINIB)の先頭番地がパラメー
|
---|
3364 | タとして渡される.CHECK_STACK_ALIGN,CHECK_STACK_NONNULLとも定義しない
|
---|
3365 | 場合には,GET_STK_TSKINICTXBを定義する必要はない.
|
---|
3366 |
|
---|
3367 | 7.3.2 ターゲット依存部で行うべきエラーチェック
|
---|
3368 |
|
---|
3369 | 以下の先頭番地は,ターゲット非依存部で生成するテーブルに出力されないた
|
---|
3370 | め,パス3のターゲット非依存部(kernel_check.tf)では,プログラムの開始
|
---|
3371 | 番地として正しくない場合のエラーをチェックしない.そのため,ターゲット
|
---|
3372 | 依存部でエラーチェックを行う必要がある.
|
---|
3373 |
|
---|
3374 | ・割込みサービスルーチンの先頭番地(ATT_ISRのisr)
|
---|
3375 | ・割込みハンドラの先頭番地(DEF_INHのinthdr)
|
---|
3376 | ・CPU例外ハンドラの先頭番地(DEF_EXCのexchdr)
|
---|
3377 | ・初期化ルーチンの先頭番地(ATT_INIのinirtn)
|
---|
3378 | ・終了処理ルーチンの先頭番地(ATT_TERのterrtn)
|
---|
3379 |
|
---|
3380 | ただし,ターゲット依存部においても,これらのエラーチェックを行えるとは
|
---|
3381 | 限らないため,ユーザーズマニュアルの「1.5 既知の問題」の節には,ターゲッ
|
---|
3382 | ト依存でこれらのエラーが検出されないことがある旨を記載してある.
|
---|
3383 |
|
---|
3384 | 7.4 cfg1_out.cのリンクに必要なスタブの定義ファイル
|
---|
3385 |
|
---|
3386 | コンフィギュレータに関してターゲット依存に用意する必要があるファイルと
|
---|
3387 | して,設定ファイル以外に,cfg1_out.cをリンクするために必要なスタブの定
|
---|
3388 | 義ファイルがある.
|
---|
3389 |
|
---|
3390 | コンフィギュレータのパス1では,静的APIの整数定数式パラメータの値をCコン
|
---|
3391 | パイラを用いて求めるために,cfg1_out.cを生成する.これをコンパイル,リ
|
---|
3392 | ンクしてオブジェクトファイルを生成する際に,スタートアップモジュールか
|
---|
3393 | ら参照されるシンボルの定義を与える必要がある.
|
---|
3394 |
|
---|
3395 | この定義を与えるために,cfg1_out.cから,ターゲット依存部の
|
---|
3396 | target_cfg1_out.hをインクルードしている.target_cfg1_out.h(または,そ
|
---|
3397 | こからインクルードされるファイル)には,スタートアップモジュールから参
|
---|
3398 | 照されるシンボルのスタブの定義を含める.典型的には,以下のような定義を
|
---|
3399 | 含める必要がある.
|
---|
3400 |
|
---|
3401 | ----------------------------------------
|
---|
3402 | void sta_ker(void)
|
---|
3403 | {
|
---|
3404 | }
|
---|
3405 |
|
---|
3406 | void hardware_init_hook(void)
|
---|
3407 | {
|
---|
3408 | }
|
---|
3409 |
|
---|
3410 | void software_init_hook(void)
|
---|
3411 | {
|
---|
3412 | }
|
---|
3413 |
|
---|
3414 | const SIZE _kernel_istksz = 0;
|
---|
3415 |
|
---|
3416 | STK_T *const _kernel_istk = NULL;
|
---|
3417 | ----------------------------------------
|
---|
3418 |
|
---|
3419 | また,コンフィギュレータを用いてオフセットファイル(offset.h)を生成す
|
---|
3420 | る場合には,そのための記述をtarget_cfg1_out.h(または,そこからインクルー
|
---|
3421 | ドされるファイル)に追加する必要がある.詳しくは,「2.5.1 コンフィギュ
|
---|
3422 | レータを用いる方法」の節を参照すること.
|
---|
3423 |
|
---|
3424 |
|
---|
3425 | 8.システムサービス等のターゲット依存部
|
---|
3426 |
|
---|
3427 | 8.0 システムサービスのターゲット依存部
|
---|
3428 |
|
---|
3429 | シリアルポート数やシステムログタスク関連の定数など,システムサービスの
|
---|
3430 | 構成を決定するための定義をtarget_syssvc.hまたはそこからインクルードされ
|
---|
3431 | るファイル(プロセッサ・チップ・開発環境依存部で用意されるヘッダファイ
|
---|
3432 | ルなど)に含める.
|
---|
3433 |
|
---|
3434 | なお,TOPPERS組込みコンポーネントシステムが導入されると,このファイルの
|
---|
3435 | 内容はコンポーネント記述ファイルに記述されることになり,このファイルは
|
---|
3436 | 無くなる(または,大幅に縮小される)見込みである.
|
---|
3437 |
|
---|
3438 | 8.1 システムログ機能のターゲット依存定義
|
---|
3439 |
|
---|
3440 | システムログ機能を使用する場合で,スタートアップモジュールでbssセクショ
|
---|
3441 | ンのクリアを省略している場合には,syslog_logmaskとsyslog_lowmask_notを
|
---|
3442 | 0に初期化するコードを追加する.これは,システムログ機能が初期化される前
|
---|
3443 | に出力されたログ情報を,低レベル出力機能を用いて出力するためである.
|
---|
3444 |
|
---|
3445 | ターゲット依存部で提供すべきシステムログ機能のための定義は次の通りであ
|
---|
3446 | る.
|
---|
3447 |
|
---|
3448 | (8-1-1) TCNT_SYSLOG_BUFFER
|
---|
3449 |
|
---|
3450 | システムログ機能のログバッファのサイズを定義するマクロ.定義しない場合
|
---|
3451 | のデフォルト値は32.
|
---|
3452 |
|
---|
3453 | (8-1-2) void target_fput_log(char_t c)
|
---|
3454 |
|
---|
3455 | システムログの低レベル出力のための文字出力関数.ターゲット依存の方法で,
|
---|
3456 | 文字cを表示/出力/保存する.
|
---|
3457 |
|
---|
3458 | この関数は,リエントラントに実装しなければならない.この関数内で排他制
|
---|
3459 | 御が必要な場合には,SILを用いて全割込みロック状態にすること.また,全割
|
---|
3460 | 込みロック状態で呼ばれる場合があるため,全割込みロック状態から呼び出す
|
---|
3461 | ことができない関数を呼ばないように実装しなければならない.
|
---|
3462 |
|
---|
3463 | 低レベル出力をシリアルポート経由で行う場合で,シリアルインタフェースド
|
---|
3464 | ライバとポートを共用しないことが望ましいが,ポート数が足りないためにや
|
---|
3465 | むをえず共用する場合には,両者が競合しないように注意が必要である.具体
|
---|
3466 | 的には,両者が同じ設定でシリアルI/Oデバイスを使うようにし,シリアルイン
|
---|
3467 | タフェースドライバの動作中に低レベル出力が行われても差し支えないように
|
---|
3468 | 設計する.また,低レベル出力が動作開始後にシリアルインタフェースドライ
|
---|
3469 | バがシリアルI/Oデバイスを初期化すると,文字化けが起こる可能性があるため,
|
---|
3470 | 共用するポートは,低レベル出力機能側で初期化し,シリアルインタフェース
|
---|
3471 | ドライバでは初期化しないようにするとよい.
|
---|
3472 |
|
---|
3473 | なお,この関数の本体を,どのファイルに記述するかが問題になる.システム
|
---|
3474 | サービスのターゲット依存部には,標準では,関数定義を記述するためのファ
|
---|
3475 | イルを用意していない.ターゲット依存で用意してもよいが,例外的に,カー
|
---|
3476 | ネル実装のターゲット依存モジュール(target_config.c)に記述してもよい.
|
---|
3477 | この場合,target_fput_logを,リネーム記述(target_rename.defなど)に含
|
---|
3478 | めてはならない.
|
---|
3479 |
|
---|
3480 | 8.2 ログタスクのターゲット依存定義
|
---|
3481 |
|
---|
3482 | ターゲット依存部で提供すべきログタスクのための定義は次の通りである.こ
|
---|
3483 | れらの定義は,target_syssvc.hまたはそこからインクルードされるファイルに
|
---|
3484 | 含める.
|
---|
3485 |
|
---|
3486 | (8-2-1) LOGTASK_PRIORITY(オプション)
|
---|
3487 |
|
---|
3488 | ログタスクの優先度を定義するマクロ.定義しない場合のデフォルト値は3.
|
---|
3489 |
|
---|
3490 | (8-2-2) LOGTASK_STACK_SIZE(オプション)
|
---|
3491 |
|
---|
3492 | ログタスクのスタックサイズを定義するマクロ.定義しない場合のデフォルト
|
---|
3493 | 値は1024.
|
---|
3494 |
|
---|
3495 | (8-2-3) LOGTASK_PORTID(オプション)
|
---|
3496 |
|
---|
3497 | ログタスクの出力先のシリアルポート番号.定義しない場合のデフォルト値は1.
|
---|
3498 |
|
---|
3499 | (8-2-4) LOGTASK_INTERVAL(オプション)
|
---|
3500 |
|
---|
3501 | ログタスクの動作間隔(単位はミリ秒).定義しない場合のデフォルト値は10.
|
---|
3502 |
|
---|
3503 | (8-2-5) LOGTASK_FLUSH_WAIT(オプション)
|
---|
3504 |
|
---|
3505 | ログ出力を待ち合わせる処理において,タスクを待たせる単位となる時間(単
|
---|
3506 | 位はミリ秒).定義しない場合のデフォルト値は1.
|
---|
3507 |
|
---|
3508 | 8.3 シリアルインタフェースドライバのターゲット依存部
|
---|
3509 |
|
---|
3510 | ターゲット依存部で提供すべきシリアルインタフェースドライバのための定義
|
---|
3511 | は次の通りである.これらの定義は,別に指定がない限り,target_serial.hま
|
---|
3512 | たはそこからインクルードされるファイルに含め,必要なコンフィギュレーショ
|
---|
3513 | ン情報をtarget_serial.cfgに記述する.関数の実体が必要な場合には,
|
---|
3514 | target_serial.c等のファイルを用意する.
|
---|
3515 |
|
---|
3516 | シリアルインタフェースドライバの中で,ターゲットのシリアルI/Oデバイスに
|
---|
3517 | 依存する部分を,シリアルI/Oデバイスドライバと呼ぶ.シリアルI/Oデバイス
|
---|
3518 | ドライバは,おおよそ,ITRONデバイスドライバ設計ガイドラインのPDICに相当
|
---|
3519 | する.PDICに相当するファイルで,他のシステムにも共通に使える可能性があ
|
---|
3520 | る場合には,pdicディレクトリに置く.
|
---|
3521 |
|
---|
3522 | 8.3.1 変数,データ型,管理関数
|
---|
3523 |
|
---|
3524 | (8-3-1-1) TNUM_PORT
|
---|
3525 |
|
---|
3526 | シリアルインタフェースドライバがサポートするシリアルポート数を定義する
|
---|
3527 | マクロ.このマクロの定義は,target_syssvc.hまたはそこからインクルードさ
|
---|
3528 | れるファイルに含める.
|
---|
3529 |
|
---|
3530 | (8-3-1-2) void sio_initialize(intptr_t exinf)(オプション)
|
---|
3531 |
|
---|
3532 | シリアルI/Oデバイスドライバの初期化処理.target_serial.cfgに,この関数
|
---|
3533 | を初期化ルーチンとして登録する静的APIを含める.
|
---|
3534 |
|
---|
3535 | (8-3-1-3) void sio_terminate(intptr_t exinf)(オプション)
|
---|
3536 |
|
---|
3537 | シリアルI/Oデバイスドライバの終了処理.target_serial.cfgに,この関数を
|
---|
3538 | 終了処理ルーチンとして登録する静的APIを含める.
|
---|
3539 |
|
---|
3540 | (8-3-1-4) void sio_isr(intptr_t exinf)
|
---|
3541 |
|
---|
3542 | シリアルI/Oデバイスの割込みサービスルーチン.target_serial.cfgに,この
|
---|
3543 | 関数を割込みサービスルーチンとして登録する静的APIを含める.また,その静
|
---|
3544 | 的APIに必要なシリアルI/Oデバイスの割込み番号などは,target_serial.hでマ
|
---|
3545 | クロ定義する.割込みサービスルーチンではなく,割込みハンドラとすること
|
---|
3546 | もできる.
|
---|
3547 |
|
---|
3548 | (8-3-1-5) SIOPCB
|
---|
3549 |
|
---|
3550 | シリアルI/Oポート管理ブロックのデータ型(target_serial.hには,データ型
|
---|
3551 | の宣言だけ含まれていればよい).
|
---|
3552 |
|
---|
3553 | (8-3-1-6) SIO_RDY_SNDとSIO_RDY_RCV
|
---|
3554 |
|
---|
3555 | 送信可能コールバックの識別番号をSIO_RDY_SNDに,受信通知コールバックの識
|
---|
3556 | 別番号をSIO_RDY_RCVにマクロ定義する.コールバックの禁止/許可を行なうサー
|
---|
3557 | ビスコール(sio_ena_cbrとsio_dis_cbr)で用いる.
|
---|
3558 |
|
---|
3559 | 8.3.2 デバイスサービスルーチン
|
---|
3560 |
|
---|
3561 | 以下のデバイスサービルルーチンは,(少なくとも)シリアルI/Oポートからの
|
---|
3562 | 割込みがマスクされた状態で呼び出される.また,タスクコンテキスト,非タ
|
---|
3563 | スクコンテキストのいずれで呼び出される場合もある(いずれで呼び出されて
|
---|
3564 | も動作するようにしなければならない).
|
---|
3565 |
|
---|
3566 | (8-3-2-1) SIOPCB *sio_opn_por(ID siopid, intptr_t exinf)
|
---|
3567 |
|
---|
3568 | siopidで指定されるシリアルI/Oポートをオープンする関数.exinfはシリアル
|
---|
3569 | I/Oポートに対する拡張情報で,コールバックを呼ぶ時にポートを区別するた
|
---|
3570 | めに渡す.
|
---|
3571 |
|
---|
3572 | (8-3-2-2) void sio_cls_por(SIOPCB *siopcb)
|
---|
3573 |
|
---|
3574 | siopcbで指定されるシリアルI/Oポートをクローズする関数.
|
---|
3575 |
|
---|
3576 | (8-3-2-3) bool_t sio_snd_chr(SIOPCB *siopcb, char_t c)
|
---|
3577 |
|
---|
3578 | siopcbで指定されるシリアルI/Oポートに,cで示される文字を送信する関数.
|
---|
3579 | 文字を送信レジスタに入れた場合にはtrueを,前に送信した文字の送信が終わっ
|
---|
3580 | ていないために,文字を送信レジスタに入れられなかった場合にはfalseを返す.
|
---|
3581 |
|
---|
3582 | (8-3-2-4) int_t sio_rcv_chr(SIOPCB *siopcb)
|
---|
3583 |
|
---|
3584 | siopcbで指定されるシリアルI/Oポートから文字を読む関数.文字を受信してい
|
---|
3585 | た場合,読んだ文字のコードは正の値として返し,文字を受信していない場合
|
---|
3586 | には-1を返す.
|
---|
3587 |
|
---|
3588 | (8-3-2-5) void sio_ena_cbr(SIOPCB *siopcb, uint_t cbrtn)
|
---|
3589 |
|
---|
3590 | siopcbで指定されるシリアルI/Oポートからの,cbrtnで指定されるコールバッ
|
---|
3591 | クを許可する.cbrtnには,SIO_RDY_SNDかSIO_RDY_RCVを指定できる.
|
---|
3592 |
|
---|
3593 | (8-3-2-6) void sio_dis_cbr(SIOPCB *siopcb, uint_t cbrtn)
|
---|
3594 |
|
---|
3595 | siopcbで指定されるシリアルI/Oポートからの,cbrtnで指定されるコールバッ
|
---|
3596 | クを禁止する.cbrtnには,SIO_RDY_SNDかSIO_RDY_RCVを指定できる.
|
---|
3597 |
|
---|
3598 | 8.3.3 コールバックルーチン
|
---|
3599 |
|
---|
3600 | ターゲット依存部は,必要なタイミングで,シリアルインタフェースドライバ
|
---|
3601 | のターゲット非依存部に含まれる以下のコールバックルーチンを呼び出びださ
|
---|
3602 | なければならない.ただし,それぞれのコールバックが禁止されている時は,
|
---|
3603 | コールバックルーチンを呼び出してはならない.
|
---|
3604 |
|
---|
3605 | コールバックルーチンは,(少なくとも)シリアルI/Oポートからの割込みが禁
|
---|
3606 | 止された状態で,非タスクコンテキストで呼び出す.exinfには,シリアルI/O
|
---|
3607 | ポートのオープン時に指定された拡張情報を渡す.
|
---|
3608 |
|
---|
3609 | (8-3-3-1) void sio_irdy_snd(intptr_t exinf)
|
---|
3610 |
|
---|
3611 | 送信可能コールバックルーチン.シリアルI/Oポートに対して文字が送信できる
|
---|
3612 | 状態になった場合に呼び出す.シリアルインタフェースドライバは,このコー
|
---|
3613 | ルバックルーチンの中で,sio_snd_chrを呼び出して次の文字を送信するか,送
|
---|
3614 | 信すべき文字がない場合には送信可能コールバックを禁止する.
|
---|
3615 |
|
---|
3616 | (8-3-3-2) void sio_irdy_rcv(intptr_t exinf)
|
---|
3617 |
|
---|
3618 | 受信通知コールバックルーチン.シリアルI/Oポートから文字を受信した場合に
|
---|
3619 | 呼び出す.シリアルインタフェースドライバは,このコールバックルーチンの
|
---|
3620 | 中で,必ずsio_rcv_chrを呼び出して受信した文字を取り出す.
|
---|
3621 |
|
---|
3622 | 8.4 カーネル起動メッセージの出力のターゲット依存定義
|
---|
3623 |
|
---|
3624 | ターゲット依存部で提供すべきカーネル起動メッセージの出力のための定義は
|
---|
3625 | 次の通りである.
|
---|
3626 |
|
---|
3627 | (8-4-1) TARGET_NAME
|
---|
3628 |
|
---|
3629 | ターゲットの名称に定義する.
|
---|
3630 |
|
---|
3631 | (8-4-2) TARGET_COPYRIGHT(オプション)
|
---|
3632 |
|
---|
3633 | カーネル起動メッセージに,ターゲット依存部の著作権表示を追加するための
|
---|
3634 | マクロ.デフォルトでは,ターゲット依存部の著作権表示を追加しない.
|
---|
3635 |
|
---|
3636 | 8.5 サンプルプログラムとテストプログラムのターゲット依存定義
|
---|
3637 |
|
---|
3638 | ターゲット依存部で提供すべきサンプルプログラムおよびテストプログラムの
|
---|
3639 | ための定義は次の通りである.これらの定義は,target_test.h(またはそれら
|
---|
3640 | からインクルードされるファイル)に含める.
|
---|
3641 |
|
---|
3642 | (8-5-1) STACK_SIZE(オプション)
|
---|
3643 |
|
---|
3644 | サンプルプログラムおよびテストプログラムのタスクのスタックサイズを定義
|
---|
3645 | するマクロ.定義しない場合のデフォルト値は4096.デフォルト設定ではメモ
|
---|
3646 | リが不足する場合や,シミュレーション環境などで大きいスタック領域が必要
|
---|
3647 | な場合には,ターゲット依存部でこのマクロを設定するスタックサイズに定義
|
---|
3648 | する.
|
---|
3649 |
|
---|
3650 | (8-5-2) CPUEXC1(オプション)
|
---|
3651 |
|
---|
3652 | サンプルプログラムおよびテストプログラムで用いるCPU例外のCPU例外ハンド
|
---|
3653 | ラ番号を定義するマクロ.このマクロを定義しない場合,CPU例外ハンドラを使
|
---|
3654 | う部分がサンプルプログラムから除外される.CPU例外ハンドラのテストをする
|
---|
3655 | テストプログラムはコンパイルできない.
|
---|
3656 |
|
---|
3657 | (8-5-3) RAISE_CPU_EXCEPTION(オプション)
|
---|
3658 |
|
---|
3659 | CPUEXC1に定義したCPU例外を発生させるC言語のプログラムを定義するマクロ.
|
---|
3660 | CPUEXC1を定義した場合には必ず定義しなければならない.
|
---|
3661 |
|
---|
3662 | (8-5-4) CANNOT_RETURN_CPUEXC(オプション)
|
---|
3663 |
|
---|
3664 | ターゲットシステムの制約により,CPU例外ハンドラからリターンした後に,タ
|
---|
3665 | スクの実行を継続できない場合に定義するマクロ.このマクロを定義すると,
|
---|
3666 | CPU例外ハンドラのテストをするテストプログラムから,CPU例外ハンドラから
|
---|
3667 | リターンした後の処理が除外される.サンプルプログラムの該当部分は正しく
|
---|
3668 | 動作しない.
|
---|
3669 |
|
---|
3670 | (8-5-5) TASK_PORTID(オプション)
|
---|
3671 |
|
---|
3672 | サンプルプログラムにおいて,コマンド文字を読み込むシリアルポート番号を
|
---|
3673 | 定義するマクロ.定義しない場合のデフォルト値は1.
|
---|
3674 |
|
---|
3675 | (8-5-6) LOOP_REF(オプション)
|
---|
3676 |
|
---|
3677 | サンプルプログラムにおいて,プロセッサの速度を計測するためのループ回数
|
---|
3678 | を定義するマクロ.定義しない場合のデフォルト値は1000000.デフォルト設定
|
---|
3679 | では,値が大き過ぎて計測に時間がかかりすぎる場合や,値が小さ過ぎて計測
|
---|
3680 | 結果が安定しない場合に,ターゲット依存部でこのマクロを設定するループ回
|
---|
3681 | 数に定義する.
|
---|
3682 |
|
---|
3683 | (8-5-7) MEASURE_TWICE(オプション)
|
---|
3684 |
|
---|
3685 | サンプルプログラムにおいて,プロセッサの速度を2度計測する場合に定義する
|
---|
3686 | マクロ.シミュレーション環境などプロセッサの速度が変動する環境で,1度の
|
---|
3687 | 計測では計測結果が安定しない場合に定義する.
|
---|
3688 |
|
---|
3689 | (8-5-8) TASK_LOOP(オプション)
|
---|
3690 |
|
---|
3691 | サンプルプログラムにおいて,プロセッサの速度を計測せずに,タスク内での
|
---|
3692 | ループ回数を固定する場合に,ループ回数を定義するマクロ.ループ全体の実
|
---|
3693 | 行時間が0.4秒程度になるようなループ回数を,このマクロに定義する.
|
---|
3694 |
|
---|
3695 | 8.6 実行時間分布集計モジュールのターゲット依存定義
|
---|
3696 |
|
---|
3697 | 実行時間分布集計モジュールの設定をターゲット依存部で変更する場合に,ター
|
---|
3698 | ゲット依存部で提供すべき実行時間分布集計モジュールのための定義は次の通
|
---|
3699 | りである.これらの定義は,target_test.h(またはそこからインクルードされ
|
---|
3700 | るファイル)に含める.この他に,ターゲット依存で必要な初期化処理がある
|
---|
3701 | 場合にも,ターゲット依存部に含める.
|
---|
3702 |
|
---|
3703 | (8-6-1) HISTTIM(オプション)
|
---|
3704 |
|
---|
3705 | 実行時間計測用の時刻のデータ型を定義するマクロ.定義しない場合のデフォ
|
---|
3706 | ルトはSYSUTM.
|
---|
3707 |
|
---|
3708 | (8-6-2) void HIST_GET_TIM(HISTTIM *p_time)(オプション)
|
---|
3709 |
|
---|
3710 | 実行時間計測用の現在時刻を*p_timeに取得する処理に定義するマクロ.定義し
|
---|
3711 | ない場合のデフォルトはget_utm.
|
---|
3712 |
|
---|
3713 | (8-6-3) uint_t HIST_CONV_TIM(HISTTIM time)(オプション)
|
---|
3714 |
|
---|
3715 | 実行時間計測用の時刻の差(時間)を,実行時間分布集計用の値に変換する処
|
---|
3716 | 理に定義するマクロ.時刻が過去に戻ったかオーバフローしたかの区別がつか
|
---|
3717 | ない場合には,最上位ビットが1の値(INT_MAXよりも大きい値)を返す.定義
|
---|
3718 | しない場合のデフォルトは,timeをuint_tにキャストする処理.
|
---|
3719 |
|
---|
3720 | (8-6-4) void HIST_BM_HOOK(void)(オプション)
|
---|
3721 |
|
---|
3722 | 実行時間計測直前に行うべき処理に定義するマクロ.キャッシュのパージやフィ
|
---|
3723 | ル,メモリバリア処理等を行いたい場合には,このマクロに定義する.定義し
|
---|
3724 | ない場合のデフォルトは,空の処理になる.
|
---|
3725 |
|
---|
3726 |
|
---|
3727 | 9.その他
|
---|
3728 |
|
---|
3729 | 9.1 ドキュメント
|
---|
3730 |
|
---|
3731 | ターゲット依存部のユーザーズマニュアルを,target_user.txtに用意する.プ
|
---|
3732 | ロセッサ・チップ・開発環境依存部のユーザーズマニュアルを切り分けてもよ
|
---|
3733 | いし,ファイルが大きくなる場合には複数のファイルに分割してよいが,その
|
---|
3734 | 場合には,target_user.txt中にそれらのファイル名を記述すること.
|
---|
3735 |
|
---|
3736 | ターゲット依存部のユーザーズマニュアルには,少なくとも次のような内容を
|
---|
3737 | 記述することが望ましい.
|
---|
3738 |
|
---|
3739 | (1) 対応しているターゲットシステムの種類・構成,バージョン番号
|
---|
3740 | ・ターゲットハードウェア(ボード等)の名称と対応している構成
|
---|
3741 | ・ターゲット略称
|
---|
3742 | ・ターゲット非依存部のバージョン番号
|
---|
3743 | ・プロセッサ,チップ,開発環境依存部の構成とバージョン番号
|
---|
3744 | ・使用するPDICとバージョン番号
|
---|
3745 |
|
---|
3746 | (2) 使用する開発環境と動作検証した条件(バージョン,オプション等)
|
---|
3747 | ・言語処理系(コンパイラ,アセンブラ,リンカ等)
|
---|
3748 | ・デバッグ環境
|
---|
3749 |
|
---|
3750 | (3) ターゲット定義事項の規定
|
---|
3751 |
|
---|
3752 | (3-1) データ型に関する規定
|
---|
3753 | ・int_t型,long_t型のサイズ
|
---|
3754 | ・char_t型,int_least8_t型,void *型,intptr_t型のサイズ
|
---|
3755 | ・int8_t型,uint8_t型,int64_t型,uint64_t型,int128_t型,
|
---|
3756 | uint128_t型,float32_t型,double64_t型のサポートの有無
|
---|
3757 |
|
---|
3758 | (3-2) 割込み処理に関する規定
|
---|
3759 | ・割込みハンドラ番号と割込み番号の割当て,両者の対応
|
---|
3760 | ・割込み優先度の段階数(TMIN_INTPRIの値)
|
---|
3761 | ・dis_intとena_intのサポートの有無,その制限事項
|
---|
3762 | ・CFG_INTの制限事項と拡張(ターゲット定義で使用できる割込み属性)
|
---|
3763 | ・TOPPERS標準割込み処理モデルからのその他の逸脱
|
---|
3764 |
|
---|
3765 | (3-3) カーネル管理外の割込みに関する規定
|
---|
3766 | ・TMIN_INTPRIは固定か設定できるか,その設定方法
|
---|
3767 | ・NMI以外にカーネル管理外の割込みを設けるか(設けられるようにするか)
|
---|
3768 | ・カーネル管理外の割込みの設定方法
|
---|
3769 | ・カーネル管理外の割込みに対してDEF_INH,CFG_INTをサポートするか
|
---|
3770 | ・カーネル管理外の割込みハンドラが実行開始される時のシステム状態と
|
---|
3771 | コンテキスト
|
---|
3772 | ・割込みハンドラの終了時に行われる処理
|
---|
3773 | ・カーネル管理外の割込みハンドラの記述方法
|
---|
3774 | ・カーネル内の割込み出入口処理で起こる可能性のあるCPU例外
|
---|
3775 |
|
---|
3776 | (3-4) CPU例外処理に関する規定
|
---|
3777 | ・CPU例外ハンドラ番号の割当て
|
---|
3778 | ・割込み優先度マスクをTMIN_INTPRIと同じかそれよりも高い値に設定して
|
---|
3779 | いる状態で発生したCPU例外を,カーネル管理外のCPU例外と扱うか
|
---|
3780 | ・カーネル内のCPU例外出入口処理で起こる可能性のあるCPU例外
|
---|
3781 |
|
---|
3782 | (3-5) 性能評価用システム時刻の参照に関する規定
|
---|
3783 | ・get_utmのサポートの有無,その制限事項
|
---|
3784 |
|
---|
3785 | (3-6) 拡張パッケージに関する規定
|
---|
3786 | ・各拡張パッケージのサポートの有無
|
---|
3787 | - ミューテックス機能拡張パッケージ
|
---|
3788 | - オーバランハンドラ機能拡張パッケージ
|
---|
3789 | - タスク優先度拡張パッケージ
|
---|
3790 | - 制約タスク拡張パッケージ
|
---|
3791 | - 動的生成機能拡張パッケージ
|
---|
3792 | ・オーバランハンドラ機能拡張パッケージをサポートする場合に,プロセッ
|
---|
3793 | サ時間に指定できる値の最大値(TMAX_OVRTIMの値)
|
---|
3794 | ・動的生成機能拡張パッケージをサポートする場合に,動的メモリ管理の
|
---|
3795 | 方法
|
---|
3796 |
|
---|
3797 | (3-7) その他
|
---|
3798 | ・その他の制限事項
|
---|
3799 | ・その他の拡張機能
|
---|
3800 |
|
---|
3801 | (4) カーネルの起動/終了処理に関する情報
|
---|
3802 | ・用意しているスタートアップモジュールの処理内容
|
---|
3803 | ・スタートアップモジュールからhardware_init_hookを呼び出している場
|
---|
3804 | 合には,hardware_init_hookをアプリケーションで用意する場合の作成
|
---|
3805 | 方法や制限事項など
|
---|
3806 | ・カーネルを終了した後の振舞い
|
---|
3807 |
|
---|
3808 | (5) メモリマップ
|
---|
3809 | ・デフォルトのメモリマップ,その変更方法
|
---|
3810 |
|
---|
3811 | (6) タイマドライバ関連の情報
|
---|
3812 | ・タイムティックの周期,その変更方法
|
---|
3813 | ・使用するリソース(タイマ)
|
---|
3814 | ・タイマ割込みの割込み優先度の変更方法
|
---|
3815 | ・オーバランタイマ割込みの割込み優先度の変更方法
|
---|
3816 |
|
---|
3817 | (7) シリアルインタフェースドライバの情報
|
---|
3818 | ・使用するリソース(SIOコントローラ)
|
---|
3819 | ・通信パラメータ(ボーレート,ビット数,パリティの有無,ストップビット)
|
---|
3820 |
|
---|
3821 | (8) システムログ機能の情報
|
---|
3822 | ・システムログの低レベル出力の実現方法
|
---|
3823 | ・通信パラメータ(ボーレート,ビット数,パリティの有無,ストップビット)
|
---|
3824 |
|
---|
3825 | (9) システム構築手順
|
---|
3826 |
|
---|
3827 | (10) ターゲットシステム固有の注意事項
|
---|
3828 | ・タスクコンテキストに含まれるレジスタ,含まれないレジスタ
|
---|
3829 |
|
---|
3830 | (11) 類似のターゲットにポーティングする開発者向けの参考情報
|
---|
3831 |
|
---|
3832 | (12) ディレクトリ構成・ファイル構成
|
---|
3833 |
|
---|
3834 | (13) バージョン履歴
|
---|
3835 |
|
---|
3836 | また,必要に応じて,ターゲット依存部の設計メモを,target_design.txtに用
|
---|
3837 | 意する.プロセッサ・チップ・開発環境依存部に関する設計メモを切り分けて
|
---|
3838 | もよいし,ファイルが大きくなる場合には複数のファイルに分割してもよいが,
|
---|
3839 | その場合には,target_design.txt中にそれらのファイル名を記述すること.
|
---|
3840 |
|
---|
3841 | 9.2 パッケージ記述ファイル
|
---|
3842 |
|
---|
3843 | リリースパッケージ(個別パッケージおよび簡易パッケージ)を作成するため
|
---|
3844 | に,パッケージに含めるファイルを記述したパッケージ記述ファイルを用意す
|
---|
3845 | る.パッケージ記述ファイルの名称は,個別パッケージ用をMANIFEST,簡易パッ
|
---|
3846 | ケージ用をE_PACKAGEとする.
|
---|
3847 |
|
---|
3848 | 例えば,arch/arm_gccディレクトリに置かれたMANIFESTファイルを用いて個別
|
---|
3849 | パッケージを作成する場合には,次のコマンドを実行する.
|
---|
3850 |
|
---|
3851 | % utils/makerelease arch/arm_gcc/MANIFEST
|
---|
3852 |
|
---|
3853 | このコマンドにより,RELEASE/asp_arch_arm_gcc-<バージョン番号>.tar.gzが
|
---|
3854 | 作成される.また,target/at91skyeye_gccディレクトリに置かれたE_PACKAGE
|
---|
3855 | ファイルを用いて簡易パッケージを作成する場合には,次のコマンドを実行す
|
---|
3856 | る.
|
---|
3857 |
|
---|
3858 | % utils/makerelease target/at91skyeye_gcc/E_PACKAGE
|
---|
3859 |
|
---|
3860 | このコマンドにより,RELEASE/asp_at91skyeye_gcc-<バージョン番号>.tar.gz
|
---|
3861 | が作成される(RELEASEディレクトリがない場合には,ディレクトリが作られ
|
---|
3862 | る).
|
---|
3863 |
|
---|
3864 | なお,makereleaseユーティリティは,ASPカーネルのソースファイルが置かれ
|
---|
3865 | たディレクトリが,aspという名称であることを仮定している(異なる名称の場
|
---|
3866 | 合でもパッケージは作成できるが,パッケージを展開した時に展開されるディ
|
---|
3867 | レクトリがaspでなくなる).また,標準のtarコマンドがGNU tarであること
|
---|
3868 | (正確には,zオプションに対応していること)を想定している.
|
---|
3869 |
|
---|
3870 | パッケージ記述ファイルには,パッケージに含めるファイル名を,パッケージ
|
---|
3871 | 記述ファイルが置かれたディレクトリからの相対パス名で,1行に1つずつ記述
|
---|
3872 | する.また,必要に応じて,以下のディレクティブを含める.
|
---|
3873 |
|
---|
3874 | (a) E_PACKAGE <簡易パッケージ名>
|
---|
3875 |
|
---|
3876 | 簡易パッケージ名を指定する.簡易パッケージ記述ファイル(E_PACKAGE)の先
|
---|
3877 | 頭に記述する.簡易パッケージ名は,asp_<ターゲット略称>とする.例えば,
|
---|
3878 | ターゲット略称がat91skyeye_gccの場合には,asp_at91skyeye_gccとなる.個
|
---|
3879 | 別パッケージと区別するために,簡易パッケージのファイル名には"target"を
|
---|
3880 | 含めない.
|
---|
3881 |
|
---|
3882 | (b) PACKAGE <個別パッケージ名>
|
---|
3883 |
|
---|
3884 | 個別パッケージ名を指定する.個別パッケージ記述ファイル(MANIFEST)の先
|
---|
3885 | 頭に記述する.また,そこからインクルードされる各ファイルの先頭にも記述
|
---|
3886 | し,それをインクルードしている個別パッケージ名を指定する.ターゲット依
|
---|
3887 | 存部の個別パッケージ名は,個別パッケージ記述ファイルが置かれたディレク
|
---|
3888 | トリの相対パス中の"/"を"_"に置き換えた文字列を,"asp_"の後につなげたも
|
---|
3889 | のとする.例えば,個別パッケージ記述ファイルがarch/arm_gcc/MANIFESTの場
|
---|
3890 | 合には,asp_arch_arm_gccとなる.
|
---|
3891 |
|
---|
3892 | (c) VERSION <バージョン番号>
|
---|
3893 |
|
---|
3894 | パッケージのバージョン番号を指定する.簡易パッケージ記述ファイルおよび
|
---|
3895 | 個別パッケージ記述ファイルの中に記述する.簡易パッケージにおいて,バー
|
---|
3896 | ジョン番号をパッケージ化した日付とする場合には,パッケージ番号の代わり
|
---|
3897 | に%dateと記述する.
|
---|
3898 |
|
---|
3899 | バージョン番号の付与方法については,「TOPPERS/ASPカーネル ユーザーズマ
|
---|
3900 | ニュアル」の「2.2 簡易パッケージ」および「2.3 個別パッケージ」の節を参
|
---|
3901 | 照すること.
|
---|
3902 |
|
---|
3903 | (d) INCLUDE <ファイル名>
|
---|
3904 |
|
---|
3905 | 別のパッケージ記述ファイルをインクルードする.簡易パッケージ記述ファイ
|
---|
3906 | ルからは,個別パッケージ記述ファイルのみをインクルードするのを原則とす
|
---|
3907 | る.個別パッケージ記述ファイルからインクルードされるファイル中で指定さ
|
---|
3908 | れる個別パッケージ名は,すべて一致していなければならない.
|
---|
3909 |
|
---|
3910 |
|
---|
3911 | 10.リファレンス
|
---|
3912 |
|
---|
3913 | 10.1 ターゲット依存部のファイル一覧
|
---|
3914 |
|
---|
3915 | 標準的なターゲット依存部のファイル構成は次の通りである.
|
---|
3916 |
|
---|
3917 | Makefile.target Makefileのターゲット依存部(2章).
|
---|
3918 | target_offset.tf オフセットファイル生成用テンプレートファイル(2.5.1節,
|
---|
3919 | オプション)
|
---|
3920 |
|
---|
3921 | target_stddef.h TOPPERS共通定義(t_stddef.h)のターゲット依存部(3
|
---|
3922 | 章).アプリケーションとカーネルの両方からインクルー
|
---|
3923 | ドされる.
|
---|
3924 | target_sil.h システムインタフェースレイヤ(sil.h)のターゲット依
|
---|
3925 | 存部(4章).アプリケーションとカーネルの両方から
|
---|
3926 | インクルードされる.
|
---|
3927 | target_kernel.h カーネルAPI(kernel.h)のターゲット依存部(5章).
|
---|
3928 | アプリケーションとカーネルの両方からインクルードさ
|
---|
3929 | れる.
|
---|
3930 |
|
---|
3931 | target_config.h カーネル実装のターゲット依存部のヘッダファイル(6
|
---|
3932 | 章).カーネルのみからインクルードされる.
|
---|
3933 | target_config.c カーネル実装のターゲット依存部のC言語で記述される
|
---|
3934 | 部分(6章,オプション).
|
---|
3935 | target_support.S カーネル実装のターゲット依存部のアセンブリ言語で記
|
---|
3936 | 述される部分(6章,オプション).
|
---|
3937 | target_rename.def カーネル実装のターゲット依存部のためのリネーム記述
|
---|
3938 | (6.12節).
|
---|
3939 | target_rename.h target_rename.defから生成されるファイル(6.12節).
|
---|
3940 | target_unrename.h target_rename.defから生成されるファイル(6.12節).
|
---|
3941 | target_timer.cfg タイマドライバのシステムコンフィギュレーションファ
|
---|
3942 | イル(6.13節).
|
---|
3943 | target_timer.h タイマドライバのヘッダファイル(6.13節).カーネル
|
---|
3944 | のみからインクルードされる.
|
---|
3945 | target_timer.c タイマドライバの実装ファイル(6.13節,オプション).
|
---|
3946 | システム略称.h ターゲットのハードウェア資源(割込みハンドラ番号や
|
---|
3947 | CPU例外ハンドラ番号,デバイスレジスタの番地など)の
|
---|
3948 | 定義を含むヘッダファイル.アプリケーションとカーネ
|
---|
3949 | ルの両方からインクルードされる(6章,オプション).
|
---|
3950 |
|
---|
3951 | target_def.csv コンフィギュレータの値取得シンボルテーブルのターゲッ
|
---|
3952 | ト依存部(7章,オプション).
|
---|
3953 | target.tf コンフィギュレータのパス2のテンプレートファイルの
|
---|
3954 | ターゲット依存部(7.2節).
|
---|
3955 | target_check.tf コンフィギュレータのパス3のテンプレートファイル(7.3
|
---|
3956 | 節).
|
---|
3957 | target_cfg1_out.h cfg1_out.cのリンクに必要なスタブの定義ファイル(7.4
|
---|
3958 | 節).
|
---|
3959 |
|
---|
3960 | target_syssvc.h システムサービスのターゲット依存定義(8.0節).
|
---|
3961 | target_serial.cfg シリアルドライバのシステムコンフィギュレーションファ
|
---|
3962 | イル(8.3節).
|
---|
3963 | target_serial.h シリアルドライバのヘッダファイル(8.3節).シリアル
|
---|
3964 | ドライバのみからインクルードされる.
|
---|
3965 | target_serial.c シリアルドライバの実装ファイル(8.3節,オプション).
|
---|
3966 | target_test.h テストプログラムのターゲット依存定義(8.4節).
|
---|
3967 |
|
---|
3968 | target_user.txt ユーザーズマニュアル(9.1節)
|
---|
3969 | target_design.txt 設計メモ(9.1節,オプション)
|
---|
3970 | MANIFEST 個別パッケージに含めるファイルのリスト(9.2節,オプ
|
---|
3971 | ション)
|
---|
3972 | E_PACKAGE 簡易パッケージに含めるファイルのリスト(9.2節,オプ
|
---|
3973 | ション)
|
---|
3974 |
|
---|
3975 | 以上
|
---|