1*63d1fd59SEnji Cooper /* $NetBSD: t_pr.c,v 1.9 2017/01/13 21:30:40 christos Exp $ */ 257718be8SEnji Cooper 357718be8SEnji Cooper #include <sys/types.h> 457718be8SEnji Cooper #include <sys/mount.h> 557718be8SEnji Cooper 657718be8SEnji Cooper #include <atf-c.h> 757718be8SEnji Cooper #include <err.h> 857718be8SEnji Cooper #include <errno.h> 957718be8SEnji Cooper #include <fcntl.h> 1057718be8SEnji Cooper #include <stdio.h> 1157718be8SEnji Cooper #include <unistd.h> 1257718be8SEnji Cooper #include <string.h> 1357718be8SEnji Cooper #include <stdlib.h> 1457718be8SEnji Cooper 1557718be8SEnji Cooper #include <rump/rump.h> 1657718be8SEnji Cooper #include <rump/rump_syscalls.h> 1757718be8SEnji Cooper 1857718be8SEnji Cooper #include <miscfs/union/union.h> 1957718be8SEnji Cooper 20*63d1fd59SEnji Cooper #include "h_macros.h" 2157718be8SEnji Cooper 2257718be8SEnji Cooper ATF_TC(multilayer); 2357718be8SEnji Cooper ATF_TC_HEAD(multilayer, tc) 2457718be8SEnji Cooper { 2557718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "mount_union -b twice"); 2657718be8SEnji Cooper } 2757718be8SEnji Cooper 2857718be8SEnji Cooper ATF_TC_BODY(multilayer, tc) 2957718be8SEnji Cooper { 3057718be8SEnji Cooper struct union_args unionargs; 3157718be8SEnji Cooper 3257718be8SEnji Cooper rump_init(); 3357718be8SEnji Cooper 3457718be8SEnji Cooper if (rump_sys_mkdir("/Tunion", 0777) == -1) 3557718be8SEnji Cooper atf_tc_fail_errno("mkdir mp1"); 3657718be8SEnji Cooper if (rump_sys_mkdir("/Tunion2", 0777) == -1) 3757718be8SEnji Cooper atf_tc_fail_errno("mkdir mp2"); 3857718be8SEnji Cooper if (rump_sys_mkdir("/Tunion2/A", 0777) == -1) 3957718be8SEnji Cooper atf_tc_fail_errno("mkdir A"); 4057718be8SEnji Cooper if (rump_sys_mkdir("/Tunion2/B", 0777) == -1) 4157718be8SEnji Cooper atf_tc_fail_errno("mkdir B"); 4257718be8SEnji Cooper 4357718be8SEnji Cooper unionargs.target = __UNCONST("/Tunion2/A"); 4457718be8SEnji Cooper unionargs.mntflags = UNMNT_BELOW; 4557718be8SEnji Cooper 4657718be8SEnji Cooper if (rump_sys_mount(MOUNT_UNION, "/Tunion", 0, 4757718be8SEnji Cooper &unionargs, sizeof(unionargs)) == -1) 4857718be8SEnji Cooper atf_tc_fail_errno("union mount"); 4957718be8SEnji Cooper 5057718be8SEnji Cooper unionargs.target = __UNCONST("/Tunion2/B"); 5157718be8SEnji Cooper unionargs.mntflags = UNMNT_BELOW; 5257718be8SEnji Cooper 5357718be8SEnji Cooper rump_sys_mount(MOUNT_UNION, "/Tunion", 0,&unionargs,sizeof(unionargs)); 5457718be8SEnji Cooper } 5557718be8SEnji Cooper 5657718be8SEnji Cooper ATF_TC(devnull1); 5757718be8SEnji Cooper ATF_TC_HEAD(devnull1, tc) 5857718be8SEnji Cooper { 5957718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "mount_union -b and " 6057718be8SEnji Cooper "'echo x > /un/null'"); 6157718be8SEnji Cooper } 6257718be8SEnji Cooper 6357718be8SEnji Cooper ATF_TC_BODY(devnull1, tc) 6457718be8SEnji Cooper { 6557718be8SEnji Cooper struct union_args unionargs; 6657718be8SEnji Cooper int fd, res; 6757718be8SEnji Cooper 6857718be8SEnji Cooper rump_init(); 6957718be8SEnji Cooper 7057718be8SEnji Cooper if (rump_sys_mkdir("/mp", 0777) == -1) 7157718be8SEnji Cooper atf_tc_fail_errno("mkdir mp"); 7257718be8SEnji Cooper 7357718be8SEnji Cooper unionargs.target = __UNCONST("/dev"); 7457718be8SEnji Cooper unionargs.mntflags = UNMNT_BELOW; 7557718be8SEnji Cooper 7657718be8SEnji Cooper if (rump_sys_mount(MOUNT_UNION, "/mp", 0, 7757718be8SEnji Cooper &unionargs, sizeof(unionargs)) == -1) 7857718be8SEnji Cooper atf_tc_fail_errno("union mount"); 7957718be8SEnji Cooper 8057718be8SEnji Cooper fd = rump_sys_open("/mp/null", O_WRONLY | O_CREAT | O_TRUNC); 8157718be8SEnji Cooper 8257718be8SEnji Cooper if (fd == -1) 8357718be8SEnji Cooper atf_tc_fail_errno("open"); 8457718be8SEnji Cooper 8557718be8SEnji Cooper res = rump_sys_write(fd, &fd, sizeof(fd)); 8657718be8SEnji Cooper if (res != sizeof(fd)) 8757718be8SEnji Cooper atf_tc_fail("write"); 8857718be8SEnji Cooper } 8957718be8SEnji Cooper 9057718be8SEnji Cooper ATF_TC(devnull2); 9157718be8SEnji Cooper ATF_TC_HEAD(devnull2, tc) 9257718be8SEnji Cooper { 9357718be8SEnji Cooper atf_tc_set_md_var(tc, "descr", "mount_union -b and " 9457718be8SEnji Cooper "'echo x >> /un/null'"); 9557718be8SEnji Cooper } 9657718be8SEnji Cooper 9757718be8SEnji Cooper ATF_TC_BODY(devnull2, tc) 9857718be8SEnji Cooper { 9957718be8SEnji Cooper struct union_args unionargs; 10057718be8SEnji Cooper int fd, res; 10157718be8SEnji Cooper 10257718be8SEnji Cooper rump_init(); 10357718be8SEnji Cooper 10457718be8SEnji Cooper if (rump_sys_mkdir("/mp", 0777) == -1) 10557718be8SEnji Cooper atf_tc_fail_errno("mkdir mp"); 10657718be8SEnji Cooper 10757718be8SEnji Cooper unionargs.target = __UNCONST("/dev"); 10857718be8SEnji Cooper unionargs.mntflags = UNMNT_BELOW; 10957718be8SEnji Cooper 11057718be8SEnji Cooper if (rump_sys_mount(MOUNT_UNION, "/mp", 0, 11157718be8SEnji Cooper &unionargs, sizeof(unionargs)) == -1) 11257718be8SEnji Cooper atf_tc_fail_errno("union mount"); 11357718be8SEnji Cooper 11457718be8SEnji Cooper fd = rump_sys_open("/mp/null", O_WRONLY | O_CREAT | O_APPEND); 11557718be8SEnji Cooper if (fd == -1) 11657718be8SEnji Cooper atf_tc_fail_errno("open"); 11757718be8SEnji Cooper 11857718be8SEnji Cooper res = rump_sys_write(fd, &fd, sizeof(fd)); 11957718be8SEnji Cooper if (res != sizeof(fd)) 12057718be8SEnji Cooper atf_tc_fail("write"); 12157718be8SEnji Cooper } 12257718be8SEnji Cooper 12357718be8SEnji Cooper ATF_TP_ADD_TCS(tp) 12457718be8SEnji Cooper { 12557718be8SEnji Cooper ATF_TP_ADD_TC(tp, multilayer); 12657718be8SEnji Cooper ATF_TP_ADD_TC(tp, devnull1); 12757718be8SEnji Cooper ATF_TP_ADD_TC(tp, devnull2); 12857718be8SEnji Cooper 12957718be8SEnji Cooper return atf_no_error(); 13057718be8SEnji Cooper } 131