/*
+ * $Id: dsi_read.c,v 1.7 2009-10-25 06:13:11 didg Exp $
+ *
* Copyright (c) 1997 Adrian Sun (asun@zoology.washington.edu)
* All rights reserved. See COPYRIGHT.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
-#endif
+#endif /* HAVE_CONFIG_H */
#include <stdio.h>
#include <string.h>
+#ifdef HAVE_UNISTD_H
#include <unistd.h>
+#endif /* HAVE_UNISTD_H */
#include <signal.h>
#include <sys/types.h>
#include <sys/time.h>
+#ifdef HAVE_SYS_FILIO_H
+#include <sys/filio.h>
+#endif
#include <atalk/dsi.h>
#ifndef min
#define min(a,b) ((a) < (b) ? (a) : (b))
-#endif
+#endif /* ! min */
/* streaming i/o for afp_read. this is all from the perspective of the
* client. it basically does the reverse of dsi_write. on first entry,
ssize_t dsi_readinit(DSI *dsi, void *buf, const size_t buflen,
const size_t size, const int err)
{
- const struct itimerval none = {{0, 0}, {0, 0}};
dsi->noreply = 1; /* we will handle our own replies */
dsi->header.dsi_flags = DSIFL_REPLY;
dsi->header.dsi_len = htonl(size);
dsi->header.dsi_code = htonl(err);
- sigprocmask(SIG_BLOCK, &dsi->sigblockset, NULL);
- setitimer(ITIMER_REAL, &none, &dsi->savetimer);
+ dsi->in_write++;
if (dsi_stream_send(dsi, buf, buflen)) {
dsi->datasize = size - buflen;
return min(dsi->datasize, buflen);
void dsi_readdone(DSI *dsi)
{
- setitimer(ITIMER_REAL, &dsi->savetimer, NULL);
- sigprocmask(SIG_UNBLOCK, &dsi->sigblockset, NULL);
+ dsi->in_write--;
}
/* send off the data */
ssize_t dsi_read(DSI *dsi, void *buf, const size_t buflen)
{
- size_t len = dsi_stream_write(dsi, buf, buflen);
+ size_t len;
+
+ len = dsi_stream_write(dsi, buf, buflen, 0);
if (len == buflen) {
dsi->datasize -= len;