Diff for /tftpd/src/srv.c between versions 1.2.2.2 and 1.2.2.5

version 1.2.2.2, 2014/02/20 01:15:45 version 1.2.2.5, 2014/02/20 14:20:42
Line 63  txData(sched_task_t *task) Line 63  txData(sched_task_t *task)
         n = htons(cli.seq);          n = htons(cli.seq);
         rpack_uint16(pkt, &n, 0);          rpack_uint16(pkt, &n, 0);
   
        len = pread(cli.fd, RPACK_NEXT(pkt), cli.siz, (cli.seq - 1) * cli.siz);        /* max file size check */
         if (cli.tsiz && cli.tsiz <= cli.seq * cli.siz) {
                 len = MAX(0, cli.tsiz - (cli.seq - 1) * cli.siz);
                 cli.close = 42; /* last sended packet, should be close! */
         } else
                 len = 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 = htole16(3);
Line 150  getOpts(rpack_t * __restrict pkt) Line 157  getOpts(rpack_t * __restrict pkt)
                         return -1;                          return -1;
         } while (!RPACK_ISEND(pkt));          } while (!RPACK_ISEND(pkt));
   
           EVERBOSE(4, "blksize=%u tsize=%llu timeout=%u", cli.siz, cli.tsiz, cli.tout);
         return 0;          return 0;
 }  }
   
Line 366  DATA(sched_task_t *task) Line 374  DATA(sched_task_t *task)
         } else          } else
                 cli.seq = ntohs(code);                  cli.seq = ntohs(code);
   
           /* max file size check */
         len = TASK_DATLEN(task) - RPACK_OFF(pkt);          len = TASK_DATLEN(task) - RPACK_OFF(pkt);
           if (cli.tsiz && cli.tsiz <= cli.seq * cli.siz)
                   len = MIN(len, cli.tsiz - (cli.seq - 1) * cli.siz);
         if (len < cli.siz)          if (len < cli.siz)
                 cli.close = 42; /* last received packet, should be close! */                  cli.close = 42; /* last received packet, should be close! */
   
Line 449  rxPkt(sched_task_t *task) Line 460  rxPkt(sched_task_t *task)
                                                 TASK_DATA(task), rlen);                                                  TASK_DATA(task), rlen);
                                 break;                                  break;
                         case TFTP_OPC_OACK:                          case TFTP_OPC_OACK:
                                 ELOGGER(LOG_WARNING, "oack");  
                                 /*  
                                 schedEvent(TASK_ROOT(task), OACK, NULL, TASK_FD(task),   
                                                 TASK_DATA(task), rlen);  
                                                 */  
                                 break;  
                         case TFTP_OPC_ERROR:                          case TFTP_OPC_ERROR:
                         default:                          default:
                                 RPACK_REWIND(pkt);                                  RPACK_REWIND(pkt);

Removed from v.1.2.2.2  
changed lines
  Added in v.1.2.2.5


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