----- Original Message -----
> From: "Zeng Linggang" <zenglg...@cn.fujitsu.com>
> To: "Alexey Kodanev" <alexey.koda...@oracle.com>
> Cc: "vasily isaenko" <vasily.isae...@oracle.com>,
> ltp-list@lists.sourceforge.net
> Sent: Tuesday, 19 May, 2015 10:50:22 AM
> Subject: [LTP] [PATCH v2] fallocate04: another check if SEEK_HOLE is not
> supported
>
> SEEK_HOLE is only supported since version 3.1. Check the specified
> range blocks are zeroed while the kernel does not supported SEEK_HOLE.
>
> Signed-off-by: Zhang Jin <jy_zhang...@cn.fujitsu.com>
> ---
> testcases/kernel/syscalls/fallocate/fallocate04.c | 13 ++++++++++---
> 1 file changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/testcases/kernel/syscalls/fallocate/fallocate04.c
> b/testcases/kernel/syscalls/fallocate/fallocate04.c
> index 911bbe8..e94c572 100644
> --- a/testcases/kernel/syscalls/fallocate/fallocate04.c
> +++ b/testcases/kernel/syscalls/fallocate/fallocate04.c
> @@ -98,13 +98,13 @@ static void setup(void)
> get_blocksize();
> }
>
> -static void check_file_data(const char exp_buf[], size_t size)
> +static void check_file_data_(const char exp_buf[], size_t size, off_t
> offset)
> {
> char rbuf[size];
>
> tst_resm(TINFO, "reading the file, compare with expected buffer");
>
> - SAFE_LSEEK(cleanup, fd, 0, SEEK_SET);
> + SAFE_LSEEK(cleanup, fd, offset, SEEK_SET);
> SAFE_READ(cleanup, 1, fd, rbuf, size);
>
> if (memcmp(exp_buf, rbuf, size)) {
> @@ -116,6 +116,11 @@ static void check_file_data(const char exp_buf[], size_t
> size)
> }
> }
>
> +static inline void check_file_data(const char exp_buf[], size_t size)
> +{
> + check_file_data_(exp_buf, size, 0);
> +}
> +
> static void test01(void)
> {
> tst_resm(TINFO, "allocate '%zu' bytes", buf_size);
> @@ -158,7 +163,9 @@ static void test02(void)
> tst_brkm(TFAIL | TERRNO, cleanup,
> "fallocate() or lseek() failed");
> }
> - tst_resm(TWARN | TERRNO, "lseek() doesn't support SEEK_HOLE");
> + char zeros[block_size];
> + memset(zeros, 0, block_size);
> + check_file_data_(zeros, block_size, block_size);
Hi,
Isn't this redundant?
Couple lines below is this check, which also checks that range
<block_size, block_size*2> is zeroed.
char exp_buf[buf_size];
fill_tst_buf(exp_buf);
memset(exp_buf + block_size, 0, block_size);
check_file_data(exp_buf, buf_size);
Wouldn't it be enough to turn that warning into TINFO, for kernels < 3.1?
diff --git a/testcases/kernel/syscalls/fallocate/fallocate04.c
b/testcases/kernel/syscalls/fallocate/fallocate04.c
index 911bbe8..45d9827 100644
--- a/testcases/kernel/syscalls/fallocate/fallocate04.c
+++ b/testcases/kernel/syscalls/fallocate/fallocate04.c
@@ -158,9 +158,12 @@ static void test02(void)
tst_brkm(TFAIL | TERRNO, cleanup,
"fallocate() or lseek() failed");
}
- tst_resm(TWARN | TERRNO, "lseek() doesn't support SEEK_HOLE");
+ if (tst_kvercmp(3, 1, 0) < 0)
+ tst_resm(TINFO, "lseek() doesn't support SEEK_HOLE, "
+ "this is expected for < 3.1 kernels");
+ } else {
+ tst_resm(TINFO, "found a hole at '%ld' offset", ret);
}
- tst_resm(TINFO, "found a hole at '%ld' offset", ret);
size_t alloc_size1 = get_allocsize();
Regards,
Jan
------------------------------------------------------------------------------
One dashboard for servers and applications across Physical-Virtual-Cloud
Widest out-of-the-box monitoring support with 50+ applications
Performance metrics, stats and reports that give you Actionable Insights
Deep dive visibility with transaction tracing using APM Insight.
http://ad.doubleclick.net/ddm/clk/290420510;117567292;y
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list