]> granicus.if.org Git - postgresql/commitdiff
Fix failure of --jobs with vacuumdb on Windows
authorMichael Paquier <michael@paquier.xyz>
Tue, 27 Aug 2019 00:11:38 +0000 (09:11 +0900)
committerMichael Paquier <michael@paquier.xyz>
Tue, 27 Aug 2019 00:11:38 +0000 (09:11 +0900)
FD_SETSIZE needs to be declared before winsock2.h, or it is possible to
run into buffer overflow issues when using --jobs.  This is similar to
pgbench's solution done in a23c641.

This has been introduced by 71d84ef, and older versions have been using
the default value of FD_SETSIZE, defined at 64.

Per buildfarm member jacana, but this impacts all Windows animals
running the TAP tests.  I have reproduced the failure locally to check
the patch.

Author: Michael Paquier
Reviewed-by: Andrew Dunstan
Discussion: https://postgr.es/m/20190826054000.GE7005@paquier.xyz
Backpatch-through: 9.5

src/bin/scripts/vacuumdb.c

index 0c434c687111e8fe4b705eda66b168ae3828c1cc..2814c034d4ec300d25e44fe647dca0fb91cf3358 100644 (file)
  *-------------------------------------------------------------------------
  */
 
+#ifdef WIN32
+#define FD_SETSIZE 1024                        /* must set before winsock2.h is included */
+#endif
+
 #include "postgres_fe.h"
 
 #ifdef HAVE_SYS_SELECT_H