source: azure_iot_hub_riscv/trunk/asp_baseplatform/test/test_cpuexc7.c@ 453

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

ファイルを追加

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-csrc;charset=UTF-8
File size: 6.2 KB
Line 
1/*
2 * TOPPERS Software
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 *
5 * Copyright (C) 2007-2013 by Embedded and Real-Time Systems Laboratory
6 * Graduate School of Information Science, Nagoya Univ., JAPAN
7 *
8 * 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
9 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
10 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
11 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
12 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
13 * スコード中に含まれていること.
14 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
15 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
16 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
17 * の無保証規定を掲載すること.
18 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
19 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
20 * と.
21 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
22 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
23 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
24 * 報告すること.
25 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
26 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
27 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
28 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
29 * 免責すること.
30 *
31 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
32 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
33 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
34 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
35 * の責任を負わない.
36 *
37 * $Id$
38 */
39
40/*
41 * CPU例外処理のテスト(7)
42 *
43 * 【テストの目的】
44 *
45 * 割込み優先度マスク=TIPM_ENAALL,ディスパッチ禁止状態,タスク例外許
46 * 可状態で発生したCPU例外におけるシステム状態のテスト.タスク例外によ
47 * りリカバリーできることもテストする.
48 *
49 * 【テスト項目】
50 *
51 * いずれも,割込み優先度マスク=TIPM_ENAALL,ディスパッチ禁止状態,タ
52 * スク例外許可状態で発生したCPU例外において,
53 *
54 * (A) CPU例外ハンドラ実行開始時にCPUロックフラグが変化しないこと
55 * (B) CPU例外ハンドラ実行開始時に割込み優先度マスクが変化しないこと
56 * !CPU例外ハンドラ中で割込み優先度マスクを読めないため,テストで
57 * きない.
58 * (C) CPU例外ハンドラ実行開始時にディスパッチ禁止フラグが変化しないこと
59 * (D) CPU例外ハンドラ実行開始時にタスク例外処理禁止フラグが変化しないこと
60 * (E) CPU例外ハンドラリターン時にCPUロックフラグが元に戻ること
61 * (F) CPU例外ハンドラリターン時に割込み優先度マスクが元に戻ること
62 * (G) CPU例外ハンドラリターン時にディスパッチ禁止フラグが変化しないこと
63 * (H) CPU例外ハンドラリターン時にタスク例外処理禁止フラグが変化しないこと
64 * (I) xsns_xpnがfalseを返すこと
65 * (J) xsns_dpnがtrueを返すこと
66 * (L) タスク例外によるリカバリーができること
67 *
68 * 【使用リソース】
69 *
70 * TASK1: TA_ACT,中優先度,タスク例外処理ルーチン登録
71 * CPUEXC1: TA_NULL
72 *
73 * 【テストシーケンス】
74 *
75 * == TASK1(中優先度,1回目)==
76 * 1: 状態のチェック
77 * dis_dsp()
78 * ena_tex()
79 * 2: 状態のチェック
80 * RAISE_CPU_EXCEPTION
81 * == CPUEXC1 ==
82 * 3: 状態のチェック ... (A),(C),(D)
83 * xsns_xpn() == false ... (I)
84 * xsns_dpn() == true ... (J)
85 * 4: iras_tex(TASK1, 1U)
86 * iloc_cpu()
87 * リターン
88 * == TASK1のタスク例外処理ルーチン ==
89 * 5: 状態のチェック ... (E),(F),(G),(H)
90 * 6: act_tsk(TASK1) ... (L)
91 * 7: ext_tsk() ... (L)
92 * == TASK1(中優先度,2回目)==
93 * 8: 状態のチェック ... (L)
94 * 9: テスト終了
95 */
96
97#include <kernel.h>
98#include <test_lib.h>
99#include <t_syslog.h>
100#include "kernel_cfg.h"
101#include "test_cpuexc.h"
102
103int_t task1_count = 0;
104
105void
106task1(intptr_t exinf)
107{
108 ER ercd;
109
110 switch (++task1_count) {
111 case 1:
112 test_start(__FILE__);
113
114 check_point(1);
115 check_state(false, false, TIPM_ENAALL, false, false, true);
116 ercd = dis_dsp();
117 check_ercd(ercd, E_OK);
118 ercd = ena_tex();
119 check_ercd(ercd, E_OK);
120
121 check_point(2);
122 check_state(false, false, TIPM_ENAALL, true, true, false);
123 RAISE_CPU_EXCEPTION;
124
125 check_point(0);
126 break;
127
128 case 2:
129 check_point(8);
130 check_state(false, false, TIPM_ENAALL, false, false, true);
131
132 check_finish(9);
133 break;
134
135 default:
136 check_point(0);
137 break;
138 }
139}
140
141void
142tex_task1(TEXPTN texptn, intptr_t exinf)
143{
144 ER ercd;
145
146 check_point(5);
147 check_state(false, false, TIPM_ENAALL, true, true, true);
148
149 check_point(6);
150 ercd = act_tsk(TASK1);
151 check_ercd(ercd, E_OK);
152
153 check_point(7);
154 ercd = ext_tsk();
155 check_ercd(ercd, E_OK);
156
157 check_point(0);
158}
159
160void
161task2(intptr_t exinf)
162{
163 check_point(0);
164}
165
166void
167alarm1_handler(intptr_t exinf)
168{
169 check_point(0);
170}
171
172void
173cpuexc_handler(void *p_excinf)
174{
175 ER ercd;
176
177 check_point(3);
178 check_state_i(true, false, true, true, false);
179 check_assert(xsns_xpn(p_excinf) == false);
180 check_assert(xsns_dpn(p_excinf) == true);
181
182 check_point(4);
183 ercd = iras_tex(TASK1, 1U);
184 check_ercd(ercd, E_OK);
185 ercd = iloc_cpu();
186 check_ercd(ercd, E_OK);
187}
Note: See TracBrowser for help on using the repository browser.