/* * Copyright (c) 2000 Silicon Graphics, Inc. All Rights Reserved. * * 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. * * Further, this software is distributed without any warranty that it is * free of the rightful claim of any third person regarding infringement * or the like. Any license provided herein, whether implied or * otherwise, applies only to this software file. Patent licenses, if * any, provided herein do not apply to combinations of this program with * other software, or any other product whatsoever. * * 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. * */ /* * access(2) test for errno(s) EFAULT as root and nobody respectively. */ #include <errno.h> #include <unistd.h> #include <sys/types.h> #include <pwd.h> #include "tst_test.h" static uid_t uid; static struct tcase { void *addr; int mode; char *name; } tcases[] = { {(void *)-1, F_OK, "F_OK"}, {(void *)-1, R_OK, "R_OK"}, {(void *)-1, W_OK, "W_OK"}, {(void *)-1, X_OK, "X_OK"}, }; static void access_test(struct tcase *tc, const char *user) { TEST(access(tc->addr, tc->mode)); if (TEST_RETURN != -1) { tst_res(TFAIL, "access(%p, %s) as %s succeeded unexpectedly", tc->addr, tc->name, user); return; } if (TEST_ERRNO != EFAULT) { tst_res(TFAIL | TTERRNO, "access(%p, %s) as %s should fail with EFAULT", tc->addr, tc->name, user); return; } tst_res(TPASS | TTERRNO, "access(%p, %s) as %s", tc->addr, tc->name, user); } static void verify_access(unsigned int n) { struct tcase *tc = &tcases[n]; pid_t pid; /* test as root */ access_test(tc, "root"); /* test as nobody */ pid = SAFE_FORK(); if (pid) { SAFE_WAITPID(pid, NULL, 0); } else { SAFE_SETUID(uid); access_test(tc, "nobody"); } } static void setup(void) { struct passwd *pw; pw = SAFE_GETPWNAM("nobody"); uid = pw->pw_uid; } static struct tst_test test = { .tcnt = ARRAY_SIZE(tcases), .needs_root = 1, .forks_child = 1, .setup = setup, .test = verify_access, };