Thanks a lot for your review and suggestion, I will send the V2 immediately.

Regards,
Xing Gu

On 3/5/2014 5:27 AM, Jan Stancek wrote:
>
> ----- Original Message -----
>> From: "Gu Xing" <[email protected]>
>> To: [email protected]
>> Sent: Friday, 21 February, 2014 11:22:29 AM
>> Subject: [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag 
>> test
>>
>> create a new case to test PROT_NONE, PROT_EXEC flag for mprotect(2)
>>
>> Signed-off-by: Gu Xing <[email protected]>
>> ---
>>   runtest/ltplite                                 |   1 +
>>   runtest/stress.part3                            |   1 +
>>   runtest/syscalls                                |   1 +
>>   testcases/kernel/syscalls/.gitignore            |   1 +
>>   testcases/kernel/syscalls/mprotect/mprotect04.c | 204
>>   ++++++++++++++++++++++++
>>   5 files changed, 208 insertions(+)
>>   create mode 100644 testcases/kernel/syscalls/mprotect/mprotect04.c
>>
>> diff --git a/runtest/ltplite b/runtest/ltplite
>> index c6d647d..a9686a0 100644
>> --- a/runtest/ltplite
>> +++ b/runtest/ltplite
>> @@ -463,6 +463,7 @@ modify_ldt02 modify_ldt02
>>   mprotect01 mprotect01
>>   mprotect02 mprotect02
>>   mprotect03 mprotect03
>> +mprotect04 mprotect04
>>   
>>   mremap01 mremap01
>>   mremap02 mremap02
>> diff --git a/runtest/stress.part3 b/runtest/stress.part3
>> index b9b8d7a..6f521cf 100644
>> --- a/runtest/stress.part3
>> +++ b/runtest/stress.part3
>> @@ -386,6 +386,7 @@ modify_ldt02 modify_ldt02
>>   mprotect01 mprotect01
>>   mprotect02 mprotect02
>>   mprotect03 mprotect03
>> +mprotect04 mprotect04
>>   
>>   mremap01 mremap01
>>   mremap02 mremap02
>> diff --git a/runtest/syscalls b/runtest/syscalls
>> index 13716d7..d803987 100644
>> --- a/runtest/syscalls
>> +++ b/runtest/syscalls
>> @@ -606,6 +606,7 @@ move_pages11 cd $LTPROOT/testcases/bin && chown root
>> move_pages11 && chmod 04755
>>   mprotect01 mprotect01
>>   mprotect02 mprotect02
>>   mprotect03 mprotect03
>> +mprotect04 mprotect04
>>   
>>   mq_notify01 mq_notify01
>>   mq_open01 mq_open01
>> diff --git a/testcases/kernel/syscalls/.gitignore
>> b/testcases/kernel/syscalls/.gitignore
>> index 42b0eed..7642b11 100644
>> --- a/testcases/kernel/syscalls/.gitignore
>> +++ b/testcases/kernel/syscalls/.gitignore
>> @@ -550,6 +550,7 @@
>>   /mprotect/mprotect01
>>   /mprotect/mprotect02
>>   /mprotect/mprotect03
>> +/mprotect/mprotect04
>>   /mq_notify/mq_notify01
>>   /mq_open/mq_open01
>>   /mq_timedreceive/mq_timedreceive01
>> diff --git a/testcases/kernel/syscalls/mprotect/mprotect04.c
>> b/testcases/kernel/syscalls/mprotect/mprotect04.c
>> new file mode 100644
>> index 0000000..1390175
>> --- /dev/null
>> +++ b/testcases/kernel/syscalls/mprotect/mprotect04.c
>> @@ -0,0 +1,204 @@
>> +/*
>> + * Copyright (c) 2014 Fujitsu Ltd.
>> + * Author: Gu Xing <[email protected]>
>> + *
>> + * This program is free software; you can redistribute it and/or modify it
>> + * under the terms of version 2 of the GNU General Public License as
>> + * published by the Free Software Foundation.
>> + *
>> + * This program is distributed in the hope that it would be useful, but
>> + * WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
>> + *
>> + * You should have received a copy of the GNU General Public License along
>> + * with this program; if not, write the Free Software Foundation, Inc.,
>> + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
>> + */
>> +/*
>> + * Description:
>> + *   Verify that,
>> + *   1) mprotect() succeeds to set a region of memory with no access,
>> + *      when 'prot' is set to PROT_NONE. An attempt to access the contents
>> + *      of the region gives rise to the signal SIGSEGV.
>> + *   2) mprotect() succeeds to set a region of memory to be executed, when
>> + *      'prot' is set to PROT_EXEC.
>> + */
>> +
>> +#include <signal.h>
>> +#include <setjmp.h>
>> +#include <sys/types.h>
>> +#include <sys/stat.h>
>> +#include <fcntl.h>
>> +#include <unistd.h>
>> +#include <errno.h>
>> +#include <string.h>
>> +#include <sys/mman.h>
>> +#include <bits/wordsize.h>
>> +#include <stdlib.h>
>> +
>> +#include "test.h"
>> +#include "usctest.h"
>> +#include "safe_macros.h"
>> +
>> +#define TEST_FILE1 "testfile1"
>> +
>> +#if __WORDSIZE == 64
>> +typedef unsigned long long psint_t;
>> +#else
>> +typedef unsigned int psint_t;
>> +#endif
> Hi,
>
> You could use uintptr_t, but I think you can avoid also that,
> see below.
>
>> +
>> +static void sighandler(int sig);
>> +
>> +static void setup(void);
>> +static void cleanup(void);
>> +
>> +static void testfunc_protnone(void);
>> +
>> +static void exec_func(void);
>> +static int (*func)(void);
>> +static void testfunc_protexec(void);
>> +
>> +static void (*testfunc[])(void) = { testfunc_protnone, testfunc_protexec };
>> +
>> +char *TCID = "mprotect04";
>> +int TST_TOTAL = ARRAY_SIZE(testfunc);
>> +
>> +static int pass;
>> +static sigjmp_buf env;
>> +static int page_sz;
>> +
>> +int main(int ac, char **av)
>> +{
>> +    int lc;
>> +    int i;
>> +    char *msg;
>> +
>> +    msg = parse_opts(ac, av, NULL, NULL);
>> +    if (msg != NULL)
>> +            tst_brkm(TBROK, NULL, "OPTION PARSING ERROR - %s", msg);
>> +
>> +    setup();
>> +
>> +    for (lc = 0; TEST_LOOPING(lc); lc++) {
>> +            tst_count = 0;
>> +
>> +            for (i = 0; i < TST_TOTAL; i++)
>> +                    (*testfunc[i])();
>> +    }
>> +
>> +    cleanup();
>> +    tst_exit();
>> +}
>> +
>> +static void sighandler(int sig)
>> +{
>> +    if (sig == SIGSEGV) {
>> +            pass = 1;
>> +            siglongjmp(env, 1);
>> +    } else {
>> +            tst_brkm(TBROK, cleanup, "received an unexpected signal: %d",
>> +                     sig);
>> +    }
>> +}
>> +
>> +static void setup(void)
>> +{
>> +    tst_sig(NOFORK, sighandler, cleanup);
>> +
>> +    TEST_PAUSE;
>> +
>> +    tst_tmpdir();
>> +}
>> +
>> +static void testfunc_protnone(void)
>> +{
>> +    int fd;
>> +    int write_sz;
>> +    const char buf[] = "abcdefghijklmnopqistuvwxyz";
>> +    char *addr = MAP_FAILED;
> No need to initialize it, that value is immediately thrown away.
>
>> +
>> +    fd = SAFE_OPEN(cleanup, TEST_FILE1, O_RDWR | O_CREAT, 0777);
>> +
>> +    page_sz = getpagesize();
> Is there any reason for page_sz to be global variable?
>
>> +
>> +    do {
>> +            if ((size_t)page_sz > strlen(buf))
>> +                    write_sz = strlen(buf);
>> +            else
>> +                    write_sz = page_sz;
>> +
>> +            page_sz -= SAFE_WRITE(cleanup, 1, fd, buf, write_sz);
>> +
>> +    } while (page_sz > 0);
>> +
>> +    addr = SAFE_MMAP(cleanup, 0, sizeof(buf), PROT_READ | PROT_WRITE,
>> +                     MAP_SHARED, fd, 0);
> Not sure why you need a file. Not that it's bad, it seems unnecessary,
> as you could do:
>          addr = SAFE_MMAP(cleanup, 0, getpagesize(), PROT_READ | PROT_WRITE,
>                           MAP_PRIVATE|MAP_ANONYMOUS, -1, 0);
>
>> +
>> +    /* Change the protection to NONE. */
>> +    TEST(mprotect(addr, sizeof(buf), PROT_NONE));
>> +
>> +    if (TEST_RETURN == -1) {
>> +            tst_resm(TFAIL | TTERRNO, "mprotect failed");
>> +            goto cleanup_protnone;
>> +    }
> If you add else here, you can remove goto.
>
>> +
>> +    if (sigsetjmp(env, 1) == 0)
>> +            addr[0] = 1;
>> +
>> +    if (pass)
>> +            tst_resm(TPASS, "test PROT_NONE for mprotect success");
>> +    else
>> +            tst_resm(TFAIL, "test PROT_NONE for mprotect failed");
>> +
>> +    pass = 0;
> Resetting this value before test looks easier to follow.
>
>> +
>> +cleanup_protnone:
>> +    SAFE_MUNMAP(cleanup, addr, sizeof(buf));
>> +    addr = MAP_FAILED;
> No need to reset addr here.
>
>> +
>> +    SAFE_CLOSE(cleanup, fd);
>> +}
>> +
>> +static void exec_func(void)
>> +{
>> +    return;
>> +}
>> +
>> +static void testfunc_protexec(void)
>> +{
>> +    psint_t base_func;
>> +
>> +    page_sz = getpagesize();
>> +
>> +    func = SAFE_MALLOC(cleanup, page_sz);
>> +
>> +    bcopy(exec_func, func, page_sz);
>> +
>> +    base_func = (psint_t)func & ~(page_sz - 1);
>> +
>> +    /* Change the protection to EXEC. */
>> +    TEST(mprotect((void *)base_func, page_sz, PROT_EXEC));
> You malloc page, align that address and then change protection
> for memory that can be also outside what you just allocated.
>
> It fails for me with:
> mprotect04    2  TFAIL  :  mprotect failed: TEST_ERRNO=EACCES(13): Permission 
> denied
>
> Also I don't see any free for that malloc.
> I'd suggest mmap instead, the result will be already aligned on page.
>
>> +
>> +    if (TEST_RETURN == -1) {
>> +            tst_resm(TFAIL | TTERRNO, "mprotect failed");
>> +            return;
>> +    }
>> +
>> +    if (sigsetjmp(env, 1) == 0)
>> +            (*func)();
>> +
>> +    if (pass)
>> +            tst_resm(TFAIL, "test PROT_EXEC for mprotect failed");
> This looks bit confusing, I'd suggest to rename variable to
> something like "sighandler_called" and again reset value before test.
>
> Regards,
> Jan
>
>> +    else
>> +            tst_resm(TPASS, "test PROT_EXEC for mprotect success");
>> +
>> +    pass = 0;
>> +}
>> +
>> +static void cleanup(void)
>> +{
>> +    tst_rmdir();
>> +
>> +    TEST_CLEANUP;
>> +}
>> --
>> 1.8.3.1
>>
>>
>> ------------------------------------------------------------------------------
>> Managing the Performance of Cloud-Based Applications
>> Take advantage of what the Cloud has to offer - Avoid Common Pitfalls.
>> Read the Whitepaper.
>> http://pubads.g.doubleclick.net/gampad/clk?id=121054471&iu=/4140/ostg.clktrk
>> _______________________________________________
>> Ltp-list mailing list
>> [email protected]
>> https://lists.sourceforge.net/lists/listinfo/ltp-list
>>


------------------------------------------------------------------------------
Subversion Kills Productivity. Get off Subversion & Make the Move to Perforce.
With Perforce, you get hassle-free workflows. Merge that actually works. 
Faster operations. Version large binaries.  Built-in WAN optimization and the
freedom to use Git, Perforce or both. Make the move to Perforce.
http://pubads.g.doubleclick.net/gampad/clk?id=122218951&iu=/4140/ostg.clktrk
_______________________________________________
Ltp-list mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ltp-list

Reply via email to