annotate example/many_task/main.cc @ 935:e54842e4d97b

-a option for sort
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 31 Jul 2010 03:13:24 +0900
parents da657af64afd
children a9c7784e5dae
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
1 #include <stdio.h>
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
2 #include <string.h>
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
3 #include <stdlib.h>
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
4 #include <sys/time.h>
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
5 #include "TaskManager.h"
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
6 #include "Func.h"
220
gongo@localhost.localdomain
parents: 217
diff changeset
7 #include "sort.h"
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
8
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
9 extern void task_init(void);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
10
220
gongo@localhost.localdomain
parents: 217
diff changeset
11 // sort.cc
gongo@localhost.localdomain
parents: 217
diff changeset
12 extern int data_length;
gongo@localhost.localdomain
parents: 217
diff changeset
13 extern DataPtr data;
935
e54842e4d97b -a option for sort
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 934
diff changeset
14 extern int all;
e54842e4d97b -a option for sort
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 934
diff changeset
15 int all = 0;
220
gongo@localhost.localdomain
parents: 217
diff changeset
16
gongo@localhost.localdomain
parents: 217
diff changeset
17 // 計測用
gongo@localhost.localdomain
parents: 217
diff changeset
18 static double st_time;
gongo@localhost.localdomain
parents: 217
diff changeset
19 static double ed_time;
gongo@localhost.localdomain
parents: 217
diff changeset
20
gongo@localhost.localdomain
parents: 217
diff changeset
21 static int length = 1200;
gongo@localhost.localdomain
parents: 217
diff changeset
22
gongo@localhost.localdomain
parents: 217
diff changeset
23 // prototype
400
00fe05184a02 Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 256
diff changeset
24 void TMend(TaskManager *);
220
gongo@localhost.localdomain
parents: 217
diff changeset
25
gongo@localhost.localdomain
parents: 217
diff changeset
26 static double
gongo@localhost.localdomain
parents: 217
diff changeset
27 getTime(void)
gongo@localhost.localdomain
parents: 217
diff changeset
28 {
gongo@localhost.localdomain
parents: 217
diff changeset
29 struct timeval tv;
gongo@localhost.localdomain
parents: 217
diff changeset
30 gettimeofday(&tv, NULL);
gongo@localhost.localdomain
parents: 217
diff changeset
31 return tv.tv_sec + (double)tv.tv_usec*1e-6;
gongo@localhost.localdomain
parents: 217
diff changeset
32 }
256
465a871f4c07 fix examples
tkaito@localhost.localdomain
parents: 230
diff changeset
33 /*
220
gongo@localhost.localdomain
parents: 217
diff changeset
34 static void
gongo@localhost.localdomain
parents: 217
diff changeset
35 show_data(void)
gongo@localhost.localdomain
parents: 217
diff changeset
36 {
gongo@localhost.localdomain
parents: 217
diff changeset
37 puts("-----------------------------------------------");
gongo@localhost.localdomain
parents: 217
diff changeset
38 for(int i = 0; i < data_length; i++) {
gongo@localhost.localdomain
parents: 217
diff changeset
39 printf("data[%02d].index = %d\n", i, data[i].index);
gongo@localhost.localdomain
parents: 217
diff changeset
40 }
gongo@localhost.localdomain
parents: 217
diff changeset
41 puts("-----------------------------------------------");
gongo@localhost.localdomain
parents: 217
diff changeset
42 }
256
465a871f4c07 fix examples
tkaito@localhost.localdomain
parents: 230
diff changeset
43 */
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
44
256
465a871f4c07 fix examples
tkaito@localhost.localdomain
parents: 230
diff changeset
45 const char *usr_help_str = "Usage: ./sort [option]\n \
217
gongo@localhost.localdomain
parents: 109
diff changeset
46 options\n\
gongo@localhost.localdomain
parents: 109
diff changeset
47 -cpu Number of SPE used (default 1)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
48 -l, --length Sorted number of data (default 1200)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
49 -h, --help Print this message";
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
50
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
51 int
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
52 init(int argc, char **argv)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
53 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
54 for (int i = 1; argv[i]; ++i) {
217
gongo@localhost.localdomain
parents: 109
diff changeset
55 if (strcmp(argv[i], "--length") == 0 || strcmp(argv[i], "-l") == 0) {
220
gongo@localhost.localdomain
parents: 217
diff changeset
56 length = atoi(argv[++i]);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
57 }
935
e54842e4d97b -a option for sort
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 934
diff changeset
58 if (strcmp(argv[i], "-a") == 0 ) {
e54842e4d97b -a option for sort
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 934
diff changeset
59 all = 1;
e54842e4d97b -a option for sort
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 934
diff changeset
60 }
256
465a871f4c07 fix examples
tkaito@localhost.localdomain
parents: 230
diff changeset
61
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
62 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
63
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
64 return 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
65 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
66
220
gongo@localhost.localdomain
parents: 217
diff changeset
67 unsigned int ts, te;
gongo@localhost.localdomain
parents: 217
diff changeset
68
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
69 int
400
00fe05184a02 Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 256
diff changeset
70 TMmain(TaskManager *manager, int argc, char *argv[])
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
71 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
72 if (init(argc, argv) < 0) {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
73 return -1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
74 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
75
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
76 task_init();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
77
674
bde5f13adf10 fix many task example (sort).
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
78 int cpu = manager->get_cpuNum();
675
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 674
diff changeset
79
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 674
diff changeset
80 // in case of -cpu 0
674
bde5f13adf10 fix many task example (sort).
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
81 if (cpu==0) cpu = 1;
932
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
82 if (1) {
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
83 HTask *dummy = manager->create_task(Dummy);
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
84 dummy->set_post(sort_init, (void*)cpu, (void*)length);
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
85 dummy->spawn();
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
86 } else {
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
87 sort_init(manager->get_schedTask(),(void*)cpu, (void*)length);
f4d7cf77ec3d sort test (add swap())
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 675
diff changeset
88 }
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
89
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
90 st_time = getTime();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
91
227
d54cbfafcb82 add sort
gongo@localhost.localdomain
parents: 220
diff changeset
92 // 全ての Task が終了した後に実行する関数をセット
220
gongo@localhost.localdomain
parents: 217
diff changeset
93 manager->set_TMend(TMend);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
94
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
95 return 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
96 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
97
934
da657af64afd sort fix ( not working now )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 932
diff changeset
98 extern void check_data();
da657af64afd sort fix ( not working now )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 932
diff changeset
99
220
gongo@localhost.localdomain
parents: 217
diff changeset
100 void
400
00fe05184a02 Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 256
diff changeset
101 TMend(TaskManager *manager)
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
102 {
220
gongo@localhost.localdomain
parents: 217
diff changeset
103 ed_time = getTime();
230
2b114977852d fix Random
gongo@localhost.localdomain
parents: 227
diff changeset
104 //show_data();
934
da657af64afd sort fix ( not working now )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 932
diff changeset
105 check_data();
220
gongo@localhost.localdomain
parents: 217
diff changeset
106 printf("Time: %0.6f\n",ed_time-st_time);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
107 }
674
bde5f13adf10 fix many task example (sort).
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
108
bde5f13adf10 fix many task example (sort).
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
109 /* end */