annotate example/many_task/main.cc @ 230:56314060907f draft

fix Random
author gongo@localhost.localdomain
date Fri, 13 Feb 2009 10:53:58 +0900
parents e7faaf516be1
children 2c775d229cc6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
1 #include <stdio.h>
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
2 #include <string.h>
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
3 #include <stdlib.h>
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
4 #include <sys/time.h>
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
5 #include "TaskManager.h"
028ffc9c0375 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
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
8
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
9 extern void task_init(void);
028ffc9c0375 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;
gongo@localhost.localdomain
parents: 217
diff changeset
14
gongo@localhost.localdomain
parents: 217
diff changeset
15 // 計測用
gongo@localhost.localdomain
parents: 217
diff changeset
16 static double st_time;
gongo@localhost.localdomain
parents: 217
diff changeset
17 static double ed_time;
gongo@localhost.localdomain
parents: 217
diff changeset
18
gongo@localhost.localdomain
parents: 217
diff changeset
19 static int length = 1200;
gongo@localhost.localdomain
parents: 217
diff changeset
20
gongo@localhost.localdomain
parents: 217
diff changeset
21 // prototype
gongo@localhost.localdomain
parents: 217
diff changeset
22 void TMend(void);
gongo@localhost.localdomain
parents: 217
diff changeset
23
gongo@localhost.localdomain
parents: 217
diff changeset
24 static double
gongo@localhost.localdomain
parents: 217
diff changeset
25 getTime(void)
gongo@localhost.localdomain
parents: 217
diff changeset
26 {
gongo@localhost.localdomain
parents: 217
diff changeset
27 struct timeval tv;
gongo@localhost.localdomain
parents: 217
diff changeset
28 gettimeofday(&tv, NULL);
gongo@localhost.localdomain
parents: 217
diff changeset
29 return tv.tv_sec + (double)tv.tv_usec*1e-6;
gongo@localhost.localdomain
parents: 217
diff changeset
30 }
gongo@localhost.localdomain
parents: 217
diff changeset
31
gongo@localhost.localdomain
parents: 217
diff changeset
32 static void
gongo@localhost.localdomain
parents: 217
diff changeset
33 show_data(void)
gongo@localhost.localdomain
parents: 217
diff changeset
34 {
gongo@localhost.localdomain
parents: 217
diff changeset
35 puts("-----------------------------------------------");
gongo@localhost.localdomain
parents: 217
diff changeset
36 for(int i = 0; i < data_length; i++) {
gongo@localhost.localdomain
parents: 217
diff changeset
37 printf("data[%02d].index = %d\n", i, data[i].index);
gongo@localhost.localdomain
parents: 217
diff changeset
38 }
gongo@localhost.localdomain
parents: 217
diff changeset
39 puts("-----------------------------------------------");
gongo@localhost.localdomain
parents: 217
diff changeset
40 }
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
41
217
gongo@localhost.localdomain
parents: 109
diff changeset
42 const char *help_str = "Usage: ./sort [option]\n \
gongo@localhost.localdomain
parents: 109
diff changeset
43 options\n\
gongo@localhost.localdomain
parents: 109
diff changeset
44 -cpu Number of SPE used (default 1)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
45 -l, --length Sorted number of data (default 1200)\n\
gongo@localhost.localdomain
parents: 109
diff changeset
46 -h, --help Print this message";
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
47
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
48 int
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
49 init(int argc, char **argv)
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
50 {
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
51 for (int i = 1; argv[i]; ++i) {
217
gongo@localhost.localdomain
parents: 109
diff changeset
52 if (strcmp(argv[i], "--length") == 0 || strcmp(argv[i], "-l") == 0) {
220
gongo@localhost.localdomain
parents: 217
diff changeset
53 length = atoi(argv[++i]);
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
54 }
217
gongo@localhost.localdomain
parents: 109
diff changeset
55 if (strcmp(argv[i], "--help") == 0 || strcmp(argv[i], "-h") == 0) {
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
56 printf("%s\n", help_str);
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
57 return -1;
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
58 }
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
59 }
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
60
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
61 return 0;
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
62 }
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
63
220
gongo@localhost.localdomain
parents: 217
diff changeset
64 extern void sort_init(int, int);
gongo@localhost.localdomain
parents: 217
diff changeset
65
gongo@localhost.localdomain
parents: 217
diff changeset
66 unsigned int ts, te;
gongo@localhost.localdomain
parents: 217
diff changeset
67
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
68 int
220
gongo@localhost.localdomain
parents: 217
diff changeset
69 TMmain(int argc, char *argv[])
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
70 {
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
71 if (init(argc, argv) < 0) {
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
72 return -1;
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
73 }
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
74
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
75 task_init();
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
76
220
gongo@localhost.localdomain
parents: 217
diff changeset
77 sort_init(manager->get_cpuNum(), length);
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
78
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
79 st_time = getTime();
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
80
227
e7faaf516be1 add sort
gongo@localhost.localdomain
parents: 220
diff changeset
81 // 全ての Task が終了した後に実行する関数をセット
220
gongo@localhost.localdomain
parents: 217
diff changeset
82 manager->set_TMend(TMend);
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
83
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
84 return 0;
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
85 }
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
86
220
gongo@localhost.localdomain
parents: 217
diff changeset
87 void
gongo@localhost.localdomain
parents: 217
diff changeset
88 TMend(void)
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
89 {
220
gongo@localhost.localdomain
parents: 217
diff changeset
90 ed_time = getTime();
230
56314060907f fix Random
gongo@localhost.localdomain
parents: 227
diff changeset
91 //show_data();
220
gongo@localhost.localdomain
parents: 217
diff changeset
92 printf("Time: %0.6f\n",ed_time-st_time);
109
028ffc9c0375 Cerium cvs version
gongo@gendarme.local
parents:
diff changeset
93 }