summaryrefslogtreecommitdiff
path: root/src/split.c
diff options
context:
space:
mode:
authorPádraig Brady <P@draigBrady.com>2015-07-01 22:37:26 +0100
committerPádraig Brady <P@draigBrady.com>2015-07-02 03:53:59 +0100
commita645ce6c04719ad616ecd3bd7a16cd14772d6a74 (patch)
treeb223ae17b9c075d76178b4ee1b02b232012c77ae /src/split.c
parent8bf2af685cf2cb1291fb03ec8a6942c26a7e0bd7 (diff)
downloadcoreutils-a645ce6c04719ad616ecd3bd7a16cd14772d6a74.tar.xz
wc: fix reading of /proc files on aarch64
tests/misc/wc-proc.sh fails when the page size is 64K * src/wc.c (wc): The lseek adjustment should be based on st_blksize, rather than on the internal buffer size. This is significant on aarch64 where st_blksize in /proc is the 64K (the page size) and thus larger than the internal buffer. * src/split.c (main): Even though the similar processing is done on the internal buffer size, that's based on st_blksize and so fine in this regard. Add an assert to enforce this. Avoid this path for the undocumented ---io-blksize option.
Diffstat (limited to 'src/split.c')
-rw-r--r--src/split.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/split.c b/src/split.c
index b6fe2ddef..35f2629ae 100644
--- a/src/split.c
+++ b/src/split.c
@@ -1493,7 +1493,9 @@ main (int argc, char **argv)
if (fstat (STDIN_FILENO, &in_stat_buf) != 0)
error (EXIT_FAILURE, errno, "%s", infile);
- if (in_blk_size == 0)
+
+ bool specified_buf_size = !! in_blk_size;
+ if (! specified_buf_size)
in_blk_size = io_blksize (in_stat_buf);
void *b = xmalloc (in_blk_size + 1 + page_size - 1);
@@ -1505,8 +1507,9 @@ main (int argc, char **argv)
off_t input_offset = lseek (STDIN_FILENO, 0, SEEK_CUR);
if (0 <= input_offset)
{
- if (usable_st_size (&in_stat_buf))
+ if (usable_st_size (&in_stat_buf) && ! specified_buf_size)
{
+ assert (ST_BLKSIZE (in_stat_buf) <= in_blk_size);
file_size = input_file_size (STDIN_FILENO, in_stat_buf.st_size,
buf, in_blk_size);
if (file_size < in_blk_size)