On Mon, Jan 26, 2015 at 02:45:56PM +0100, Cyril Hrubis wrote: > You are adding the page_size_mask to all uses of total_ram, wouldn't it > be easier to add it to the total_ram at the start of the function (and > remove the page_size_mask from the malloc() call that has it allready)? > Yes, you're right. This is the new patch. Please review. Thanks.
>From 8d0521c7fbee1b46f27d8268fee28e9721c79cc2 Mon Sep 17 00:00:00 2001 From: Han Pingtian <ha...@linux.vnet.ibm.com> Date: Mon, 26 Jan 2015 17:29:41 +0800 Subject: [PATCH] increasing buffer size for correct alignment For align buffer address to the number specified by -a option in aio-stress, it needs to add page_size_mask extra length to total_ram before call allocation functions. Or it wouldn't be correct in this line after the allocation: p = (char *)((intptr_t) (p + page_size_mask) & ~page_size_mask); Signed-off-by: Han Pingtian <ha...@linux.vnet.ibm.com> --- testcases/kernel/io/ltp-aiodio/aio-stress.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/testcases/kernel/io/ltp-aiodio/aio-stress.c b/testcases/kernel/io/ltp-aiodio/aio-stress.c index 0b7148c..06a4953 100644 --- a/testcases/kernel/io/ltp-aiodio/aio-stress.c +++ b/testcases/kernel/io/ltp-aiodio/aio-stress.c @@ -1019,8 +1019,11 @@ int setup_shared_mem(int num_threads, int num_files, int depth, if (verify) total_ram += padded_reclen; + /* for aligning buffer after the allocation */ + total_ram += page_size_mask; + if (use_shm == USE_MALLOC) { - p = malloc(total_ram + page_size_mask); + p = malloc(total_ram); } else if (use_shm == USE_SHM) { shm_id = shmget(IPC_PRIVATE, total_ram, IPC_CREAT | 0700); if (shm_id < 0) { -- 1.9.3 ------------------------------------------------------------------------------ Dive into the World of Parallel Programming. The Go Parallel Website, sponsored by Intel and developed in partnership with Slashdot Media, is your hub for all things parallel software development, from weekly thought leadership blogs to news, videos, case studies, tutorials and more. Take a look and join the conversation now. http://goparallel.sourceforge.net/ _______________________________________________ Ltp-list mailing list Ltp-list@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/ltp-list