Annotation of libaitsched/example/test_basic.c, revision 1.3.4.2

1.2       misho       1: #include <stdio.h>
                      2: #include <stdlib.h>
                      3: #include <string.h>
                      4: #include <unistd.h>
                      5: #include <fcntl.h>
                      6: #include <signal.h>
                      7: #include <sys/types.h>
                      8: #include <sys/stat.h>
                      9: #include <sys/socket.h>
                     10: #include <netinet/in.h>
                     11: #include <aitsched.h>
                     12: 
                     13: intptr_t Kill;
                     14: 
                     15: void *event(sched_task_t *arg)
                     16: {
                     17:        printf("Event::\n");
                     18:        taskExit(arg, NULL);
                     19: }
                     20: 
                     21: void *regular(sched_task_t *arg)
                     22: {
                     23:        printf("Task::\n");
                     24:        taskExit(arg, NULL);
                     25: }
                     26: 
                     27: void *timer(sched_task_t *arg)
                     28: {
                     29:        printf("Timer %p sec::\n", TASK_ARG(arg));
                     30:        taskExit(arg, NULL);
                     31: }
                     32: 
                     33: void *r(sched_task_t *arg)
                     34: {
                     35:        int rlen;
                     36:        char buf[BUFSIZ] = { [0 ... BUFSIZ - 1] = 0 };
                     37: 
                     38:        rlen = read(TASK_FD(arg), buf, sizeof buf);
1.3       misho      39:        printf("read:: RET=%d FLAG=0x%lx rlen=%d bytes readed = %s\n", 
1.3.4.1   misho      40:                        (int) TASK_RET(arg), TASK_FLAG(arg), (int) rlen, buf);
1.3       misho      41:        for (rlen = 0; rlen < TASK_RET(arg); rlen++)
                     42:                printf("buf[%d]=%c\n", rlen, buf[rlen]);
1.2       misho      43:        Kill++;
                     44:        taskExit(arg, NULL);
                     45: }
                     46: 
                     47: void *w(sched_task_t *arg)
                     48: {
1.3.4.1   misho      49:        printf("write:: RET=%d FLAG=0x%lx\n", (int) TASK_RET(arg), TASK_FLAG(arg));
1.2       misho      50:        taskExit(arg, NULL);
                     51: }
                     52: 
                     53: void *once(sched_task_t *arg)
                     54: {
                     55:        printf("once::\n");
                     56:        taskExit(arg, NULL);
                     57: }
                     58: 
                     59: void *thr(sched_task_t *arg)
                     60: {
                     61:        printf("tid (%lx):: %s\n", TASK_VAL(arg), __func__);
                     62:        taskExit(arg, 42);
                     63: }
                     64: 
                     65: void *thr4kill(sched_task_t *arg)
                     66: {
                     67:        char blah[BUFSIZ];
                     68: 
                     69:        printf("tid (%lx):: %s\n", TASK_VAL(arg), __func__);
                     70: 
                     71:        read(0, blah, sizeof blah);
                     72:        printf("never see!!! (%lx):: %s (%d == %d)\n", TASK_VAL(arg), (char*) TASK_ARG(arg), TASK_TYPE(arg), taskTHREAD);
                     73:        taskExit(arg, 0);
                     74: }
                     75: 
                     76: void sig(int s)
                     77: {
                     78:        switch (s) {
                     79:                case SIGTERM:
                     80:                        Kill++;
                     81:                        break;
                     82:        }
                     83: }
                     84: 
                     85: int
                     86: main(int argc, char **argv)
                     87: {
                     88:        sched_root_task_t *root;
                     89:        int f;
                     90:        struct sockaddr_in sin;
                     91:        struct timespec ts = { 20, 0 };
                     92: //     struct timespec p = { 0, 10000000 };
                     93:        struct sigaction sa;
                     94:        sched_task_t *t;
                     95: 
                     96:        sa.sa_handler = sig;
                     97:        sigemptyset(&sa.sa_mask);
                     98:        sigaction(SIGTERM, &sa, NULL);
                     99: 
                    100:        f = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
                    101:        if (f == -1)
                    102:                return 1;
1.3.4.1   misho     103: #ifndef __linux__
1.2       misho     104:        sin.sin_len = sizeof sin;
1.3.4.1   misho     105: #endif
1.2       misho     106:        sin.sin_family = AF_INET;
                    107:        sin.sin_port = htons(2345);
                    108:        sin.sin_addr.s_addr = INADDR_ANY;
                    109:        if (bind(f, (struct sockaddr*) &sin, sizeof sin) == -1)
                    110:                return 1;
                    111: 
                    112:        root = schedBegin();
                    113:        if (!root) {
                    114:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    115:                return 1;
                    116:        }
                    117: 
                    118:        if (!schedTimer(root, timer, (void*) (intptr_t) ts.tv_sec, ts, NULL, 0)) {
                    119:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    120:                return 4;
                    121:        } else
                    122:                ts.tv_sec = 15;
                    123:        if (!schedTimer(root, timer, (void*) (intptr_t) ts.tv_sec, ts, NULL, 0)) {
                    124:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    125:                return 4;
                    126:        } else
                    127:                ts.tv_sec = 10;
                    128: 
                    129:        if (!schedEvent(root, event, "piuk", 1234, NULL, 0)) {
                    130:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    131:                return 2;
                    132:        }
                    133: 
                    134:        if (!schedTask(root, regular, "piuk", 1111, NULL, 0)) {
                    135:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    136:                return 3;
                    137:        }
                    138: 
                    139:        if (!schedTimer(root, timer, (void*) (intptr_t) ts.tv_sec, ts, NULL, 0)) {
                    140:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    141:                return 4;
                    142:        }
                    143: 
                    144:        if (!schedRead(root, r, "rrr", f, NULL, 0)) {
                    145:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    146:                return 5;
                    147:        }
                    148: 
                    149:        if (!schedWrite(root, w, "www", f, NULL, 0)) {
                    150:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    151:                return 6;
                    152:        }
                    153: 
                    154:        if (!(t = schedThread(root, thr4kill, "0aaaa", 0, NULL, 0))) {
                    155:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    156:                return 7;
                    157:        }
                    158:        if (!schedThread(root, thr, "mdaaaa this is thread task", 8192, NULL, 0)) {
                    159:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
1.3.4.2 ! misho     160:                printf("stack is too small\n");
1.2       misho     161:        }
                    162:        if (!schedThread(root, thr, "mdaaaa this is thread task -detached", 131072, NULL, 0)) {
                    163:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    164:                return 7;
                    165:        }
                    166:        if (!schedThread(root, thr, "mdaaaa this is thread task -j", 0, NULL, 0)) {
                    167:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    168:                return 7;
                    169:        }
                    170:        printf("try to cancel tid = %lx\n", TASK_VAL(t));
                    171:        schedCancel(t);
                    172:        if (!schedThread(root, thr, "mdaaaa this is thread task -j2", 0, NULL, 0)) {
                    173:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    174:                return 7;
                    175:        }
                    176:        if (!(t = schedThread(root, thr4kill, "0aaaa", 0, NULL, 0))) {
                    177:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
                    178:                return 7;
                    179:        }
                    180:        if (!schedThread(root, thr, "mdaaaa this is thread task -j3", 4096, NULL, 0)) {
                    181:                printf("Error:: #%d - %s\n", sched_GetErrno(), sched_GetError());
1.3.4.2 ! misho     182:                printf("stack is too small\n");
1.2       misho     183:        }
                    184:        sleep(1);
                    185:        schedCancel(t);
                    186: 
                    187:        schedCallOnce(root, once, "000000", 42, NULL, 0);
                    188: 
                    189: //     schedPolling(root, &p, NULL);
                    190:        schedRun(root, &Kill);
                    191:        schedEnd(&root);
                    192: 
                    193:        close(f);
                    194:        return 0;
                    195: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>