mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 16:21:06 +00:00
Test p{read,write}64 with offset > 4GB
Test p{read,write}64 with offset > 4GB. Since it is not an error for a successful pread/pwrite call to transfer fewer bytes than requested, we should check if the return value is -1. No need to close and unlink temporary file, which is handled by test-skeleton.c. [BZ #20350] * posix/tst-preadwrite.c: Renamed to ... * posix/tst-preadwrite-common.c: This. (PREAD): Removed. (PWRITE): Likewise. (STRINGIFY): Likewise. (STRINGIFY2): Likewise. (do_prepare): Make it static and remove function arguments. (do_test): Likewise. (PREPARE): Updated. (TEST_FUNCTION): New. (name): Make it static. (fd): Likewise. (do_prepare): Use create_temp_file. (do_test): Renamed to ... (do_test_with_offset): This. Make it static and accept offset. Properly check return value of PWRITE and PREAD. Return bytes read. Don't close fd nor unlink name. * posix/tst-preadwrite.c: Rewrite. * posix/tst-preadwrite64.c: Likewise.
This commit is contained in:
parent
61655555aa
commit
3bbee82a56
23
ChangeLog
23
ChangeLog
@ -1,3 +1,26 @@
|
|||||||
|
2016-07-12 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
|
[BZ #20350]
|
||||||
|
* posix/tst-preadwrite.c: Renamed to ...
|
||||||
|
* posix/tst-preadwrite-common.c: This.
|
||||||
|
(PREAD): Removed.
|
||||||
|
(PWRITE): Likewise.
|
||||||
|
(STRINGIFY): Likewise.
|
||||||
|
(STRINGIFY2): Likewise.
|
||||||
|
(do_prepare): Make it static and remove function arguments.
|
||||||
|
(do_test): Likewise.
|
||||||
|
(PREPARE): Updated.
|
||||||
|
(TEST_FUNCTION): New.
|
||||||
|
(name): Make it static.
|
||||||
|
(fd): Likewise.
|
||||||
|
(do_prepare): Use create_temp_file.
|
||||||
|
(do_test): Renamed to ...
|
||||||
|
(do_test_with_offset): This. Make it static and accept offset.
|
||||||
|
Properly check return value of PWRITE and PREAD. Return bytes
|
||||||
|
read. Don't close fd nor unlink name.
|
||||||
|
* posix/tst-preadwrite.c: Rewrite.
|
||||||
|
* posix/tst-preadwrite64.c: Likewise.
|
||||||
|
|
||||||
2016-07-12 H.J. Lu <hongjiu.lu@intel.com>
|
2016-07-12 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
[BZ #20309]
|
[BZ #20309]
|
||||||
|
85
posix/tst-preadwrite-common.c
Normal file
85
posix/tst-preadwrite-common.c
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
/* Common definitions for pread and pwrite.
|
||||||
|
Copyright (C) 2016 Free Software Foundation, Inc.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The GNU C Library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public
|
||||||
|
License along with the GNU C Library; if not, see
|
||||||
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <error.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
static void do_prepare (void);
|
||||||
|
#define PREPARE(argc, argv) do_prepare ()
|
||||||
|
static int do_test (void);
|
||||||
|
#define TEST_FUNCTION do_test ()
|
||||||
|
|
||||||
|
/* We might need a bit longer timeout. */
|
||||||
|
#define TIMEOUT 20 /* sec */
|
||||||
|
|
||||||
|
/* This defines the `main' function and some more. */
|
||||||
|
#include <test-skeleton.c>
|
||||||
|
|
||||||
|
/* These are for the temporary file we generate. */
|
||||||
|
static char *name;
|
||||||
|
static int fd;
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_prepare (void)
|
||||||
|
{
|
||||||
|
fd = create_temp_file ("tst-preadwrite.", &name);
|
||||||
|
if (fd == -1)
|
||||||
|
error (EXIT_FAILURE, errno, "cannot create temporary file");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static ssize_t
|
||||||
|
do_test_with_offset (off_t offset)
|
||||||
|
{
|
||||||
|
char buf[1000];
|
||||||
|
char res[1000];
|
||||||
|
int i;
|
||||||
|
ssize_t ret;
|
||||||
|
|
||||||
|
memset (buf, '\0', sizeof (buf));
|
||||||
|
memset (res, '\xff', sizeof (res));
|
||||||
|
|
||||||
|
if (write (fd, buf, sizeof (buf)) != sizeof (buf))
|
||||||
|
error (EXIT_FAILURE, errno, "during write");
|
||||||
|
|
||||||
|
for (i = 100; i < 200; ++i)
|
||||||
|
buf[i] = i;
|
||||||
|
ret = pwrite (fd, buf + 100, 100, offset + 100);
|
||||||
|
if (ret == -1)
|
||||||
|
error (EXIT_FAILURE, errno, "during pwrite");
|
||||||
|
|
||||||
|
for (i = 450; i < 600; ++i)
|
||||||
|
buf[i] = i;
|
||||||
|
ret = pwrite (fd, buf + 450, 150, offset + 450);
|
||||||
|
if (ret == -1)
|
||||||
|
error (EXIT_FAILURE, errno, "during pwrite");
|
||||||
|
|
||||||
|
ret = pread (fd, res, sizeof (buf) - 50, offset + 50);
|
||||||
|
if (ret == -1)
|
||||||
|
error (EXIT_FAILURE, errno, "during pread");
|
||||||
|
|
||||||
|
if (memcmp (buf + 50, res, ret) != 0)
|
||||||
|
{
|
||||||
|
printf ("error: read of pread != write of pwrite\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
@ -1,7 +1,6 @@
|
|||||||
/* Tests for pread and pwrite.
|
/* Tests for pread and pwrite.
|
||||||
Copyright (C) 1998-2016 Free Software Foundation, Inc.
|
Copyright (C) 1998-2016 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
modify it under the terms of the GNU Lesser General Public
|
modify it under the terms of the GNU Lesser General Public
|
||||||
@ -17,88 +16,10 @@
|
|||||||
License along with the GNU C Library; if not, see
|
License along with the GNU C Library; if not, see
|
||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <errno.h>
|
#include "tst-preadwrite-common.c"
|
||||||
#include <error.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
|
static int
|
||||||
/* Allow testing of the 64-bit versions as well. */
|
do_test (void)
|
||||||
#ifndef PREAD
|
|
||||||
# define PREAD pread
|
|
||||||
# define PWRITE pwrite
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define STRINGIFY(s) STRINGIFY2 (s)
|
|
||||||
#define STRINGIFY2(s) #s
|
|
||||||
|
|
||||||
/* Prototype for our test function. */
|
|
||||||
extern void do_prepare (int argc, char *argv[]);
|
|
||||||
extern int do_test (int argc, char *argv[]);
|
|
||||||
|
|
||||||
/* We have a preparation function. */
|
|
||||||
#define PREPARE do_prepare
|
|
||||||
|
|
||||||
/* We might need a bit longer timeout. */
|
|
||||||
#define TIMEOUT 20 /* sec */
|
|
||||||
|
|
||||||
/* This defines the `main' function and some more. */
|
|
||||||
#include <test-skeleton.c>
|
|
||||||
|
|
||||||
/* These are for the temporary file we generate. */
|
|
||||||
char *name;
|
|
||||||
int fd;
|
|
||||||
|
|
||||||
void
|
|
||||||
do_prepare (int argc, char *argv[])
|
|
||||||
{
|
{
|
||||||
size_t name_len;
|
return do_test_with_offset (0) == -1;
|
||||||
|
|
||||||
#define FNAME FNAME2(TRUNCATE)
|
|
||||||
#define FNAME2(s) "/" STRINGIFY(s) "XXXXXX"
|
|
||||||
|
|
||||||
name_len = strlen (test_dir);
|
|
||||||
name = malloc (name_len + sizeof (FNAME));
|
|
||||||
if (name == NULL)
|
|
||||||
error (EXIT_FAILURE, errno, "cannot allocate file name");
|
|
||||||
mempcpy (mempcpy (name, test_dir, name_len), FNAME, sizeof (FNAME));
|
|
||||||
add_temp_file (name);
|
|
||||||
|
|
||||||
/* Open our test file. */
|
|
||||||
fd = mkstemp (name);
|
|
||||||
if (fd == -1)
|
|
||||||
error (EXIT_FAILURE, errno, "cannot open test file `%s'", name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
do_test (int argc, char *argv[])
|
|
||||||
{
|
|
||||||
char buf[1000];
|
|
||||||
char res[1000];
|
|
||||||
int i;
|
|
||||||
|
|
||||||
memset (buf, '\0', sizeof (buf));
|
|
||||||
memset (res, '\xff', sizeof (res));
|
|
||||||
|
|
||||||
if (write (fd, buf, sizeof (buf)) != sizeof (buf))
|
|
||||||
error (EXIT_FAILURE, errno, "during write");
|
|
||||||
|
|
||||||
for (i = 100; i < 200; ++i)
|
|
||||||
buf[i] = i;
|
|
||||||
if (PWRITE (fd, buf + 100, 100, 100) != 100)
|
|
||||||
error (EXIT_FAILURE, errno, "during %s", STRINGIFY (PWRITE));
|
|
||||||
|
|
||||||
for (i = 450; i < 600; ++i)
|
|
||||||
buf[i] = i;
|
|
||||||
if (PWRITE (fd, buf + 450, 150, 450) != 150)
|
|
||||||
error (EXIT_FAILURE, errno, "during %s", STRINGIFY (PWRITE));
|
|
||||||
|
|
||||||
if (PREAD (fd, res, sizeof (buf) - 50, 50) != sizeof (buf) - 50)
|
|
||||||
error (EXIT_FAILURE, errno, "during %s", STRINGIFY (PREAD));
|
|
||||||
|
|
||||||
close (fd);
|
|
||||||
unlink (name);
|
|
||||||
|
|
||||||
return memcmp (buf + 50, res, sizeof (buf) - 50);
|
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
/* Tests for pread64 and pwrite64.
|
/* Tests for pread64 and pwrite64.
|
||||||
Copyright (C) 2000-2016 Free Software Foundation, Inc.
|
Copyright (C) 2000-2016 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
modify it under the terms of the GNU Lesser General Public
|
modify it under the terms of the GNU Lesser General Public
|
||||||
@ -17,7 +16,40 @@
|
|||||||
License along with the GNU C Library; if not, see
|
License along with the GNU C Library; if not, see
|
||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#define PREAD pread64
|
#define _FILE_OFFSET_BITS 64
|
||||||
#define PWRITE pwrite64
|
#include "tst-preadwrite-common.c"
|
||||||
|
|
||||||
#include "tst-preadwrite.c"
|
static int
|
||||||
|
do_test (void)
|
||||||
|
{
|
||||||
|
ssize_t ret;
|
||||||
|
|
||||||
|
ret = do_test_with_offset (0);
|
||||||
|
if (ret == -1)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
/* Create a sparse file larger than 4GB to check if offset is handled
|
||||||
|
correctly in p{write,read}64. */
|
||||||
|
off_t base_offset = UINT32_MAX + 2048LL;
|
||||||
|
ret = do_test_with_offset (base_offset);
|
||||||
|
if (ret == -1)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
struct stat st;
|
||||||
|
if (fstat (fd, &st) == -1)
|
||||||
|
{
|
||||||
|
printf ("error: fstat on temporary file failed: %m");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The file size should >= base_offset plus bytes read. */
|
||||||
|
off_t expected_value = base_offset + ret;
|
||||||
|
if (st.st_size < expected_value)
|
||||||
|
{
|
||||||
|
printf ("error: file size less than expected (%jd > %jd)\n",
|
||||||
|
(intmax_t) expected_value, (intmax_t) st.st_size);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user