X-Git-Url: http://dolda2000.com/gitweb/?p=doldaconnect.git;a=blobdiff_plain;f=daemon%2Ftransfer.c;h=433ceb1e277c1639416599f281fb7563d06275c5;hp=29ad45d22ea580fcf4bb7f8303c3e53114d507ba;hb=d1ef02006f3d39a45ef40235f716c7f9317195f6;hpb=2b9a1911defbd6f0295b74cd7b41a2a5328d9e6a diff --git a/daemon/transfer.c b/daemon/transfer.c index 29ad45d..433ceb1 100644 --- a/daemon/transfer.c +++ b/daemon/transfer.c @@ -235,7 +235,7 @@ static void transexpire(int cancelled, struct transfer *transfer) static void transferread(struct socket *sk, struct transfer *transfer) { if(sockgetdatalen(sk) >= 65536) - sk->ignread = 1; + sockblock(sk, 1); if((transfer->iface != NULL) && (transfer->iface->gotdata != NULL)) transfer->iface->gotdata(transfer, transfer->ifacedata); } @@ -287,7 +287,7 @@ void *transfergetdata(struct transfer *transfer, size_t *size) if(transfer->localend == NULL) return(NULL); - transfer->localend->ignread = 0; + sockblock(transfer->localend, 0); time(&transfer->activity); if((buf = sockgetinbuf(transfer->localend, size)) == NULL) return(NULL); @@ -311,7 +311,7 @@ void transferprepul(struct transfer *transfer, off_t size, off_t start, off_t en transfersetsize(transfer, size); transfer->curpos = start; transfer->endpos = end; - lesk->ignread = 1; + sockblock(lesk, 1); transfersetlocalend(transfer, lesk); } @@ -326,7 +326,7 @@ void transferstartul(struct transfer *transfer, struct socket *sk) transfersetstate(transfer, TRNS_MAIN); socksettos(sk, confgetint("transfer", "ultos")); if(transfer->localend != NULL) - transfer->localend->ignread = 0; + sockblock(transfer->localend, 0); } void transfersetlocalend(struct transfer *transfer, struct socket *sk) @@ -716,7 +716,7 @@ int forkfilter(struct transfer *transfer) * the fd, and thus it closes it. Until I can find out whyever the * kernel gives a POLLIN on the fd (if I can at all...), I'll just * set ignread on insock for now. */ - insock->ignread = 1; + sockblock(insock, 1); transfer->filter = pid; transfersetlocalend(transfer, insock); getsock(transfer->filterout = outsock);