OSDN Git Service

ターゲット名間違いを修正
[toppersasp4lpc/asp.git] / asp / test / perf1.c
1 /*
2  *  TOPPERS Software
3  *      Toyohashi Open Platform for Embedded Real-Time Systems
4  * 
5  *  Copyright (C) 2006-2009 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: perf1.c 1575 2009-05-31 14:15:46Z ertl-hiro $
38  */
39
40 /*
41  *              カーネル性能評価プログラム(1)
42  *
43  *  slp_tsk,wup_tskによるタスク切換え時間を計測するためのプログラム.
44  */
45
46 #include <kernel.h>
47 #include <t_syslog.h>
48 #include <test_lib.h>
49 #include <histogram.h>
50 #include "kernel_cfg.h"
51 #include "perf1.h"
52
53 /*
54  *  計測回数と実行時間分布を記録する最大時間
55  */
56 #define NO_MEASURE      10000U                  /* 計測回数 */
57 #define MAX_TIME        1000U                   /* 実行時間分布を記録する最大時間 */
58
59 /*
60  *  実行時間分布を記録するメモリ領域
61  */
62 static uint_t   histarea1[MAX_TIME + 1];
63 static uint_t   histarea2[MAX_TIME + 1];
64
65 /*
66  *  計測タスク1(高優先度)
67  */
68 void task1(intptr_t exinf)
69 {
70         uint_t  i;
71
72         slp_tsk();
73         end_measure(1);
74         for (i = 1; i < NO_MEASURE; i++) {
75                 begin_measure(2);
76                 slp_tsk();
77                 end_measure(1);
78         }
79         begin_measure(2);
80         slp_tsk();
81 }
82
83 /*
84  *  計測タスク2(中優先度)
85  */
86 void task2(intptr_t exinf)
87 {
88         uint_t  i;
89
90         for (i = 0; i < NO_MEASURE; i++) {
91                 begin_measure(1);
92                 wup_tsk(TASK1);
93                 end_measure(2);
94         }
95         wup_tsk(TASK1);
96 }
97
98 /*
99  *  メインタスク(低優先度)
100  */
101 void main_task(intptr_t exinf)
102 {
103         syslog_0(LOG_NOTICE, "Performance evaluation program (1)");
104         init_hist(1, MAX_TIME, histarea1);
105         init_hist(2, MAX_TIME, histarea2);
106         syslog_flush();
107
108         act_tsk(TASK1);
109         act_tsk(TASK2);
110
111         syslog_0(LOG_NOTICE, "Execution times of wup_tsk -> slp_tsk");
112         print_hist(1);
113         syslog_0(LOG_NOTICE, "Execution times of slp_tsk -> wup_tsk");
114         print_hist(2);
115         test_finish();
116 }