annotate example/renew_task/main.cc @ 2054:2e7a6f40672f draft

add param(4) in FileMapReduce.cc
author masa
date Fri, 29 Jan 2016 15:56:28 +0900
parents f40558ec00a8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
1 #include <stdio.h>
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
2 #include <stdlib.h>
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
3 #include <string.h>
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
4 #include "TaskManager.h"
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 573
diff changeset
5 #include "SchedTask.h"
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
6 #include "Func.h"
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
7
400
984e7890db0c Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 260
diff changeset
8 extern void task_init();
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
9
260
c29b7163d6d9 change example
e065746@localhost.localdomain
parents: 192
diff changeset
10 const char *usr_help_str = "Usage: ./renew_task";
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
11
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
12 SchedDefineTask(RenewRepeat);
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
13
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
14 static int count = 1;
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
15 static int task_count = 1;
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
16
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
17 static void
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 573
diff changeset
18 renewRepeat1(SchedTask *s, void *arg, void *d)
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
19 {
567
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
20 TaskManager *manager = (TaskManager *)arg;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
21
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
22 if (count-->0) {
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
23 HTask *repeat = manager->create_task(RENEW_REPEAT);
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 573
diff changeset
24 repeat->set_post(renewRepeat1, (void*)manager, 0);
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
25 repeat->spawn();
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
26
567
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
27 HTask *renew;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
28
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
29 printf("[PPE] Create Task : RenewStart\n\n");
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
30
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
31 for(int i=0;i<task_count;i++) {
567
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
32 renew = manager->create_task(RENEW_START);
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
33 renew->set_cpu(SPE_ANY);
1412
f40558ec00a8 remove duplicated spe task code source
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
34 renew->set_param(0,i);
f40558ec00a8 remove duplicated spe task code source
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 625
diff changeset
35 renew->set_param(1,&task_count);
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
36
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
37 // add Active Queue
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
38 renew->spawn();
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
39 }
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
40 }
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
41 }
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
42
567
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
43 static int
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
44 run(SchedTask *s, void *rbuf, void *wbuf)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
45 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
46 // RewnewRepeat Task
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
47 return 0;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 546
diff changeset
48 }
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
49
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
50 static int
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
51 init(int argc, char **argv)
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
52 {
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
53 for (int i = 1; argv[i]; ++i) {
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
54 if (strcmp(argv[i], "-count") == 0) {
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
55 count = atoi(argv[++i]);
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
56 } else if (strcmp(argv[i], "-task") == 0) {
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
57 task_count = atoi(argv[++i]);
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
58 }
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
59
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
60
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
61 }
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
62 return 0;
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
63 }
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
64
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
65 static void
400
984e7890db0c Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 260
diff changeset
66 renew_init(TaskManager *manager)
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
67 {
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
68 HTask *repeat;
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
69
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
70 printf("[PPE] Create Task : RenewRepeat\n\n");
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
71
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
72 repeat = manager->create_task(RENEW_REPEAT);
619
278db3ca751d RenewTask removal
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 573
diff changeset
73 repeat->set_post(renewRepeat1, (void*)manager, 0);
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
74
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
75 // add Active Queue
489
1d893ffbc5ff comment
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 400
diff changeset
76 repeat->spawn();
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
77 }
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
78
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
79 int
400
984e7890db0c Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 260
diff changeset
80 TMmain(TaskManager *manager, int argc, char *argv[])
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
81 {
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
82 if (init(argc, argv) < 0) {
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
83 return -1;
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
84 }
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
85
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
86 // Task Register
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
87 // ppe/task_init.cc
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
88 task_init();
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
89
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
90 printf("[PPE] Program Start\n\n");
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
91
400
984e7890db0c Fix examples.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 260
diff changeset
92 renew_init(manager);
192
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
93
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
94 return 0;
6694da357750 add example/renew_task
gongo@localhost.localdomain
parents:
diff changeset
95 }