Skip to content

Commit 0991249

Browse files
tglsfdcdf7cb
andcommitted
Make sure IOV_MAX is defined.
We stopped defining IOV_MAX on non-Windows systems in 75357ab, on the assumption that every non-Windows system defines it in <limits.h> as required by X/Open. GNU Hurd, however, doesn't follow that standard either. Put back the old logic to assume 16 if it's not defined. Author: Michael Banck <mbanck@gmx.net> Co-authored-by: Christoph Berg <myon@debian.org> Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/6862e8d1.050a0220.194b8d.76fa@mx.google.com Discussion: https://postgr.es/m/6846e0c3.df0a0220.39ef9b.c60e@mx.google.com Backpatch-through: 16
1 parent 29c54ea commit 0991249

File tree

1 file changed

+9
-3
lines changed

1 file changed

+9
-3
lines changed

src/include/port/pg_iovec.h

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,6 @@
2121

2222
#else
2323

24-
/* POSIX requires at least 16 as a maximum iovcnt. */
25-
#define IOV_MAX 16
26-
2724
/* Define our own POSIX-compatible iovec struct. */
2825
struct iovec
2926
{
@@ -33,6 +30,15 @@ struct iovec
3330

3431
#endif
3532

33+
/*
34+
* If <limits.h> didn't define IOV_MAX, define our own. X/Open requires at
35+
* least 16. (GNU Hurd apparently feel that they're not bound by X/Open,
36+
* because they don't define this symbol at all.)
37+
*/
38+
#ifndef IOV_MAX
39+
#define IOV_MAX 16
40+
#endif
41+
3642
/* Define a reasonable maximum that is safe to use on the stack. */
3743
#define PG_IOV_MAX Min(IOV_MAX, 32)
3844

0 commit comments

Comments
 (0)