source: asp_ewarm/asp-1.7.0/test/test_cpuexc2.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.4 KB
Line 
1/*
2 * TOPPERS Software
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 *
5 * Copyright (C) 2007-2010 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_cpuexc2.c 2005 2010-12-31 04:20:08Z ertl-hiro $
42 */
43
44/*
45 * CPU—áŠOˆ—‚̃eƒXƒg(2)
46 *
47 * yƒeƒXƒg‚Ì–Ú“Iz
48 *
49 * ”ñƒ^ƒXƒNƒRƒ“ƒeƒLƒXƒgCŠ„žƒƒbƒN‰ðœCCPUƒƒbƒNó‘Ô‚Å”­¶‚µ‚½CPU—á
50 * ŠO‚É‚¨‚¯‚éƒVƒXƒeƒ€ó‘Ԃ̃eƒXƒgDŠ„ž‚Ý—Dæ“xƒ}ƒXƒNTIPM_ENAALLCƒfƒB
51 * ƒXƒpƒbƒ`‹ÖŽ~ó‘ԁCƒ^ƒXƒN—áŠO‹–‰Âó‘ԂŃeƒXƒg‚·‚éD
52 *
53 * yƒeƒXƒg€–ځz
54 *
55 * ‚¢‚¸‚ê‚àC”ñƒ^ƒXƒNƒRƒ“ƒeƒLƒXƒgCŠ„žƒƒbƒN‰ðœCCPUƒƒbƒNó‘Ô‚Å”­¶
56 * ‚µ‚½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 * ICPU—áŠOƒnƒ“ƒhƒ‰‚©‚烊ƒ^[ƒ“‚Å‚«‚éê‡‚̂݃eƒXƒg‚·‚éD
66 * (F) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚ÉŠ„ž‚Ý—Dæ“xƒ}ƒXƒN‚ªŒ³‚ɖ߂邱‚Æ
67 * ICPU—áŠOƒnƒ“ƒhƒ‰‚©‚烊ƒ^[ƒ“‚Å‚«‚éê‡‚̂݃eƒXƒg‚·‚éD
68 * (G) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚ɃfƒBƒXƒpƒbƒ`‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
69 * ICPU—áŠOƒnƒ“ƒhƒ‰‚©‚烊ƒ^[ƒ“‚Å‚«‚éê‡‚̂݃eƒXƒg‚·‚éD
70 * (H) CPU—áŠOƒnƒ“ƒhƒ‰ƒŠƒ^[ƒ“Žž‚Ƀ^ƒXƒN—áŠOˆ—‹ÖŽ~ƒtƒ‰ƒO‚ª•Ï‰»‚µ‚È‚¢‚±‚Æ
71 * ICPU—áŠOƒnƒ“ƒhƒ‰‚©‚烊ƒ^[ƒ“‚Å‚«‚éê‡‚̂݃eƒXƒg‚·‚éD
72 * (I) xsns_xpn‚ªtrue‚ð•Ô‚·‚±‚Æ
73 * (J) xsns_dpn‚ªtrue‚ð•Ô‚·‚±‚Æ
74 *
75 * yŽg—pƒŠƒ\[ƒXz
76 *
77 * TASK1: TA_ACTC’†—Dæ“xCƒ^ƒXƒN—áŠOˆ—ƒ‹[ƒ`ƒ““o˜^
78 * CPUEXC1: TA_NULL
79 * ALM1: TA_NULL
80 *
81 * yƒeƒXƒgƒV[ƒPƒ“ƒXz
82 *
83 * == TASK1i’†—Dæ“xj==
84 * 1: ó‘Ԃ̃`ƒFƒbƒN
85 * dis_dsp()
86 * ena_tex()
87 * 2: ó‘Ԃ̃`ƒFƒbƒN
88 * sta_alm(ALM1, 1U)
89 * ƒAƒ‰[ƒ€ƒnƒ“ƒhƒ‰1‚ÌŽÀs‚ð‘Ò‚Â
90 * == ALM1 ==
91 * 3: ó‘Ԃ̃`ƒFƒbƒN
92 * iloc_cpu()
93 * RAISE_CPU_EXCEPTION
94 * == CPUEXC1 ==
95 * 4: ó‘Ԃ̃`ƒFƒbƒN ... (A)(C)(D)
96 * xsns_xpn() == true ... (I)
97 * xsns_dpn() == true ... (J)
98 * 5: CPU—áŠOƒnƒ“ƒhƒ‰‚©‚烊ƒ^[ƒ“‚Å‚«‚È‚¢ê‡‚́C‚±‚±‚ŏI—¹
99 * 5: ƒŠƒ^[ƒ“
100 * == ALM1i‘±‚«j==
101 * 6: ó‘Ԃ̃`ƒFƒbƒN ... (E)(G)(H)
102 * ƒŠƒ^[ƒ“
103 * == TASK1i‘±‚«j==
104 * 7: ó‘Ԃ̃`ƒFƒbƒN ... (F)
105 * 8: ƒeƒXƒgI—¹
106 */
107
108#include <kernel.h>
109#include <test_lib.h>
110#include <t_syslog.h>
111#include "kernel_cfg.h"
112#include "test_cpuexc.h"
113
114volatile bool_t alm1_flag = false;
115
116void
117task1(intptr_t exinf)
118{
119 ER ercd;
120
121 check_point(1);
122 check_state(false, false, TIPM_ENAALL, false, false, true);
123 ercd = dis_dsp();
124 check_ercd(ercd, E_OK);
125 ercd = ena_tex();
126 check_ercd(ercd, E_OK);
127
128 check_point(2);
129 check_state(false, false, TIPM_ENAALL, true, true, false);
130 ercd = sta_alm(ALM1, 1U);
131 check_ercd(ercd, E_OK);
132
133 while (!(alm1_flag));
134
135 check_point(7);
136 check_state(false, false, TIPM_ENAALL, true, true, false);
137
138 check_finish(8);
139}
140
141void
142tex_task1(TEXPTN texptn, intptr_t exinf)
143{
144 check_point(0);
145}
146
147void
148task2(intptr_t exinf)
149{
150 check_point(0);
151}
152
153void
154alarm1_handler(intptr_t exinf)
155{
156 ER ercd;
157
158 check_point(3);
159 check_state_i(true, false, true, true, false);
160 ercd = iloc_cpu();
161 check_ercd(ercd, E_OK);
162 RAISE_CPU_EXCEPTION;
163
164 check_point(6);
165 check_state_i(true, true, true, true, false);
166 alm1_flag = true;
167}
168
169void
170cpuexc_handler(void *p_excinf)
171{
172 check_point(4);
173 check_state_i(true, true, true, true, false);
174 check_assert(xsns_xpn(p_excinf) == true);
175 check_assert(xsns_dpn(p_excinf) == true);
176
177#ifdef CANNOT_RETURN_CPUEXC
178 check_finish(5);
179#endif /* CANNOT_RETURN_CPUEXC */
180
181 check_point(5);
182}
Note: See TracBrowser for help on using the repository browser.