aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMagnus Hagander <magnus@hagander.net>2008-08-20 11:53:51 +0000
committerMagnus Hagander <magnus@hagander.net>2008-08-20 11:53:51 +0000
commit1852a73c7ac8096104e2e2ad4b2fbe9484fc1dd9 (patch)
treee3a84443120dc3ef1d4d655e181a257a3dbc8473
parent4dff669cf0b999bf57c29d2cd43df562a7b70e82 (diff)
downloadpostgresql-1852a73c7ac8096104e2e2ad4b2fbe9484fc1dd9.tar.gz
postgresql-1852a73c7ac8096104e2e2ad4b2fbe9484fc1dd9.zip
Make libpq on windows not try to send chunks larger than 64Kb.
Per Microsoft knowledge base article Q201213, early versions of Windows fail when we do this. Later versions of Windows appear to have a higher limit than 64Kb, but do still fail on large sends, so we unconditionally limit it for all versions. Patch from Tom Lane.
-rw-r--r--src/interfaces/libpq/fe-misc.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/interfaces/libpq/fe-misc.c b/src/interfaces/libpq/fe-misc.c
index 3d063865427..cd6bdec3a51 100644
--- a/src/interfaces/libpq/fe-misc.c
+++ b/src/interfaces/libpq/fe-misc.c
@@ -23,7 +23,7 @@
* Portions Copyright (c) 1994, Regents of the University of California
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/interfaces/libpq/fe-misc.c,v 1.133 2008/01/01 19:46:00 momjian Exp $
+ * $PostgreSQL: pgsql/src/interfaces/libpq/fe-misc.c,v 1.133.2.1 2008/08/20 11:53:51 mha Exp $
*
*-------------------------------------------------------------------------
*/
@@ -752,7 +752,16 @@ pqSendSome(PGconn *conn, int len)
int sent;
char sebuf[256];
+#ifndef WIN32
sent = pqsecure_write(conn, ptr, len);
+#else
+ /*
+ * Windows can fail on large sends, per KB article Q201213. The failure-point
+ * appears to be different in different versions of Windows, but 64k should
+ * always be safe.
+ */
+ sent = pqsecure_write(conn, ptr, Min(len, 65536));
+#endif
if (sent < 0)
{