aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2016-11-30 14:59:27 +0100
committerFlorian Weimer <fweimer@redhat.com>2016-11-30 14:59:27 +0100
commit705a79f82560ff6472cebed86aa5db04cdea3bce (patch)
tree37c952d4411aa2bcccf0556110d78e4e289ec6b9
parent934fc4773eec45ec31b03a0244d391cade53f210 (diff)
downloadglibc-705a79f82560ff6472cebed86aa5db04cdea3bce.zip
glibc-705a79f82560ff6472cebed86aa5db04cdea3bce.tar.gz
glibc-705a79f82560ff6472cebed86aa5db04cdea3bce.tar.bz2
libio: Limit buffer size to 8192 bytes [BZ #4099]
This avoids overly large buffers with network file systems which report very large block sizes.
-rw-r--r--ChangeLog6
-rw-r--r--NEWS6
-rw-r--r--libio/filedoalloc.c2
3 files changed, 13 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 40f460f..c2cb608 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2016-11-30 Florian Weimer <fweimer@redhat.com>
+
+ [BZ #4099]
+ * libio/filedoalloc.c (_IO_file_doallocate): Limit buffer size to
+ _IO_BUFSIZ (8192).
+
2016-11-30 Carlos O'Donell <carlos@redhat.com>
* PROJECTS: Remove file.
diff --git a/NEWS b/NEWS
index 9a45e73..b2a0b0f 100644
--- a/NEWS
+++ b/NEWS
@@ -80,6 +80,12 @@ Version 2.25
affect the ABI of other libraries that use this type in their interfaces,
if they are compiled or used with those options.
+* The buffer size for byte-oriented stdio streams is now limited to 8192
+ bytes by default. Previously, on Linux, the default buffer size on most
+ file systems was 4096 bytes (and thus remains unchanged), except on
+ network file systems, where the buffer size was unpredictable and could be
+ as large as several megabytes.
+
* The <sys/quota.h> header now includes the <linux/quota.h> header. Support
for the Linux quota interface which predates kernel version 2.4.22 has
been removed.
diff --git a/libio/filedoalloc.c b/libio/filedoalloc.c
index 4f9d738..ded0725 100644
--- a/libio/filedoalloc.c
+++ b/libio/filedoalloc.c
@@ -94,7 +94,7 @@ _IO_file_doallocate (_IO_FILE *fp)
fp->_flags |= _IO_LINE_BUF;
}
#if _IO_HAVE_ST_BLKSIZE
- if (st.st_blksize > 0)
+ if (st.st_blksize > 0 && st.st_blksize < _IO_BUFSIZ)
size = st.st_blksize;
#endif
}