--- tftpd/src/srv.c 2014/02/14 15:44:24 1.1.1.1.2.1 +++ tftpd/src/srv.c 2014/02/14 16:01:28 1.1.1.1.2.2 @@ -39,6 +39,7 @@ txPkt(sched_task_t *task) EVERBOSE(2, "Sended %d bytes", wlen); /* on error or argument, drop session */ if (TASK_ARG(task) == (void*) -1 || ntohs(tftp->tftp_opc) == TFTP_OPC_ERROR) { + schedTask(TASK_ROOT(task), execProg, "error", 0, NULL, TFTP_OPC_ERROR); schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); memset(&cli, 0, sizeof cli); @@ -106,6 +107,7 @@ txAck(sched_task_t *task) TASK_DATA(task), RPACK_OFF(pkt)); if (cli.close) { + schedTask(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_WRQ); schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); EVERBOSE(2, "Finish WRQ request"); @@ -193,6 +195,7 @@ RQ(sched_task_t *task) schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), TASK_DATA(task), 0); + schedTask(TASK_ROOT(task), execProg, "request", 0, NULL, cli.opc); cli.seq = 1; /* 1st ack */ taskExit(task, NULL); end: @@ -236,6 +239,7 @@ ACK(sched_task_t *task) schedEvent(TASK_ROOT(task), txData, NULL, TASK_FD(task), TASK_DATA(task), 0); else { + schedTask(TASK_ROOT(task), execProg, "complete", 0, NULL, TFTP_OPC_RRQ); schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_CALL, timeoutSession, NULL); schedEvent(TASK_ROOT(task), timeoutSession, NULL, 0, NULL, 0); EVERBOSE(2, "Finish RRQ request");