/* @(#)faccessat.c 1.1 14/05/11 Copyright 2013-2014 J. Schilling */ /* * Emulate the behavior of faccessat(int fd, const char *name, * int amode, int flag) * * Note that emulation methods that do not use the /proc filesystem are * not MT safe. In the non-MT-safe case, we do: * * savewd()/fchdir()/open(name)/restorewd() * * Errors may force us to abort the program as our caller is not expected * to know that we do more than a simple open() here and that the * working directory may be changed by us. * * Copyright (c) 2013-2014 J. Schilling */ /* * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * See the file CDDL.Schily.txt in this distribution for details. * A copy of the CDDL is also available via the Internet at * http://www.opensource.org/licenses/cddl1.txt * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file CDDL.Schily.txt from this distribution. */ #include #include #include #include #include #include #include #include "at-defs.h" #ifndef HAVE_FACCESSAT /* CSTYLED */ #define PROTO_DECL , int amode, int flag #define KR_DECL int amode; int flag; /* CSTYLED */ #define KR_ARGS , amode, flag #define FUNC_CALL(n) (flag & AT_EACCESS ? \ eaccess(n, amode) : access(n, amode)) #define FLAG_CHECK() if (flag & ~(AT_EACCESS)) { \ seterrno(EINVAL); \ return (-1); \ } #define FUNC_NAME faccessat #define FUNC_RESULT int #include "at-base.c" #endif /* HAVE_FCHOWNAT */