annotate example/many_task/main.cc @ 217:897aeb144569

fix
author gongo@localhost.localdomain
date Wed, 04 Feb 2009 22:50:42 +0900
parents 5c194c71eca8
children 29e338dbc280
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"
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
7
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
8 extern void task_init(void);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
9
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
10 int data_size = 1200;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
11
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
12 double getTime();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
13
217
gongo@localhost.localdomain
parents: 109
diff changeset
14 const char *help_str = "Usage: ./sort [option]\n \
gongo@localhost.localdomain
parents: 109
diff changeset
15 options\n\
gongo@localhost.localdomain
parents: 109
diff changeset
16 -cpu Number of SPE used (default 1)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
17 -l, --length Sorted number of data (default 1200)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
18 -h, --help Print this message";
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
19
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
20 int
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
21 init(int argc, char **argv)
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
22 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
23 for (int i = 1; argv[i]; ++i) {
217
gongo@localhost.localdomain
parents: 109
diff changeset
24 if (strcmp(argv[i], "--length") == 0 || strcmp(argv[i], "-l") == 0) {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
25 data_size = atoi(argv[++i]);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
26 }
217
gongo@localhost.localdomain
parents: 109
diff changeset
27 if (strcmp(argv[i], "--help") == 0 || strcmp(argv[i], "-h") == 0) {
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
28 printf("%s\n", help_str);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
29 return -1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
30 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
31 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
32
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
33 return 0;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
34 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
35
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
36 int
217
gongo@localhost.localdomain
parents: 109
diff changeset
37 cerium_main(int argc, char *argv[])
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
38 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
39 // 計測用
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
40 double st_time, ed_time;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
41 HTask *runLoop;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
42
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
43 if (init(argc, argv) < 0) {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
44 return -1;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
45 }
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
46
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
47 task_init();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
48
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
49 runLoop = manager->create_task(TASK_MAIN);
217
gongo@localhost.localdomain
parents: 109
diff changeset
50 runLoop->add_param(6);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
51 runLoop->add_param(data_size);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
52
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
53 runLoop->spawn();
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
54 // Start
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
55 st_time = getTime();
217
gongo@localhost.localdomain
parents: 109
diff changeset
56 //manager->run();
gongo@localhost.localdomain
parents: 109
diff changeset
57 //ed_time = getTime();
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
58
217
gongo@localhost.localdomain
parents: 109
diff changeset
59 //printf("Time: %0.6f\n",ed_time-st_time);
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
60
217
gongo@localhost.localdomain
parents: 109
diff changeset
61 //delete manager;
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
62
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
63 FINISH:
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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
67 double getTime()
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
68 {
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
69 struct timeval tv;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
70 gettimeofday(&tv, NULL);
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
71 return tv.tv_sec + (double)tv.tv_usec*1e-6;
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
72 }