From 6dd265b961165a08b8d601c7ae693f64c4a6346f Mon Sep 17 00:00:00 2001 From: Eugene Syromyatnikov Date: Wed, 4 Apr 2018 23:25:19 +0200 Subject: [PATCH] tests: add more mount checks * tests/gen_tests.in (mount, mount-Xabbrev, mount-Xraw, mount-Xverbose): Add -a33 option. * tests/mount.c: Check printing of flags and pointers. Co-Authored-by: Dmitry V. Levin --- tests/gen_tests.in | 8 ++++---- tests/mount.c | 38 ++++++++++++++++++++++++++++++++++---- 2 files changed, 38 insertions(+), 8 deletions(-) diff --git a/tests/gen_tests.in b/tests/gen_tests.in index bd6565d1..a9e0a75f 100644 --- a/tests/gen_tests.in +++ b/tests/gen_tests.in @@ -192,10 +192,10 @@ mmsg-silent -a25 -e verbose=none -e trace=sendmmsg,recvmmsg mmsg_name -a25 -e trace=sendmmsg,recvmmsg mmsg_name-v -v -a25 -e trace=sendmmsg,recvmmsg modify_ldt -a23 -mount -mount-Xabbrev -e trace=mount -Xabbrev -mount-Xraw -e trace=mount -Xraw -mount-Xverbose -e trace=mount -Xverbose +mount -a33 +mount-Xabbrev -a33 -e trace=mount -Xabbrev +mount-Xraw -a33 -e trace=mount -Xraw +mount-Xverbose -a33 -e trace=mount -Xverbose move_pages -s3 mq -a32 -e trace=mq_getsetattr,mq_open,mq_unlink mq_sendrecv -a14 -e trace=mq_open,mq_notify,mq_timedsend,mq_timedreceive,mq_unlink diff --git a/tests/mount.c b/tests/mount.c index b96a5679..ba422f8e 100644 --- a/tests/mount.c +++ b/tests/mount.c @@ -41,12 +41,16 @@ #endif #if XLAT_RAW +# define str_unknown "0x300" +# define str_submount_200 "0x4000200" # define str_mgc_val "0xc0ed0000" # define str_remount "0x20" # define str_bind "0x1000" # define str_ro_nosuid_nodev_noexec "0xf" # define str_ro_nosuid_nodev_noexec_relatime "0x20000f" #elif XLAT_VERBOSE +# define str_unknown "0x300 /* MS_??? */" +# define str_submount_200 "0x4000200 /* MS_SUBMOUNT|0x200 */" # define str_mgc_val "0xc0ed0000 /* MS_MGC_VAL */" # define str_remount "0x20 /* MS_REMOUNT */" # define str_bind "0x1000 /* MS_BIND */" @@ -55,6 +59,8 @@ # define str_ro_nosuid_nodev_noexec_relatime \ "0x20000f /* MS_RDONLY|MS_NOSUID|MS_NODEV|MS_NOEXEC|MS_RELATIME */" #else /* !XLAT_RAW && !XLAT_VERBOSE */ +# define str_unknown "0x300 /* MS_??? */" +# define str_submount_200 "MS_SUBMOUNT|0x200" # define str_mgc_val "MS_MGC_VAL" # define str_remount "MS_REMOUNT" # define str_bind "MS_BIND" @@ -70,8 +76,24 @@ main(void) static const char target[] = "mount_target"; static const char fstype[] = "mount_fstype"; static const char data[] = "mount_data"; + TAIL_ALLOC_OBJECT_CONST_PTR(char, bogus); - int rc = mount(source, target, fstype, 15, data); + bogus[0] = 'a'; + + int rc = mount(NULL, NULL, NULL, 0, NULL); + printf("mount(NULL, NULL, NULL, 0, NULL) = %s\n", + sprintrc(rc)); + + rc = mount(bogus, bogus, bogus, 768, bogus); + printf("mount(%p, %p, %p, %s, %p) = %s\n", + bogus, bogus, bogus, str_unknown, bogus, sprintrc(rc)); + + rc = mount(bogus + 1, bogus + 1, bogus + 1, 0x4000200, bogus + 1); + printf("mount(%p, %p, %p, %s, %p) = %s\n", + bogus + 1, bogus + 1, bogus + 1, str_submount_200, + bogus + 1, sprintrc(rc)); + + rc = mount(source, target, fstype, 15, data); printf("mount(\"%s\", \"%s\", \"%s\", %s, \"%s\") = %s\n", source, target, fstype, str_ro_nosuid_nodev_noexec, data, sprintrc(rc)); @@ -92,13 +114,21 @@ main(void) str_mgc_val "|" str_ro_nosuid_nodev_noexec, data, sprintrc(rc)); + rc = mount(source, target, NULL, MS_REMOUNT, data); + printf("mount(\"%s\", \"%s\", NULL, %s, \"%s\") = %s\n", + source, target, str_remount, data, sprintrc(rc)); + rc = mount(source, target, fstype, MS_REMOUNT, data); printf("mount(\"%s\", \"%s\", %p, %s, \"%s\") = %s\n", source, target, fstype, str_remount, data, sprintrc(rc)); - rc = mount(source, target, fstype, MS_BIND, data); - printf("mount(\"%s\", \"%s\", %p, %s, %p) = %s\n", - source, target, fstype, str_bind, data, sprintrc(rc)); + rc = mount(source, target, NULL, MS_BIND, data); + printf("mount(\"%s\", \"%s\", NULL, %s, %p) = %s\n", + source, target, str_bind, data, sprintrc(rc)); + + rc = mount(source, target, fstype, MS_BIND, NULL); + printf("mount(\"%s\", \"%s\", %p, %s, NULL) = %s\n", + source, target, fstype, str_bind, sprintrc(rc)); puts("+++ exited with 0 +++"); return 0;