version 1.2.2.6, 2014/02/20 15:39:15
|
version 1.5, 2014/02/21 09:02:28
|
Line 6
|
Line 6
|
static void * |
static void * |
timeoutSession(sched_task_t *task) |
timeoutSession(sched_task_t *task) |
{ |
{ |
|
rpack_t *pkt = TASK_DATA(task); |
|
|
ETRACE(); |
ETRACE(); |
|
|
/* drop session */ |
/* drop session */ |
if (cli.fd > 2) |
if (cli.fd > 2) |
close(cli.fd); |
close(cli.fd); |
|
rpack_resize(pkt, TFTP_PKT_MAX); |
memset(&cli, 0, sizeof cli); |
memset(&cli, 0, sizeof cli); |
|
|
taskExit(task, NULL); |
taskExit(task, NULL); |
Line 35 txPkt(sched_task_t *task)
|
Line 38 txPkt(sched_task_t *task)
|
schedEvent(TASK_ROOT(task), execProg, "error", 0, NULL, TFTP_OPC_ERROR); |
schedEvent(TASK_ROOT(task), execProg, "error", 0, NULL, TFTP_OPC_ERROR); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, |
timeoutSession, NULL); |
timeoutSession, NULL); |
schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, TASK_DATA(task), 0); |
} else |
} else |
EVERBOSE(2, "Sended %d bytes", wlen); |
EVERBOSE(2, "Sended %d bytes", wlen); |
/* on error or argument, drop session */ |
/* on error or argument, drop session */ |
Line 43 txPkt(sched_task_t *task)
|
Line 46 txPkt(sched_task_t *task)
|
schedEvent(TASK_ROOT(task), execProg, "error", 0, NULL, TFTP_OPC_ERROR); |
schedEvent(TASK_ROOT(task), execProg, "error", 0, NULL, TFTP_OPC_ERROR); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, |
timeoutSession, NULL); |
timeoutSession, NULL); |
schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, TASK_DATA(task), 0); |
} |
} |
|
|
taskExit(task, NULL); |
taskExit(task, NULL); |
Line 73 txData(sched_task_t *task)
|
Line 76 txData(sched_task_t *task)
|
len = pread(cli.fd, RPACK_NEXT(pkt), len, (cli.seq - 1) * cli.siz); |
len = pread(cli.fd, RPACK_NEXT(pkt), len, (cli.seq - 1) * cli.siz); |
if (len == -1) { |
if (len == -1) { |
ESYSERR(0); |
ESYSERR(0); |
code = htole16(3); | code = htons(3); |
goto end; |
goto end; |
} else { |
} else { |
rpack_rnext(pkt, len); |
rpack_rnext(pkt, len); |
Line 91 end:
|
Line 94 end:
|
n = htons(TFTP_OPC_ERROR); |
n = htons(TFTP_OPC_ERROR); |
rpack_uint16(pkt, &n, 0); |
rpack_uint16(pkt, &n, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[le16toh(code)].err_msg, strlen(errs[le16toh(code)].err_msg) + 1); | rpack_rdata(pkt, errs[ntohs(code)].err_msg, strlen(errs[ntohs(code)].err_msg) + 1); |
|
|
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
Line 117 txAck(sched_task_t *task)
|
Line 120 txAck(sched_task_t *task)
|
if (cli.close) { |
if (cli.close) { |
schedEvent(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_WRQ); |
schedEvent(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_WRQ); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, TASK_DATA(task), 0); |
EVERBOSE(2, "Finish WRQ request"); |
EVERBOSE(2, "Finish WRQ request"); |
} |
} |
taskExit(task, NULL); |
taskExit(task, NULL); |
Line 129 getOpts(rpack_t * __restrict pkt, int rlen)
|
Line 132 getOpts(rpack_t * __restrict pkt, int rlen)
|
char *opt, *val; |
char *opt, *val; |
int len; |
int len; |
|
|
|
if (!rlen) |
|
return -1; |
|
|
do { |
do { |
/* option */ |
/* option */ |
len = str_getString(RPACK_NEXT(pkt), RPACK_REMAIN(pkt), NULL); |
len = str_getString(RPACK_NEXT(pkt), RPACK_REMAIN(pkt), NULL); |
Line 139 getOpts(rpack_t * __restrict pkt, int rlen)
|
Line 145 getOpts(rpack_t * __restrict pkt, int rlen)
|
opt = (char*) rpack_rnext(pkt, len); |
opt = (char*) rpack_rnext(pkt, len); |
if (!opt) |
if (!opt) |
return -1; |
return -1; |
|
EVERBOSE(7, "opt=%s rlen=%d", opt, rlen); |
/* value */ |
/* value */ |
len = str_getString(RPACK_NEXT(pkt), RPACK_REMAIN(pkt), NULL); |
len = str_getString(RPACK_NEXT(pkt), RPACK_REMAIN(pkt), NULL); |
if (len == -1) |
if (len == -1) |
Line 148 getOpts(rpack_t * __restrict pkt, int rlen)
|
Line 155 getOpts(rpack_t * __restrict pkt, int rlen)
|
val = (char*) rpack_rnext(pkt, len); |
val = (char*) rpack_rnext(pkt, len); |
if (!val) |
if (!val) |
return -1; |
return -1; |
|
EVERBOSE(7, "val=%s rlen=%d", val, rlen); |
|
|
if (!strcasecmp(opt, TFTP_OPT_BLKSIZE)) { | if (!strcasecmp(opt, TFTP_OPT_BLKSIZE)) |
len = strtol(val, NULL, 10); | cli.tmp = strtol(val, NULL, 10); |
if (len > TFTP_LOAD_MAX) { | else if (!strcasecmp(opt, TFTP_OPT_TSIZE)) |
cli.siz = len; | |
if (rpack_resize(pkt, cli.siz + 4)) | |
cli.siz = TFTP_PKT_MAX; | |
} | |
} else if (!strcasecmp(opt, TFTP_OPT_TSIZE)) | |
cli.tsiz = strtoll(val, NULL, 10); |
cli.tsiz = strtoll(val, NULL, 10); |
else if (!strcasecmp(opt, TFTP_OPT_TIMEOUT)) |
else if (!strcasecmp(opt, TFTP_OPT_TIMEOUT)) |
cli.tout = strtol(val, NULL, 10); | cli.tout.tv_sec = strtol(val, NULL, 10); |
else if (!strcasecmp(opt, TFTP_OPT_ROLLOVER)) | else if (!strcasecmp(opt, TFTP_OPT_ROLLOVER)) { |
cli.roll = strtol(val, NULL, 10); |
cli.roll = strtol(val, NULL, 10); |
else | cli.roll++; |
return -1; | } |
} while (rlen > 0); |
} while (rlen > 0); |
|
|
EVERBOSE(4, "blksize=%u tsize=%llu timeout=%u rollover=%u", |
EVERBOSE(4, "blksize=%u tsize=%llu timeout=%u rollover=%u", |
cli.siz, cli.tsiz, cli.tout, cli.roll); | cli.siz, cli.tsiz, cli.tout.tv_sec, cli.roll - 1); |
return 0; |
return 0; |
} |
} |
|
|
Line 200 txOack(sched_task_t *task)
|
Line 203 txOack(sched_task_t *task)
|
rpack_rdata(pkt, TFTP_OPT_TSIZE, strlen(TFTP_OPT_TSIZE) + 1); |
rpack_rdata(pkt, TFTP_OPT_TSIZE, strlen(TFTP_OPT_TSIZE) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
} |
} |
if (cli.tout) { | if (cli.tout.tv_sec) { |
memset(szStr, 0, sizeof szStr); |
memset(szStr, 0, sizeof szStr); |
snprintf(szStr, sizeof szStr, "%u", cli.tout); | snprintf(szStr, sizeof szStr, "%u", cli.tout.tv_sec); |
rpack_rdata(pkt, TFTP_OPT_TIMEOUT, strlen(TFTP_OPT_TIMEOUT) + 1); |
rpack_rdata(pkt, TFTP_OPT_TIMEOUT, strlen(TFTP_OPT_TIMEOUT) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
} |
} |
if (cli.roll) { |
if (cli.roll) { |
memset(szStr, 0, sizeof szStr); |
memset(szStr, 0, sizeof szStr); |
snprintf(szStr, sizeof szStr, "%u", cli.roll); | snprintf(szStr, sizeof szStr, "%u", cli.roll - 1); |
rpack_rdata(pkt, TFTP_OPT_ROLLOVER, strlen(TFTP_OPT_ROLLOVER) + 1); |
rpack_rdata(pkt, TFTP_OPT_ROLLOVER, strlen(TFTP_OPT_ROLLOVER) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
rpack_rdata(pkt, szStr, strlen(szStr) + 1); |
} |
} |
|
|
EVERBOSE(4, "blksize=%u tsize=%llu timeout=%u rollover=%u", |
EVERBOSE(4, "blksize=%u tsize=%llu timeout=%u rollover=%u", |
cli.siz, cli.tsiz, cli.tout, cli.roll); | cli.siz, cli.tsiz, cli.tout.tv_sec, cli.roll - 1); |
schedEvent(TASK_ROOT(task), txPkt, NULL, TASK_FD(task), | schedCallOnce(TASK_ROOT(task), txPkt, NULL, TASK_FD(task), |
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
taskExit(task, NULL); |
taskExit(task, NULL); |
} |
} |
Line 233 RQ(sched_task_t *task)
|
Line 236 RQ(sched_task_t *task)
|
|
|
cli.siz = TFTP_LOAD_MAX; |
cli.siz = TFTP_LOAD_MAX; |
cli.opc = ntohs(rpack_uint16(pkt, NULL, 0)); |
cli.opc = ntohs(rpack_uint16(pkt, NULL, 0)); |
len = str_getString(tftp->tftp_data, rlen, &str); | len = str_getString(RPACK_NEXT(pkt), rlen, &str); |
if (len == -1) |
if (len == -1) |
goto end; |
goto end; |
else { |
else { |
|
strlcpy(cli.file, (char*) RPACK_NEXT(pkt), sizeof cli.file); |
rlen -= len; |
rlen -= len; |
rpack_rnext(pkt, len); |
rpack_rnext(pkt, len); |
strlcpy(cli.file, (char*) tftp->tftp_data, sizeof cli.file); |
|
} |
} |
len = str_getString((const u_char*) str, rlen, NULL); |
len = str_getString((const u_char*) str, rlen, NULL); |
if (len == -1) |
if (len == -1) |
Line 253 RQ(sched_task_t *task)
|
Line 256 RQ(sched_task_t *task)
|
strlcpy(cli.mode, TFTP_MODE_OCTET, sizeof cli.mode); |
strlcpy(cli.mode, TFTP_MODE_OCTET, sizeof cli.mode); |
else if (!strcasecmp(str, TFTP_MODE_MAIL)) { |
else if (!strcasecmp(str, TFTP_MODE_MAIL)) { |
strlcpy(cli.mode, TFTP_MODE_MAIL, sizeof cli.mode); |
strlcpy(cli.mode, TFTP_MODE_MAIL, sizeof cli.mode); |
code = htole16(4); | code = htons(4); |
goto end; |
goto end; |
} else { |
} else { |
code = htole16(1); | code = htons(1); |
goto end; |
goto end; |
} |
} |
} |
} |
Line 278 RQ(sched_task_t *task)
|
Line 281 RQ(sched_task_t *task)
|
cli.fd = open(cli.file, code, 0644); |
cli.fd = open(cli.file, code, 0644); |
if (cli.fd == -1) { |
if (cli.fd == -1) { |
if (errno == EACCES) |
if (errno == EACCES) |
code = htole16(2); | code = htons(2); |
else if (errno == ENFILE) |
else if (errno == ENFILE) |
code = htole16(3); | code = htons(3); |
else if (errno == EEXIST) |
else if (errno == EEXIST) |
code = htole16(6); | code = htons(6); |
else |
else |
code = htole16(0); | code = htons(0); |
ESYSERR(0); |
ESYSERR(0); |
goto end; |
goto end; |
} else |
} else |
Line 292 RQ(sched_task_t *task)
|
Line 295 RQ(sched_task_t *task)
|
|
|
schedEvent(TASK_ROOT(task), execProg, "request", 0, NULL, cli.opc); |
schedEvent(TASK_ROOT(task), execProg, "request", 0, NULL, cli.opc); |
|
|
if (!RPACK_ISEND(pkt) && !getOpts(pkt, rlen)) | if (!getOpts(pkt, rlen)) { |
| if (cli.tmp > TFTP_LOAD_MAX) { |
| if (rpack_resize(pkt, cli.tmp + 4)) |
| ELIBERR(elwix); |
| else |
| cli.siz = cli.tmp; |
| } |
| if (cli.tout.tv_sec) { |
| schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, |
| timeoutSession, NULL); |
| schedTimer(TASK_ROOT(task), timeoutSession, NULL, |
| cli.tout, TASK_DATA(task), 0); |
| } |
schedEvent(TASK_ROOT(task), txOack, NULL, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txOack, NULL, TASK_FD(task), |
TASK_DATA(task), 0); |
TASK_DATA(task), 0); |
else if (cli.opc == TFTP_OPC_WRQ) { | } else if (cli.opc == TFTP_OPC_WRQ) { |
/* ack */ |
/* ack */ |
tftp->tftp_opc = htons(TFTP_OPC_ACK); |
tftp->tftp_opc = htons(TFTP_OPC_ACK); |
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
Line 315 end:
|
Line 330 end:
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[le16toh(code)].err_msg, strlen(errs[le16toh(code)].err_msg) + 1); | rpack_rdata(pkt, errs[ntohs(code)].err_msg, strlen(errs[ntohs(code)].err_msg) + 1); |
|
|
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
Line 334 ACK(sched_task_t *task)
|
Line 349 ACK(sched_task_t *task)
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
code = rpack_uint16(pkt, NULL, 0); |
code = rpack_uint16(pkt, NULL, 0); |
if (ntohs(code) != TFTP_OPC_ACK) { |
if (ntohs(code) != TFTP_OPC_ACK) { |
code = htole16(5); | code = htons(5); |
goto end; |
goto end; |
} |
} |
|
|
code = rpack_uint16(pkt, NULL, 0); |
code = rpack_uint16(pkt, NULL, 0); |
if (ntohs(code) > cli.seq || (ntohs(code) < (cli.seq - 1))) { |
if (ntohs(code) > cli.seq || (ntohs(code) < (cli.seq - 1))) { |
code = htole16(5); | code = htons(5); |
goto end; |
goto end; |
} else if (ntohs(code) == cli.seq) | } else if (ntohs(code) == cli.seq) { |
cli.seq++; | /* check for rollover seq id */ |
| if (cli.roll && cli.seq == USHRT_MAX) |
| cli.seq = cli.roll - 1; |
| else |
| cli.seq++; |
| } |
|
|
EVERBOSE(3, "ACK:: seq=%hu; my new seq=%hu;", ntohs(code), cli.seq); |
EVERBOSE(3, "ACK:: seq=%hu; my new seq=%hu;", ntohs(code), cli.seq); |
|
|
Line 353 ACK(sched_task_t *task)
|
Line 373 ACK(sched_task_t *task)
|
else { |
else { |
schedEvent(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_RRQ); |
schedEvent(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_RRQ); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, TASK_DATA(task), 0); |
EVERBOSE(2, "Finish RRQ request"); |
EVERBOSE(2, "Finish RRQ request"); |
} |
} |
taskExit(task, NULL); |
taskExit(task, NULL); |
Line 362 end:
|
Line 382 end:
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[le16toh(code)].err_msg, strlen(errs[le16toh(code)].err_msg) + 1); | rpack_rdata(pkt, errs[ntohs(code)].err_msg, strlen(errs[ntohs(code)].err_msg) + 1); |
|
|
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
Line 382 DATA(sched_task_t *task)
|
Line 402 DATA(sched_task_t *task)
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
code = rpack_uint16(pkt, NULL, 0); |
code = rpack_uint16(pkt, NULL, 0); |
if (ntohs(code) != TFTP_OPC_DATA) { |
if (ntohs(code) != TFTP_OPC_DATA) { |
code = htole16(5); | code = htons(5); |
goto end; |
goto end; |
} |
} |
|
|
code = rpack_uint16(pkt, NULL, 0); |
code = rpack_uint16(pkt, NULL, 0); |
if (ntohs(code) < cli.seq || ntohs(code) > cli.seq + 1) { |
if (ntohs(code) < cli.seq || ntohs(code) > cli.seq + 1) { |
code = htole16(5); | code = htons(5); |
goto end; |
goto end; |
} else |
} else |
cli.seq = ntohs(code); |
cli.seq = ntohs(code); |
Line 405 DATA(sched_task_t *task)
|
Line 425 DATA(sched_task_t *task)
|
len = pwrite(cli.fd, RPACK_NEXT(pkt), len, (cli.seq - 1) * cli.siz); |
len = pwrite(cli.fd, RPACK_NEXT(pkt), len, (cli.seq - 1) * cli.siz); |
if (len == -1) { |
if (len == -1) { |
ESYSERR(0); |
ESYSERR(0); |
code = htole16(3); | code = htons(3); |
goto end; |
goto end; |
} else { |
} else { |
rpack_rnext(pkt, len); |
rpack_rnext(pkt, len); |
Line 419 end:
|
Line 439 end:
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, NULL, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[le16toh(code)].err_msg, strlen(errs[le16toh(code)].err_msg) + 1); | rpack_rdata(pkt, errs[ntohs(code)].err_msg, strlen(errs[ntohs(code)].err_msg) + 1); |
|
|
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txPkt, (void*) -1, TASK_FD(task), |
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
Line 445 rxPkt(sched_task_t *task)
|
Line 465 rxPkt(sched_task_t *task)
|
goto end; |
goto end; |
} else if (!cli.addr.sa.sa_len) { |
} else if (!cli.addr.sa.sa_len) { |
cli.addr = sa; |
cli.addr = sa; |
|
RPACK_REWIND(pkt); |
switch (ntohs(tftp->tftp_opc)) { |
switch (ntohs(tftp->tftp_opc)) { |
case TFTP_OPC_RRQ: |
case TFTP_OPC_RRQ: |
case TFTP_OPC_WRQ: |
case TFTP_OPC_WRQ: |
Line 456 rxPkt(sched_task_t *task)
|
Line 477 rxPkt(sched_task_t *task)
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
code = htons(TFTP_OPC_ERROR); |
code = htons(TFTP_OPC_ERROR); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
code = htole16(4); | code = htons(4); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[4].err_msg, strlen(errs[4].err_msg) + 1); |
rpack_rdata(pkt, errs[4].err_msg, strlen(errs[4].err_msg) + 1); |
|
|
Line 484 rxPkt(sched_task_t *task)
|
Line 505 rxPkt(sched_task_t *task)
|
RPACK_REWIND(pkt); |
RPACK_REWIND(pkt); |
code = htons(TFTP_OPC_ERROR); |
code = htons(TFTP_OPC_ERROR); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
code = htole16(4); | code = htons(4); |
rpack_uint16(pkt, &code, 0); |
rpack_uint16(pkt, &code, 0); |
rpack_rdata(pkt, errs[4].err_msg, strlen(errs[4].err_msg) + 1); |
rpack_rdata(pkt, errs[4].err_msg, strlen(errs[4].err_msg) + 1); |
|
|
Line 494 rxPkt(sched_task_t *task)
|
Line 515 rxPkt(sched_task_t *task)
|
} |
} |
|
|
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); |
schedTimer(TASK_ROOT(task), timeoutSession, NULL, timeout, NULL, 0); | schedTimer(TASK_ROOT(task), timeoutSession, NULL, |
| cli.tout.tv_sec ? cli.tout : timeout, TASK_DATA(task), 0); |
end: |
end: |
schedReadSelf(task); |
schedReadSelf(task); |
taskExit(task, NULL); |
taskExit(task, NULL); |