From af92a00b953746d64e1394d1988e77ffc3142df8 Mon Sep 17 00:00:00 2001 From: Keith Packard Date: Tue, 1 Jan 2002 07:51:45 +0000 Subject: Add (some) support for BIG-REQUESTS --- server.c | 39 +++++++++++++++++++++++++++++++-------- 1 file changed, 31 insertions(+), 8 deletions(-) (limited to 'server.c') diff --git a/server.c b/server.c index 383a66b..d1bc769 100644 --- a/server.c +++ b/server.c @@ -489,23 +489,46 @@ long FinishSetUpMessage (fd, buf, n) return(n); } +long StartBigRequest (fd, buf, n) + FD fd; + unsigned char *buf; + long n; +{ + enterprocedure("StartBigRequest"); + + /* bytes 0-3 are ignored now; bytes 4-8 tell us the request length */ + CS[fd].requestLen = ILong(&buf[4]); + CS[fd].ByteProcessing = FinishRequest; + CS[fd].NumberofBytesNeeded = 4 * CS[fd].requestLen; + debug(8,(stderr, "need %d more bytes to finish request\n", + CS[fd].NumberofBytesNeeded - n)); + StartStuff (fd); + return(0); +} long StartRequest (fd, buf, n) FD fd; unsigned char *buf; long n; { - unsigned short requestlength; enterprocedure("StartRequest"); /* bytes 0,1 are ignored now; bytes 2,3 tell us the request length */ - requestlength = IShort(&buf[2]); - if (requestlength == 0) - requestlength=0xffff; - CS[fd].ByteProcessing = FinishRequest; - CS[fd].NumberofBytesNeeded = 4 * requestlength; - debug(8,(stderr, "need %d more bytes to finish request\n", - CS[fd].NumberofBytesNeeded - n)); + CS[fd].requestLen = IShort(&buf[2]); + if (CS[fd].requestLen == 0 && CS[fd].bigreqEnabled) + { + CS[fd].ByteProcessing = StartBigRequest; + CS[fd].NumberofBytesNeeded = 8; + } + else + { + if (CS[fd].requestLen == 0) + CS[fd].requestLen = 1; + CS[fd].ByteProcessing = FinishRequest; + CS[fd].NumberofBytesNeeded = 4 * CS[fd].requestLen; + debug(8,(stderr, "need %d more bytes to finish request\n", + CS[fd].NumberofBytesNeeded - n)); + } StartStuff (fd); return(0); } -- cgit v1.2.1