109
|
1 #include <stdio.h>
|
|
2 #include <string.h>
|
|
3 #include <stdlib.h>
|
|
4 #include <sys/time.h>
|
|
5 #include "TaskManager.h"
|
|
6 #include "Func.h"
|
|
7
|
|
8 extern void task_init(void);
|
|
9
|
|
10 int data_size = 1200;
|
|
11
|
|
12 double getTime();
|
|
13
|
217
|
14 const char *help_str = "Usage: ./sort [option]\n \
|
|
15 options\n\
|
|
16 -cpu Number of SPE used (default 1)\n\
|
|
17 -l, --length Sorted number of data (default 1200)\n\
|
|
18 -h, --help Print this message";
|
109
|
19
|
|
20 int
|
|
21 init(int argc, char **argv)
|
|
22 {
|
|
23 for (int i = 1; argv[i]; ++i) {
|
217
|
24 if (strcmp(argv[i], "--length") == 0 || strcmp(argv[i], "-l") == 0) {
|
109
|
25 data_size = atoi(argv[++i]);
|
|
26 }
|
217
|
27 if (strcmp(argv[i], "--help") == 0 || strcmp(argv[i], "-h") == 0) {
|
109
|
28 printf("%s\n", help_str);
|
|
29 return -1;
|
|
30 }
|
|
31 }
|
|
32
|
|
33 return 0;
|
|
34 }
|
|
35
|
|
36 int
|
217
|
37 cerium_main(int argc, char *argv[])
|
109
|
38 {
|
|
39 // 計測用
|
|
40 double st_time, ed_time;
|
|
41 HTask *runLoop;
|
|
42
|
|
43 if (init(argc, argv) < 0) {
|
|
44 return -1;
|
|
45 }
|
|
46
|
|
47 task_init();
|
|
48
|
|
49 runLoop = manager->create_task(TASK_MAIN);
|
217
|
50 runLoop->add_param(6);
|
109
|
51 runLoop->add_param(data_size);
|
|
52
|
|
53 runLoop->spawn();
|
|
54 // Start
|
|
55 st_time = getTime();
|
217
|
56 //manager->run();
|
|
57 //ed_time = getTime();
|
109
|
58
|
217
|
59 //printf("Time: %0.6f\n",ed_time-st_time);
|
109
|
60
|
217
|
61 //delete manager;
|
109
|
62
|
|
63 FINISH:
|
|
64 return 0;
|
|
65 }
|
|
66
|
|
67 double getTime()
|
|
68 {
|
|
69 struct timeval tv;
|
|
70 gettimeofday(&tv, NULL);
|
|
71 return tv.tv_sec + (double)tv.tv_usec*1e-6;
|
|
72 }
|