version 1.1.1.1.2.2, 2014/02/14 16:01:28
|
version 1.1.1.1.2.3, 2014/02/17 14:28:02
|
Line 32 txPkt(sched_task_t *task)
|
Line 32 txPkt(sched_task_t *task)
|
else if (wlen != TASK_DATLEN(task)) { |
else if (wlen != TASK_DATLEN(task)) { |
EERROR(EIO, "Sended %d bytes != packet %d bytes", |
EERROR(EIO, "Sended %d bytes != packet %d bytes", |
wlen, TASK_DATLEN(task)); |
wlen, TASK_DATLEN(task)); |
|
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); |
memset(&cli, 0, sizeof(sockaddr_t)); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 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 */ |
if (TASK_ARG(task) == (void*) -1 || ntohs(tftp->tftp_opc) == TFTP_OPC_ERROR) { |
if (TASK_ARG(task) == (void*) -1 || ntohs(tftp->tftp_opc) == TFTP_OPC_ERROR) { |
schedTask(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); |
memset(&cli, 0, sizeof cli); | schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); |
} |
} |
|
|
taskExit(task, NULL); |
taskExit(task, NULL); |
Line 107 txAck(sched_task_t *task)
|
Line 108 txAck(sched_task_t *task)
|
TASK_DATA(task), RPACK_OFF(pkt)); |
TASK_DATA(task), RPACK_OFF(pkt)); |
|
|
if (cli.close) { |
if (cli.close) { |
schedTask(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, NULL, 0); |
EVERBOSE(2, "Finish WRQ request"); |
EVERBOSE(2, "Finish WRQ request"); |
Line 182 RQ(sched_task_t *task)
|
Line 183 RQ(sched_task_t *task)
|
} else |
} else |
cli.seq = 0; |
cli.seq = 0; |
|
|
|
schedEvent(TASK_ROOT(task), execProg, "request", 0, NULL, cli.opc); |
|
|
if (cli.opc == TFTP_OPC_WRQ) { |
if (cli.opc == TFTP_OPC_WRQ) { |
/* ack */ |
/* ack */ |
tftp->tftp_opc = htons(TFTP_OPC_ACK); |
tftp->tftp_opc = htons(TFTP_OPC_ACK); |
Line 195 RQ(sched_task_t *task)
|
Line 198 RQ(sched_task_t *task)
|
schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), |
TASK_DATA(task), 0); |
TASK_DATA(task), 0); |
|
|
schedTask(TASK_ROOT(task), execProg, "request", 0, NULL, cli.opc); |
|
cli.seq = 1; /* 1st ack */ |
cli.seq = 1; /* 1st ack */ |
taskExit(task, NULL); |
taskExit(task, NULL); |
end: |
end: |
Line 239 ACK(sched_task_t *task)
|
Line 241 ACK(sched_task_t *task)
|
schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), |
schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), |
TASK_DATA(task), 0); |
TASK_DATA(task), 0); |
else { |
else { |
schedTask(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, NULL, 0); |
EVERBOSE(2, "Finish RRQ request"); |
EVERBOSE(2, "Finish RRQ request"); |