* [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test
@ 2014-02-21 10:22 Gu Xing
2014-03-04 6:40 ` guxing
2014-03-04 21:27 ` Jan Stancek
0 siblings, 2 replies; 4+ messages in thread
From: Gu Xing @ 2014-02-21 10:22 UTC (permalink / raw)
To: ltp-list
create a new case to test PROT_NONE, PROT_EXEC flag for mprotect(2)
Signed-off-by: Gu Xing <gux.fnst@cn.fujitsu.com>
---
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 <gux.fnst@cn.fujitsu.com>
+ *
+ * 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
+
+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;
+
+ fd = SAFE_OPEN(cleanup, TEST_FILE1, O_RDWR | O_CREAT, 0777);
+
+ page_sz = getpagesize();
+
+ 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);
+
+ /* 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 (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;
+
+cleanup_protnone:
+ SAFE_MUNMAP(cleanup, addr, sizeof(buf));
+ addr = MAP_FAILED;
+
+ 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));
+
+ 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");
+ 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
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test
2014-02-21 10:22 [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test Gu Xing
@ 2014-03-04 6:40 ` guxing
2014-03-04 21:27 ` Jan Stancek
1 sibling, 0 replies; 4+ messages in thread
From: guxing @ 2014-03-04 6:40 UTC (permalink / raw)
To: ltp-list
Hi,
Could any one help to review this patch?
Thanks,
Xing Gu
On 2/21/2014 6:22 PM, Gu Xing wrote:
> create a new case to test PROT_NONE, PROT_EXEC flag for mprotect(2)
>
> Signed-off-by: Gu Xing <gux.fnst@cn.fujitsu.com>
> ---
> 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 <gux.fnst@cn.fujitsu.com>
> + *
> + * 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
> +
> +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;
> +
> + fd = SAFE_OPEN(cleanup, TEST_FILE1, O_RDWR | O_CREAT, 0777);
> +
> + page_sz = getpagesize();
> +
> + 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);
> +
> + /* 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 (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;
> +
> +cleanup_protnone:
> + SAFE_MUNMAP(cleanup, addr, sizeof(buf));
> + addr = MAP_FAILED;
> +
> + 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));
> +
> + 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");
> + else
> + tst_resm(TPASS, "test PROT_EXEC for mprotect success");
> +
> + pass = 0;
> +}
> +
> +static void cleanup(void)
> +{
> + tst_rmdir();
> +
> + TEST_CLEANUP;
> +}
------------------------------------------------------------------------------
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
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test
2014-02-21 10:22 [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test Gu Xing
2014-03-04 6:40 ` guxing
@ 2014-03-04 21:27 ` Jan Stancek
2014-03-05 5:41 ` guxing
1 sibling, 1 reply; 4+ messages in thread
From: Jan Stancek @ 2014-03-04 21:27 UTC (permalink / raw)
To: gux.fnst; +Cc: ltp-list
----- Original Message -----
> From: "Gu Xing" <gux.fnst@cn.fujitsu.com>
> To: ltp-list@lists.sourceforge.net
> 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 <gux.fnst@cn.fujitsu.com>
> ---
> 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 <gux.fnst@cn.fujitsu.com>
> + *
> + * 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
> Ltp-list@lists.sourceforge.net
> 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
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test
2014-03-04 21:27 ` Jan Stancek
@ 2014-03-05 5:41 ` guxing
0 siblings, 0 replies; 4+ messages in thread
From: guxing @ 2014-03-05 5:41 UTC (permalink / raw)
To: Jan Stancek; +Cc: ltp-list
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" <gux.fnst@cn.fujitsu.com>
>> To: ltp-list@lists.sourceforge.net
>> 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 <gux.fnst@cn.fujitsu.com>
>> ---
>> 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 <gux.fnst@cn.fujitsu.com>
>> + *
>> + * 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
>> Ltp-list@lists.sourceforge.net
>> 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
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2014-03-05 5:41 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-02-21 10:22 [LTP] [PATCH] mprotect/mprotect04.c: add PROT_NONE, PROT_EXEC flag test Gu Xing
2014-03-04 6:40 ` guxing
2014-03-04 21:27 ` Jan Stancek
2014-03-05 5:41 ` guxing
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.