Binkp code cleanup

This commit is contained in:
Michiel Broek 2003-12-24 19:52:23 +00:00
parent 67a32996f6
commit 24cc63cd91
3 changed files with 184 additions and 140 deletions

View File

@ -3,6 +3,12 @@ $Id$
v0.39.5 24-Dec-2003 v0.39.5 24-Dec-2003
mbcico:
Binkp code cleanup.
script:
Fixed NetBSD init script
v0.39.4 08-Dec-2003 - 24-Dec-2003 v0.39.4 08-Dec-2003 - 24-Dec-2003
general: general:

View File

@ -124,12 +124,12 @@ static char *opstate[] = { (char *)"No", (char *)"WeCan", (char *)"WeWant", (cha
static time_t Timer; static time_t Timer;
static int CRAMflag = FALSE; /* CRAM option flag */ static int CRAMflag = FALSE; /* CRAM option flag */
static int Secure = FALSE; /* Secure session */ static int Secure = FALSE; /* Secure session */
unsigned long nethold, mailhold; /* Trafic for the remote */
int transferred = FALSE; /* Anything transferred in batch */ int transferred = FALSE; /* Anything transferred in batch */
int batchnr = 0;
unsigned char *MD_challenge = NULL; /* Received CRAM challenge data */ unsigned char *MD_challenge = NULL; /* Received CRAM challenge data */
int ext_rand = 0; int ext_rand = 0;
struct binkprec { struct binkprec {
int role; /* 1=orig, 0=answer */ int role; /* 1=orig, 0=answer */
int RxState; /* Receiver state */ int RxState; /* Receiver state */
@ -149,6 +149,29 @@ struct binkprec {
int MBflag; /* MB option flag */ int MBflag; /* MB option flag */
int Major; /* Remote major protocol version */ int Major; /* Remote major protocol version */
int Minor; /* Remote minor protocol version */ int Minor; /* Remote minor protocol version */
int rc; /* Protocol return code */
int rxlen; /* Receive buffer length */
int txlen; /* Length of transmitted data block */
char *txbuf; /* Transmitter buffer */
char *rxbuf; /* Receiver buffer */
FILE *txfp; /* File in transmitter */
FILE *rxfp; /* File in receiver */
int txpos; /* Transmitter position */
int rxpos; /* Receiver position */
int stxpos; /* Start transmitter position */
int cmd; /* Command flag */
int GotFrame; /* Got Frame flag */
unsigned short header; /* Frame header */
int blklen; /* Block length */
off_t rxbytes; /* Receiver bytecount */
struct timeval rxtvstart; /* Receive file start */
struct timeval rxtvend; /* Receiver file end */
struct timeval txtvstart; /* Transmit file start */
struct timeval txtvend; /* Transmit file end */
struct timezone tz; /* Timezone */
unsigned long nethold; /* Netmail on hold */
unsigned long mailhold; /* Packed mail (files) on hold */
int batchnr; /* Batch number */
}; };
struct binkprec bp; /* Global structure */ struct binkprec bp; /* Global structure */
@ -164,6 +187,19 @@ void binkp_init(void)
bp.Major = 1; bp.Major = 1;
bp.Minor = 0; bp.Minor = 0;
bp.DidSendGET = FALSE; bp.DidSendGET = FALSE;
bp.rc = 0;
bp.rxlen = 0;
bp.txbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
bp.rxbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
bp.txfp = NULL;
bp.rxfp = NULL;
bp.txpos = 0;
bp.rxpos = 0;
bp.stxpos = 0;
bp.cmd = FALSE;
bp.GotFrame = FALSE;
bp.header = 0;
bp.batchnr = 0;
} }
@ -175,6 +211,10 @@ void binkp_deinit(void)
free(bp.lname); free(bp.lname);
if (bp.gname) if (bp.gname)
free(bp.gname); free(bp.gname);
if (bp.txbuf)
free(bp.txbuf);
if (bp.rxbuf)
free(bp.rxbuf);
} }
@ -1115,9 +1155,9 @@ void fill_binkp_list(binkp_list **bll, file_list *fal, off_t offs)
return; return;
} }
if (strstr(fal->remote, (char *)".pkt")) if (strstr(fal->remote, (char *)".pkt"))
nethold += tstat.st_size; bp.nethold += tstat.st_size;
else else
mailhold += tstat.st_size; bp.mailhold += tstat.st_size;
for (tmpl = bll; *tmpl; tmpl = &((*tmpl)->next)); for (tmpl = bll; *tmpl; tmpl = &((*tmpl)->next));
*tmpl = (binkp_list *)malloc(sizeof(binkp_list)); *tmpl = (binkp_list *)malloc(sizeof(binkp_list));
@ -1154,72 +1194,16 @@ void debug_binkp_list(binkp_list **bll)
} }
/*
int binkp_batch(file_list *to_send) * Get a fram for the batch
*/
void batch_receive_frame(void);
void batch_receive_frame(void)
{ {
int rc = 0, NotDone, rxlen = 0, txlen = 0, rxerror = FALSE; int c;
static char *txbuf, *rxbuf;
FILE *txfp = NULL, *rxfp = NULL;
long txpos = 0, rxpos = 0, stxpos = 0, written;
int sverr, cmd = FALSE, GotFrame = FALSE, blklen = 0, c, Found = FALSE;
unsigned short header = 0;
off_t rxbytes;
binkp_list *bll = NULL, *tmp, *tmpg, *cursend = NULL;
file_list *tsl;
struct timeval rxtvstart, rxtvend;
struct timeval txtvstart, txtvend;
struct timezone tz;
struct statfs sfs;
rxtvstart.tv_sec = rxtvstart.tv_usec = 0;
rxtvend.tv_sec = rxtvend.tv_usec = 0;
txtvstart.tv_sec = txtvstart.tv_usec = 0;
txtvend.tv_sec = txtvend.tv_usec = 0;
tz.tz_minuteswest = tz.tz_dsttime = 0;
batchnr++;
Syslog('+', "Binkp: starting batch %d", batchnr);
IsDoing("Binkp %s %s", (bp.role == 1)?"out":"inb", ascfnode(remote->addr, 0xf));
txbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
rxbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
// TfState = Switch;
bp.RxState = RxWaitFile;
bp.TxState = TxGetNextFile;
binkp_settimer(BINKP_TIMEOUT);
nethold = mailhold = 0L;
transferred = FALSE;
/*
* Build a new filelist from the existing filelist.
* This one is special for binkp behaviour.
*/
for (tsl = to_send; tsl; tsl = tsl->next) {
if (tsl->remote != NULL)
fill_binkp_list(&bll, tsl, 0L);
}
debug_binkp_list(&bll);
Syslog('+', "Binkp: mail %ld, files %ld bytes", nethold, mailhold);
binkp_send_control(MM_NUL, "TRF %ld %ld", nethold, mailhold);
while ((bp.RxState != RxDone) || (bp.TxState != TxDone)) {
Nopper();
if (binkp_expired()) {
Syslog('!', "Binkp: Transfer timeout");
Syslog('b', "Binkp: TxState=%s, RxState=%s, rxlen=%d", txstate[bp.TxState], rxstate[bp.RxState], rxlen);
bp.RxState = RxDone;
bp.TxState = TxDone;
binkp_send_control(MM_ERR, "Transfer timeout");
rc = MBERR_FTRANSFER;
break;
}
/*
* Receiver binkp frame
*/
for (;;) { for (;;) {
if (GotFrame) { if (bp.GotFrame) {
Syslog('b', "Binkp: WARNING: frame not processed"); Syslog('b', "Binkp: WARNING: frame not processed");
break; break;
} else { } else {
@ -1233,30 +1217,88 @@ int binkp_batch(file_list *to_send)
Syslog('?', "Binkp: receiver status %s", ttystat[c]); Syslog('?', "Binkp: receiver status %s", ttystat[c]);
bp.TxState = TxDone; bp.TxState = TxDone;
bp.RxState = RxDone; bp.RxState = RxDone;
rc = (MBERR_TTYIO + (-c)); bp.rc = (MBERR_TTYIO + (-c));
break; break;
} else { } else {
switch (rxlen) { switch (bp.rxlen) {
case 0: header = c << 8; case 0: bp.header = c << 8;
break; break;
case 1: header += c; case 1: bp.header += c;
break; break;
default:rxbuf[rxlen-2] = c; default:bp.rxbuf[bp.rxlen-2] = c;
} }
if (rxlen == 1) { if (bp.rxlen == 1) {
cmd = header & 0x8000; bp.cmd = bp.header & 0x8000;
blklen = header & 0x7fff; bp.blklen = bp.header & 0x7fff;
} }
if ((rxlen == (blklen + 1) && (rxlen >= 1))) { if ((bp.rxlen == (bp.blklen + 1) && (bp.rxlen >= 1))) {
GotFrame = TRUE; bp.GotFrame = TRUE;
binkp_settimer(BINKP_TIMEOUT); binkp_settimer(BINKP_TIMEOUT);
rxbuf[rxlen-1] = '\0'; bp.rxbuf[bp.rxlen-1] = '\0';
break; break;
} }
rxlen++; bp.rxlen++;
} }
} }
} }
}
int binkp_batch(file_list *to_send)
{
int NotDone, written, Found = FALSE;
off_t rxbytes;
binkp_list *bll = NULL, *tmp, *tmpg, *cursend = NULL;
file_list *tsl;
struct statfs sfs;
bp.rxtvstart.tv_sec = bp.rxtvstart.tv_usec = 0;
bp.rxtvend.tv_sec = bp.rxtvend.tv_usec = 0;
bp.txtvstart.tv_sec = bp.txtvstart.tv_usec = 0;
bp.txtvend.tv_sec = bp.txtvend.tv_usec = 0;
bp.tz.tz_minuteswest = bp.tz.tz_dsttime = 0;
bp.batchnr++;
Syslog('+', "Binkp: starting batch %d", bp.batchnr);
IsDoing("Binkp %s %s", (bp.role == 1)?"out":"inb", ascfnode(remote->addr, 0xf));
// TfState = Switch;
bp.RxState = RxWaitFile;
bp.TxState = TxGetNextFile;
binkp_settimer(BINKP_TIMEOUT);
bp.nethold = bp.mailhold = 0L;
transferred = FALSE;
/*
* Build a new filelist from the existing filelist.
* This one is special for binkp behaviour.
*/
for (tsl = to_send; tsl; tsl = tsl->next) {
if (tsl->remote != NULL)
fill_binkp_list(&bll, tsl, 0L);
}
debug_binkp_list(&bll);
Syslog('+', "Binkp: mail %ld, files %ld bytes", bp.nethold, bp.mailhold);
binkp_send_control(MM_NUL, "TRF %ld %ld", bp.nethold, bp.mailhold);
while ((bp.RxState != RxDone) || (bp.TxState != TxDone)) {
Nopper();
if (binkp_expired()) {
Syslog('!', "Binkp: Transfer timeout");
Syslog('b', "Binkp: TxState=%s, RxState=%s, rxlen=%d", txstate[bp.TxState], rxstate[bp.RxState], bp.rxlen);
bp.RxState = RxDone;
bp.TxState = TxDone;
binkp_send_control(MM_ERR, "Transfer timeout");
bp.rc = MBERR_FTRANSFER;
break;
}
/*
* Receiver binkp frame
*/
batch_receive_frame();
/* /*
* Transmitter state machine * Transmitter state machine
@ -1275,10 +1317,9 @@ int binkp_batch(file_list *to_send)
txflock.l_start = 0L; txflock.l_start = 0L;
txflock.l_len = 0L; txflock.l_len = 0L;
txfp = fopen(tmp->local, "r"); bp.txfp = fopen(tmp->local, "r");
if (txfp == NULL) { if (bp.txfp == NULL) {
sverr = errno; if ((errno == ENOENT) || (errno == EINVAL)) {
if ((sverr == ENOENT) || (sverr == EINVAL)) {
Syslog('+', "Binkp: file %s doesn't exist, removing", MBSE_SS(tmp->local)); Syslog('+', "Binkp: file %s doesn't exist, removing", MBSE_SS(tmp->local));
tmp->state = Got; tmp->state = Got;
} else { } else {
@ -1288,19 +1329,20 @@ int binkp_batch(file_list *to_send)
break; break;
} }
if (fcntl(fileno(txfp), F_SETLK, &txflock) != 0) { if (fcntl(fileno(bp.txfp), F_SETLK, &txflock) != 0) {
WriteError("$Binkp: can't lock file %s, skipping", MBSE_SS(tmp->local)); WriteError("$Binkp: can't lock file %s, skipping", MBSE_SS(tmp->local));
fclose(txfp); fclose(bp.txfp);
bp.txfp = NULL;
tmp->state = Skipped; tmp->state = Skipped;
break; break;
} }
txpos = stxpos = tmp->offset; bp.txpos = bp.stxpos = tmp->offset;
Syslog('+', "Binkp: send \"%s\" as \"%s\"", MBSE_SS(tmp->local), MBSE_SS(tmp->remote)); Syslog('+', "Binkp: send \"%s\" as \"%s\"", MBSE_SS(tmp->local), MBSE_SS(tmp->remote));
Syslog('+', "Binkp: size %lu bytes, dated %s", (unsigned long)tmp->size, date(tmp->date)); Syslog('+', "Binkp: size %lu bytes, dated %s", (unsigned long)tmp->size, date(tmp->date));
binkp_send_control(MM_FILE, "%s %lu %ld %ld", MBSE_SS(tmp->remote), binkp_send_control(MM_FILE, "%s %lu %ld %ld", MBSE_SS(tmp->remote),
(unsigned long)tmp->size, (long)tmp->date, (unsigned long)tmp->offset); (unsigned long)tmp->size, (long)tmp->date, (unsigned long)tmp->offset);
gettimeofday(&txtvstart, &tz); gettimeofday(&bp.txtvstart, &bp.tz);
tmp->state = Sending; tmp->state = Sending;
cursend = tmp; cursend = tmp;
bp.TxState = TxTryRead; bp.TxState = TxTryRead;
@ -1327,12 +1369,12 @@ int binkp_batch(file_list *to_send)
break; break;
case TxReadSend: case TxReadSend:
fseek(txfp, txpos, SEEK_SET); fseek(bp.txfp, bp.txpos, SEEK_SET);
txlen = fread(txbuf, 1, SND_BLKSIZE, txfp); bp.txlen = fread(bp.txbuf, 1, SND_BLKSIZE, bp.txfp);
if (txlen == 0) { if (bp.txlen == 0) {
if (ferror(txfp)) { if (ferror(bp.txfp)) {
WriteError("$Binkp: error reading from file"); WriteError("$Binkp: error reading from file");
bp.TxState = TxGetNextFile; bp.TxState = TxGetNextFile;
cursend->state = Skipped; cursend->state = Skipped;
@ -1340,35 +1382,31 @@ int binkp_batch(file_list *to_send)
break; break;
} }
/*
* Send empty dataframe, most binkp mailers need it to detect EOF.
*/
// binkp_send_data(txbuf, 0);
/* /*
* calculate time needed and bytes transferred * calculate time needed and bytes transferred
*/ */
gettimeofday(&txtvend, &tz); gettimeofday(&bp.txtvend, &bp.tz);
/* /*
* Close transmitter file * Close transmitter file
*/ */
fclose(txfp); fclose(bp.txfp);
bp.txfp = NULL;
if (txpos >= 0) { if (bp.txpos >= 0) {
stxpos = txpos - stxpos; bp.stxpos = bp.txpos - bp.stxpos;
Syslog('+', "Binkp: OK %s", transfertime(txtvstart, txtvend, stxpos, TRUE)); Syslog('+', "Binkp: OK %s", transfertime(bp.txtvstart, bp.txtvend, bp.stxpos, TRUE));
} else { } else {
Syslog('+', "Binkp: transmitter skipped file after %ld seconds", txtvend.tv_sec - txtvstart.tv_sec); Syslog('+', "Binkp: transmitter skipped file after %ld seconds", bp.txtvend.tv_sec - bp.txtvstart.tv_sec);
} }
cursend->state = IsSent; cursend->state = IsSent;
bp.TxState = TxGetNextFile; bp.TxState = TxGetNextFile;
break; break;
} else { } else {
txpos += txlen; bp.txpos += bp.txlen;
sentbytes += txlen; sentbytes += bp.txlen;
binkp_send_data(txbuf, txlen); binkp_send_data(bp.txbuf, bp.txlen);
} }
bp.TxState = TxTryRead; bp.TxState = TxTryRead;
@ -1396,26 +1434,26 @@ int binkp_batch(file_list *to_send)
/* /*
* Process received frame * Process received frame
*/ */
if (GotFrame) { if (bp.GotFrame) {
if (cmd) { if (bp.cmd) {
switch (rxbuf[0]) { switch (bp.rxbuf[0]) {
case MM_ERR: Syslog('+', "Binkp: got ERR: %s", rxbuf+1); case MM_ERR: Syslog('+', "Binkp: got ERR: %s", bp.rxbuf+1);
bp.RxState = RxDone; bp.RxState = RxDone;
bp.TxState = TxDone; bp.TxState = TxDone;
rc = MBERR_FTRANSFER; bp.rc = MBERR_FTRANSFER;
break; break;
case MM_BSY: Syslog('+', "Binkp: got BSY: %s", rxbuf+1); case MM_BSY: Syslog('+', "Binkp: got BSY: %s", bp.rxbuf+1);
bp.RxState = RxDone; bp.RxState = RxDone;
bp.TxState = TxDone; bp.TxState = TxDone;
rc = MBERR_FTRANSFER; bp.rc = MBERR_FTRANSFER;
break; break;
case MM_SKIP: Syslog('+', "Binkp: got SKIP: %s", rxbuf+1); case MM_SKIP: Syslog('+', "Binkp: got SKIP: %s", bp.rxbuf+1);
break; break;
case MM_GET: Syslog('+', "Binkp: got GET: %s", rxbuf+1); case MM_GET: Syslog('+', "Binkp: got GET: %s", bp.rxbuf+1);
sscanf(rxbuf+1, "%s %ld %ld %ld", bp.gname, &bp.gsize, &bp.gtime, &bp.goffset); sscanf(bp.rxbuf+1, "%s %ld %ld %ld", bp.gname, &bp.gsize, &bp.gtime, &bp.goffset);
for (tmpg = bll; tmpg; tmpg = tmpg->next) { for (tmpg = bll; tmpg; tmpg = tmpg->next) {
if (strcasecmp(tmpg->remote, bp.gname) == 0) { if (strcasecmp(tmpg->remote, bp.gname) == 0) {
tmpg->state = NoState; tmpg->state = NoState;
@ -1430,8 +1468,8 @@ int binkp_batch(file_list *to_send)
} }
break; break;
case MM_GOT: Syslog('+', "Binkp: got GOT: %s", rxbuf+1); case MM_GOT: Syslog('+', "Binkp: got GOT: %s", bp.rxbuf+1);
sscanf(rxbuf+1, "%s %ld %ld", bp.lname, &bp.lsize, &bp.ltime); sscanf(bp.rxbuf+1, "%s %ld %ld", bp.lname, &bp.lsize, &bp.ltime);
Found = FALSE; Found = FALSE;
for (tmp = bll; tmp; tmp = tmp->next) for (tmp = bll; tmp; tmp = tmp->next)
if ((strcmp(bp.lname, tmp->remote) == 0) && (bp.lsize == tmp->size) && if ((strcmp(bp.lname, tmp->remote) == 0) && (bp.lsize == tmp->size) &&
@ -1441,52 +1479,52 @@ int binkp_batch(file_list *to_send)
Found = TRUE; Found = TRUE;
} }
if (!Found) { if (!Found) {
Syslog('!', "Binkp: unexpected GOT \"%s\"", rxbuf+1); Syslog('!', "Binkp: unexpected GOT \"%s\"", bp.rxbuf+1);
} }
break; break;
case MM_NUL: b_nul(rxbuf+1); case MM_NUL: b_nul(bp.rxbuf+1);
break; break;
case MM_EOB: Syslog('+', "Binkp: got EOB"); case MM_EOB: Syslog('+', "Binkp: got EOB");
bp.RxState = RxEndOfBatch; bp.RxState = RxEndOfBatch;
break; break;
case MM_FILE: Syslog('b', "Binkp: got FILE: %s", rxbuf+1); case MM_FILE: Syslog('b', "Binkp: got FILE: %s", bp.rxbuf+1);
if ((bp.RxState == RxWaitFile) || (bp.RxState == RxEndOfBatch)) { if ((bp.RxState == RxWaitFile) || (bp.RxState == RxEndOfBatch)) {
bp.RxState = RxAcceptFile; bp.RxState = RxAcceptFile;
/* /*
* Check against buffer overflow * Check against buffer overflow
*/ */
if (strlen(rxbuf) < 512) { if (strlen(bp.rxbuf) < 512) {
sscanf(rxbuf+1, "%s %ld %ld %ld", bp.rname, &bp.rsize, &bp.rtime, &bp.roffs); sscanf(bp.rxbuf+1, "%s %ld %ld %ld", bp.rname, &bp.rsize, &bp.rtime, &bp.roffs);
} else { } else {
Syslog('+', "Binkp: got corrupted FILE frame, size %d bytes", strlen(rxbuf)); Syslog('+', "Binkp: got corrupted FILE frame, size %d bytes", strlen(bp.rxbuf));
} }
} else { } else {
Syslog('+', "Binkp: got unexpected FILE frame %s", rxbuf+1); Syslog('+', "Binkp: got unexpected FILE frame %s", bp.rxbuf+1);
} }
break; break;
default: Syslog('+', "Binkp: Unexpected frame %d \"%s\"", rxbuf[0], printable(rxbuf+1, 0)); default: Syslog('+', "Binkp: Unexpected frame %d \"%s\"", bp.rxbuf[0], printable(bp.rxbuf+1, 0));
} }
} else { } else {
if (blklen) { if (bp.blklen) {
if (bp.RxState == RxReceData) { if (bp.RxState == RxReceData) {
written = fwrite(rxbuf, 1, blklen, rxfp); written = fwrite(bp.rxbuf, 1, bp.blklen, bp.rxfp);
if (!written && blklen) { if (!written && bp.blklen) {
Syslog('+', "Binkp: file write error"); Syslog('+', "Binkp: file write error");
bp.RxState = RxDone; bp.RxState = RxDone;
} }
rxpos += written; bp.rxpos += written;
if (rxpos == bp.rsize) { if (bp.rxpos == bp.rsize) {
bp.RxState = RxWaitFile; bp.RxState = RxWaitFile;
binkp_send_control(MM_GOT, "%s %ld %ld", bp.rname, bp.rsize, bp.rtime); binkp_send_control(MM_GOT, "%s %ld %ld", bp.rname, bp.rsize, bp.rtime);
closefile(); closefile();
rxpos = rxpos - rxbytes; bp.rxpos = bp.rxpos - rxbytes;
gettimeofday(&rxtvend, &tz); gettimeofday(&bp.rxtvend, &bp.tz);
Syslog('+', "Binkp: %s %s", rxerror?"ERROR":"OK", transfertime(rxtvstart, rxtvend, rxpos, FALSE)); Syslog('+', "Binkp: OK %s", transfertime(bp.rxtvstart, bp.rxtvend, bp.rxpos, FALSE));
rcvdbytes += rxpos; rcvdbytes += bp.rxpos;
bp.RxState = RxWaitFile; bp.RxState = RxWaitFile;
transferred = TRUE; transferred = TRUE;
} }
@ -1496,15 +1534,15 @@ int binkp_batch(file_list *to_send)
* Do not log after a GET command, there will be data packets * Do not log after a GET command, there will be data packets
* in the pipeline that must be ignored. * in the pipeline that must be ignored.
*/ */
Syslog('+', "Binkp: unexpected DATA frame %d", rxbuf[0]); Syslog('+', "Binkp: unexpected DATA frame %d", bp.rxbuf[0]);
} }
} }
} }
} }
GotFrame = FALSE; bp.GotFrame = FALSE;
rxlen = 0; bp.rxlen = 0;
header = 0; bp.header = 0;
blklen = 0; bp.blklen = 0;
} }
/* /*
@ -1517,7 +1555,7 @@ int binkp_batch(file_list *to_send)
case RxAcceptFile: case RxAcceptFile:
Syslog('+', "Binkp: receive file \"%s\" date %s size %ld offset %ld", bp.rname, date(bp.rtime), bp.rsize, bp.roffs); Syslog('+', "Binkp: receive file \"%s\" date %s size %ld offset %ld", bp.rname, date(bp.rtime), bp.rsize, bp.roffs);
(void)binkp2unix(bp.rname); (void)binkp2unix(bp.rname);
rxfp = openfile(binkp2unix(bp.rname), bp.rtime, bp.rsize, &rxbytes, resync); bp.rxfp = openfile(binkp2unix(bp.rname), bp.rtime, bp.rsize, &rxbytes, resync);
if (bp.DidSendGET) { if (bp.DidSendGET) {
/* /*
@ -1529,16 +1567,15 @@ int binkp_batch(file_list *to_send)
break; break;
} }
gettimeofday(&rxtvstart, &tz); gettimeofday(&bp.rxtvstart, &bp.tz);
rxpos = bp.roffs; bp.rxpos = bp.roffs;
rxerror = FALSE;
if (!diskfree(CFG.freespace)) { if (!diskfree(CFG.freespace)) {
Syslog('+', "Binkp: low diskspace, sending BSY"); Syslog('+', "Binkp: low diskspace, sending BSY");
binkp_send_control(MM_BSY, "Low diskspace, try again later"); binkp_send_control(MM_BSY, "Low diskspace, try again later");
bp.RxState = RxDone; bp.RxState = RxDone;
bp.TxState = TxDone; bp.TxState = TxDone;
rc = MBERR_FTRANSFER; bp.rc = MBERR_FTRANSFER;
break; break;
} }
@ -1549,7 +1586,7 @@ int binkp_batch(file_list *to_send)
Syslog('!', "Only %lu blocks free (need %lu) in %s", sfs.f_bfree, Syslog('!', "Only %lu blocks free (need %lu) in %s", sfs.f_bfree,
(unsigned long)(bp.rsize / (sfs.f_bsize + 1)), tempinbound); (unsigned long)(bp.rsize / (sfs.f_bsize + 1)), tempinbound);
closefile(); closefile();
rxfp = NULL; /* Force SKIP command */ bp.rxfp = NULL; /* Force SKIP command */
} }
} }
@ -1561,8 +1598,8 @@ int binkp_batch(file_list *to_send)
Syslog('+', "Binkp: already got %s, sending GOT", bp.rname); Syslog('+', "Binkp: already got %s, sending GOT", bp.rname);
binkp_send_control(MM_GOT, "%s %ld %ld", bp.rname, bp.rsize, bp.rtime); binkp_send_control(MM_GOT, "%s %ld %ld", bp.rname, bp.rsize, bp.rtime);
bp.RxState = RxWaitFile; bp.RxState = RxWaitFile;
rxfp = NULL; bp.rxfp = NULL;
} else if (!rxfp) { } else if (!bp.rxfp) {
/* /*
* Some error, request to skip it * Some error, request to skip it
*/ */
@ -1614,19 +1651,16 @@ int binkp_batch(file_list *to_send)
free(bll); free(bll);
} }
free(txbuf);
free(rxbuf);
/* /*
* If there was an error, try to close a possible incomplete file in * If there was an error, try to close a possible incomplete file in
* the temp inbound so we can resume the next time we have a session * the temp inbound so we can resume the next time we have a session
* with this node. * with this node.
*/ */
if (rc) if (bp.rc)
closefile(); closefile();
Syslog('+', "Binkp: batch %d completed rc=%d", batchnr, rc); Syslog('+', "Binkp: batch %d completed rc=%d", bp.batchnr, bp.rc);
return rc; return bp.rc;
} }

View File

@ -20,7 +20,11 @@
/* protocol version */ /* protocol version */
#define PRTCLNAME "binkp" #define PRTCLNAME "binkp"
#ifdef USE_EXPERIMENT
#define PRTCLVER "1.0" #define PRTCLVER "1.0"
#else
#define PRTCLVER "1.0"
#endif
#define MAX_BLKSIZE 0x7fff /* Don't change! */ #define MAX_BLKSIZE 0x7fff /* Don't change! */
#define BLK_HDR_SIZE 2 /* 2 bytes header */ #define BLK_HDR_SIZE 2 /* 2 bytes header */