source: asp_ewarm/asp-1.7.0/test/test_cpuexc7.c@ 61

Last change on this file since 61 was 61, checked in by ertl-honda, 11 years ago

ASP for EWARM のコミット.

File size: 5.2 KB
Line 
1/*
2 * TOPPERS Software
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 *
5 * Copyright (C) 2007-2009 by Embedded and Real-Time Systems Laboratory
6 * Graduate School of Information Science, Nagoya Univ., JAPAN
7 *
8 * ã‹L’˜ìŒ ŽÒ‚́CˆÈ‰º‚Ì(1)`(4)‚ÌðŒ‚ð–ž‚½‚·ê‡‚ÉŒÀ‚èC–{ƒ\ƒtƒgƒEƒF
9 * ƒAi–{ƒ\ƒtƒgƒEƒFƒA‚ð‰ü•Ï‚µ‚½‚à‚Ì‚ðŠÜ‚ށDˆÈ‰º“¯‚¶j‚ðŽg—pE•¡»E‰ü
10 * •ÏEÄ”z•ziˆÈ‰ºC—˜—p‚ƌĂԁj‚·‚邱‚Ƃ𖳏ž‚Å‹–‘ø‚·‚éD
11 * (1) –{ƒ\ƒtƒgƒEƒFƒA‚ðƒ\[ƒXƒR[ƒh‚ÌŒ`‚Å—˜—p‚·‚éê‡‚ɂ́Cã‹L‚Ì’˜ì
12 * Œ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’肪C‚»‚Ì‚Ü‚Ü‚ÌŒ`‚Ń\[
13 * ƒXƒR[ƒh’†‚ÉŠÜ‚Ü‚ê‚Ä‚¢‚邱‚ƁD
14 * (2) –{ƒ\ƒtƒgƒEƒFƒA‚ðCƒ‰ƒCƒuƒ‰ƒŠŒ`Ž®‚ȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
15 * —p‚Å‚«‚éŒ`‚ōĔz•z‚·‚éê‡‚ɂ́CÄ”z•z‚É”º‚¤ƒhƒLƒ…
16ƒƒ“ƒgi—˜—p
17 * ŽÒƒ}ƒjƒ…
18ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L
19 * ‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
20 * (3) –{ƒ\ƒtƒgƒEƒFƒA‚ðC‹@Ší‚É‘g‚ݍž‚ނȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
21 * —p‚Å‚«‚È‚¢Œ`‚ōĔz•z‚·‚éê‡‚ɂ́CŽŸ‚Ì‚¢‚¸‚ê‚©‚ÌðŒ‚ð–ž‚½‚·‚±
22 * ‚ƁD
23 * (a) Ä”z•z‚É”º‚¤ƒhƒLƒ…
24ƒƒ“ƒgi—˜—pŽÒƒ}ƒjƒ…
25ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜
26 * ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
27 * (b) Ä”z•z‚ÌŒ`‘Ô‚ðC•Ê‚É’è‚ß‚é•û–@‚É‚æ‚Á‚āCTOPPERSƒvƒƒWƒFƒNƒg‚É
28 * •ñ‚·‚邱‚ƁD
29 * (4) –{ƒ\ƒtƒgƒEƒFƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚é‚¢‚©‚Ȃ鑹
30 * ŠQ‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð–Ɛӂ·‚邱‚ƁD
31 * ‚Ü‚½C–{ƒ\ƒtƒgƒEƒFƒA‚̃†[ƒU‚Ü‚½‚̓Gƒ“ƒhƒ†[ƒU‚©‚ç‚Ì‚¢‚©‚Ȃ闝
32 * —R‚ÉŠî‚­¿‹‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð
33 * –Ɛӂ·‚邱‚ƁD
34 *
35 * –{ƒ\ƒtƒgƒEƒFƒA‚́C–³•ÛØ‚Å’ñ‹Ÿ‚³‚ê‚Ä‚¢‚é‚à‚Ì‚Å‚ ‚éDã‹L’˜ìŒ ŽÒ‚¨
36 * ‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚́C–{ƒ\ƒtƒgƒEƒFƒA‚ÉŠÖ‚µ‚āC“Á’è‚ÌŽg—p–Ú“I
37 * ‚ɑ΂·‚é“K‡«‚àŠÜ‚߂āC‚¢‚©‚È‚é•ÛØ‚às‚í‚È‚¢D‚Ü‚½C–{ƒ\ƒtƒgƒEƒF
38 * ƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚½‚¢‚©‚Ȃ鑹ŠQ‚ÉŠÖ‚µ‚Ä‚àC‚»
39 * ‚̐ӔC‚𕉂í‚È‚¢D
40 *
41 * @(#) $Id: test_cpuexc7.c 1577 2009-05-31 14:30:51Z ertl-hiro $
42 */
43
44/*
45 * CPU—áŠOˆ—‚̃eƒXƒg(7)
46 *
47 * yƒeƒXƒg‚Ì–Ú“Iz
48 *
49 * Š„ž‚Ý—Dæ“xƒ}ƒXƒNTIPM_ENAALLCƒfƒBƒXƒpƒbƒ`‹ÖŽ~ó‘ԁCƒ^ƒXƒN—áŠO‹–
50 * ‰Âó‘Ô‚Å”­¶‚µ‚½CPU—áŠO‚É‚¨‚¯‚éƒVƒXƒeƒ€ó‘Ԃ̃eƒXƒgDƒ^ƒXƒN—áŠO‚É‚æ
51 * ‚胊ƒJƒoƒŠ[‚Å‚«‚邱‚Æ‚àƒeƒXƒg‚·‚éD
52 *
53 * yƒeƒXƒg€–ځz
54 *
55 * ‚¢‚¸‚ê‚àCŠ„ž‚Ý—Dæ“xƒ}ƒXƒNTIPM_ENAALLCƒfƒBƒXƒpƒbƒ`‹ÖŽ~ó‘ԁCƒ^
56 * ƒXƒN—áŠO‹–‰Âó‘Ô‚Å”­¶‚µ‚½CPU—áŠO‚É‚¨‚¢‚āC
57 *
58 * (A) CPU—áŠOƒnƒ“ƒhƒ‰ŽÀsŠJŽnŽž‚ÉCPUƒƒbƒNƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
59 * (B) CPU—áŠOƒnƒ“ƒhƒ‰ŽÀsŠJŽnŽž‚ÉŠ„ž‚Ý—Dæ“xƒ}ƒXƒN‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
60 * ICPU—áŠOƒnƒ“ƒhƒ‰’†‚ÅŠ„ž‚Ý—Dæ“xƒ}ƒXƒN‚ð“Ç‚ß‚È‚¢‚½‚߁CƒeƒXƒg‚Å
61 * ‚«‚È‚¢D
62 * (C) CPU—áŠOƒnƒ“ƒhƒ‰ŽÀsŠJŽnŽž‚ɃfƒBƒXƒpƒbƒ`‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
63 * (D) CPU—áŠOƒnƒ“ƒhƒ‰ŽÀsŠJŽnŽž‚Ƀ^ƒXƒN—áŠOˆ—‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
64 * (E) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚ÉCPUƒƒbƒNƒtƒ‰ƒO‚ªŒ³‚ɖ߂邱‚Æ
65 * (F) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚ÉŠ„ž‚Ý—Dæ“xƒ}ƒXƒN‚ªŒ³‚ɖ߂邱‚Æ
66 * (G) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚ɃfƒBƒXƒpƒbƒ`‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
67 * (H) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚Ƀ^ƒXƒN—áŠOˆ—‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
68 * (I) xsns_xpn‚ªfalse‚ð•Ô‚·‚±‚Æ
69 * (J) xsns_dpn‚ªtrue‚ð•Ô‚·‚±‚Æ
70 * (L) ƒ^ƒXƒN—áŠO‚É‚æ‚郊ƒJƒoƒŠ[‚ª‚Å‚«‚邱‚Æ
71 *
72 * yŽg—pƒŠƒ\[ƒXz
73 *
74 * TASK1: TA_ACTC’†—Dæ“xCƒ^ƒXƒN—áŠOˆ—ƒ‹[ƒ`ƒ““o˜^
75 * CPUEXC1: TA_NULL
76 *
77 * yƒeƒXƒgƒV[ƒPƒ“ƒXz
78 *
79 * == TASK1i’†—Dæ“xC1‰ñ–ځj==
80 * 1: ó‘Ԃ̃`ƒFƒbƒN
81 * dis_dsp()
82 * ena_tex()
83 * 2: ó‘Ԃ̃`ƒFƒbƒN
84 * RAISE_CPU_EXCEPTION
85 * == CPUEXC1 ==
86 * 3: ó‘Ԃ̃`ƒFƒbƒN ... (A),(C),(D)
87 * xsns_xpn() == false ... (I)
88 * xsns_dpn() == true ... (J)
89 * 4: iras_tex(TASK1, 1U)
90 * iloc_cpu()
91 * ƒŠƒ^[ƒ“
92 * == TASK1‚̃^ƒXƒN—áŠOˆ—ƒ‹[ƒ`ƒ“ ==
93 * 5: ó‘Ԃ̃`ƒFƒbƒN ... (E),(F),(G),(H)
94 * 6: act_tsk(TASK1) ... (L)
95 * 7: ext_tsk() ... (L)
96 * == TASK1i’†—Dæ“xC2‰ñ–ځj==
97 * 8: ó‘Ԃ̃`ƒFƒbƒN ... (L)
98 * 9: ƒeƒXƒgI—¹
99 */
100
101#include <kernel.h>
102#include <test_lib.h>
103#include <t_syslog.h>
104#include "kernel_cfg.h"
105#include "test_cpuexc.h"
106
107int_t task1_count = 0;
108
109void
110task1(intptr_t exinf)
111{
112 ER ercd;
113
114 switch (++task1_count) {
115 case 1:
116 check_point(1);
117 check_state(false, false, TIPM_ENAALL, false, false, true);
118 ercd = dis_dsp();
119 check_ercd(ercd, E_OK);
120 ercd = ena_tex();
121 check_ercd(ercd, E_OK);
122
123 check_point(2);
124 check_state(false, false, TIPM_ENAALL, true, true, false);
125 RAISE_CPU_EXCEPTION;
126
127 check_point(0);
128 break;
129
130 case 2:
131 check_point(8);
132 check_state(false, false, TIPM_ENAALL, false, false, true);
133
134 check_finish(9);
135 break;
136
137 default:
138 check_point(0);
139 break;
140 }
141}
142
143void
144tex_task1(TEXPTN texptn, intptr_t exinf)
145{
146 ER ercd;
147
148 check_point(5);
149 check_state(false, false, TIPM_ENAALL, true, true, true);
150
151 check_point(6);
152 ercd = act_tsk(TASK1);
153 check_ercd(ercd, E_OK);
154
155 check_point(7);
156 ercd = ext_tsk();
157 check_ercd(ercd, E_OK);
158
159 check_point(0);
160}
161
162void
163task2(intptr_t exinf)
164{
165 check_point(0);
166}
167
168void
169alarm1_handler(intptr_t exinf)
170{
171 check_point(0);
172}
173
174void
175cpuexc_handler(void *p_excinf)
176{
177 ER ercd;
178
179 check_point(3);
180 check_state_i(true, false, true, true, false);
181 check_assert(xsns_xpn(p_excinf) == false);
182 check_assert(xsns_dpn(p_excinf) == true);
183
184 check_point(4);
185 ercd = iras_tex(TASK1, 1U);
186 check_ercd(ercd, E_OK);
187 ercd = iloc_cpu();
188 check_ercd(ercd, E_OK);
189}
Note: See TracBrowser for help on using the repository browser.