diff options
author | Andreas Baumann <mail@andreasbaumann.cc> | 2023-02-11 07:20:24 +0100 |
---|---|---|
committer | Andreas Baumann <mail@andreasbaumann.cc> | 2023-02-11 07:20:24 +0100 |
commit | f867d7b44080fa9716deeff4476275f9a489879f (patch) | |
tree | bc964662fc3300dc626fb6d833d8ed5c8f46eca7 /gl/sys-limits.h | |
parent | 9734c439cba0a02b087e50789e94ec9b07754608 (diff) | |
parent | c07206f2ccc2356aa74bc6813a94c2190017d44e (diff) | |
download | monitoring-plugins-f867d7b.tar.gz |
Merge branch 'master' into curlfixes
Diffstat (limited to 'gl/sys-limits.h')
-rw-r--r-- | gl/sys-limits.h | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/gl/sys-limits.h b/gl/sys-limits.h new file mode 100644 index 00000000..0e9556d6 --- /dev/null +++ b/gl/sys-limits.h | |||
@@ -0,0 +1,42 @@ | |||
1 | /* System call limits | ||
2 | |||
3 | Copyright 2018-2023 Free Software Foundation, Inc. | ||
4 | |||
5 | This file is free software: you can redistribute it and/or modify | ||
6 | it under the terms of the GNU Lesser General Public License as | ||
7 | published by the Free Software Foundation; either version 2.1 of the | ||
8 | License, or (at your option) any later version. | ||
9 | |||
10 | This file is distributed in the hope that it will be useful, | ||
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | GNU Lesser General Public License for more details. | ||
14 | |||
15 | You should have received a copy of the GNU Lesser General Public License | ||
16 | along with this program. If not, see <https://www.gnu.org/licenses/>. */ | ||
17 | |||
18 | #ifndef _GL_SYS_LIMITS_H | ||
19 | #define _GL_SYS_LIMITS_H | ||
20 | |||
21 | #include <limits.h> | ||
22 | |||
23 | /* Maximum number of bytes to read or write in a single system call. | ||
24 | This can be useful for system calls like sendfile on GNU/Linux, | ||
25 | which do not handle more than MAX_RW_COUNT bytes correctly. | ||
26 | The Linux kernel MAX_RW_COUNT is at least INT_MAX >> 20 << 20, | ||
27 | where the 20 comes from the Hexagon port with 1 MiB pages; use that | ||
28 | as an approximation, as the exact value may not be available to us. | ||
29 | |||
30 | Using this also works around a serious Linux bug before 2.6.16; see | ||
31 | <https://bugzilla.redhat.com/show_bug.cgi?id=612839>. | ||
32 | |||
33 | Using this also works around a Tru64 5.1 bug, where attempting | ||
34 | to read INT_MAX bytes fails with errno == EINVAL. See | ||
35 | <https://lists.gnu.org/r/bug-gnu-utils/2002-04/msg00010.html>. | ||
36 | |||
37 | Using this is likely to work around similar bugs in other operating | ||
38 | systems. */ | ||
39 | |||
40 | enum { SYS_BUFSIZE_MAX = INT_MAX >> 20 << 20 }; | ||
41 | |||
42 | #endif | ||