OSDN Git Service

カーネルのターゲット非依存部1.7.0およびCFGをマージ
[toppersasp4lpc/asp.git] / asp / test / perf3.c
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  *  上記著作権者は,以下の(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: perf3.c 1575 2009-05-31 14:15:46Z ertl-hiro $
38  */
39
40 /*
41  *              カーネル性能評価プログラム(3)
42  *
43  *  待ち解除するタスクの数により,set_flgの処理時間がどのように変化する
44  *  かを計測するためのプログラム.
45  */
46
47 #include <kernel.h>
48 #include <t_syslog.h>
49 #include <test_lib.h>
50 #include <histogram.h>
51 #include "kernel_cfg.h"
52 #include "perf3.h"
53
54 /*
55  *  計測回数と実行時間分布を記録する最大時間
56  */
57 #define NO_MEASURE      10000U                  /* 計測回数 */
58 #define MAX_TIME        1000U                   /* 実行時間分布を記録する最大時間 */
59
60 /*
61  *  実行時間分布を記録するメモリ領域
62  */
63 static uint_t   histarea1[MAX_TIME + 1];
64
65 /*
66  *  計測タスクのリスト
67  */
68 static ID task_list[20] = {
69         TASK1, TASK2, TASK3, TASK4, TASK5,
70         TASK6, TASK7, TASK8, TASK9, TASK10,
71         TASK11, TASK12, TASK13, TASK14, TASK15,
72         TASK16, TASK17, TASK18, TASK19, TASK20
73 };
74
75 /*
76  *  計測タスク(中優先度)
77  */
78 void task(intptr_t exinf)
79 {
80         FLGPTN  flgptn;
81
82         wai_flg(FLG1, 0x01U, TWF_ORW, &flgptn);
83 }
84
85 /*
86  *  計測ルーチン
87  */
88 void
89 perf_eval(uint_t n)
90 {
91         uint_t          i, j;
92
93         init_hist(1, MAX_TIME, histarea1);
94
95         for (i = 0; i < NO_MEASURE; i++) {
96                 ini_flg(FLG1);
97                 for (j = 0; j < n; j++) {
98                         act_tsk(task_list[j]);
99                 }
100                 chg_pri(TSK_SELF, MAIN_PRIORITY_LOW);
101                 /* タスクが待ち状態に入るのを待つ */
102                 chg_pri(TSK_SELF, TPRI_INI);
103
104                 begin_measure(1);
105                 set_flg(FLG1, 0x01U);
106                 end_measure(1);
107
108                 chg_pri(TSK_SELF, MAIN_PRIORITY_LOW);
109                 /* タスクが終了するのを待つ */
110                 chg_pri(TSK_SELF, TPRI_INI);
111         }
112
113         syslog_1(LOG_NOTICE, "Execution times of set_flg"
114                                                         " when %d tasks are released from waiting.", n);
115         print_hist(1);
116         syslog_flush();
117 }
118
119 /*
120  *  メインタスク(高優先度)
121  */
122 void main_task(intptr_t exinf)
123 {
124         syslog_0(LOG_NOTICE, "Performance evaluation program (3)");
125         syslog_flush();
126
127         perf_eval(0);
128         perf_eval(1);
129         perf_eval(2);
130         perf_eval(3);
131         perf_eval(4);
132         perf_eval(5);
133         perf_eval(10);
134         perf_eval(20);
135         test_finish();
136 }