Diff for /tftpd/src/srv.c between versions 1.2.2.7 and 1.2.2.8

version 1.2.2.7, 2014/02/20 16:04:03 version 1.2.2.8, 2014/02/20 16:30:05
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 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 154  getOpts(rpack_t * __restrict pkt, int rlen) Line 157  getOpts(rpack_t * __restrict pkt, int rlen)
                         return -1;                          return -1;
                 EVERBOSE(7, "val=%s rlen=%d", val, rlen);                  EVERBOSE(7, "val=%s rlen=%d", val, rlen);
   
                if (!strcasecmp(opt, TFTP_OPT_BLKSIZE)) {                if (!strcasecmp(opt, TFTP_OPT_BLKSIZE))
                         cli.tmp = strtol(val, NULL, 10);                          cli.tmp = strtol(val, NULL, 10);
                } else if (!strcasecmp(opt, TFTP_OPT_TSIZE))                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);
         } 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);
         return 0;          return 0;
 }  }
   
Line 198  txOack(sched_task_t *task) Line 201  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);
         }          }
Line 212  txOack(sched_task_t *task) Line 215  txOack(sched_task_t *task)
         }          }
   
         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);
         schedEvent(TASK_ROOT(task), txPkt, NULL, TASK_FD(task),           schedEvent(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 297  RQ(sched_task_t *task) Line 300  RQ(sched_task_t *task)
                         else                          else
                                 cli.siz = cli.tmp;                                  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) {
Line 357  ACK(sched_task_t *task) Line 366  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 498  rxPkt(sched_task_t *task) Line 507  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);

Removed from v.1.2.2.7  
changed lines
  Added in v.1.2.2.8


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