/*
* Copyright (c) Wipro Technologies Ltd, 2002. 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.
*
* 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: This is a setuid to root program invoked by a non-root
* process to validate the mount flag MS_NOSUID.
*
* This function exit with 0 or 1 depending upon the
* success/failure of setuid(2) system call.
*/
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdlib.h>
#include <errno.h>
/* Save the effective and real UIDs. */
static uid_t ruid;
/* Restore the effective UID to its original value. */
int do_setuid(void)
{
int status;
status = setreuid(ruid, 0);
if (status < 0) {
return 1;
} else {
return 0;
}
return 0;
}
/* Main program. */
int main(void)
{
int exit_status;
/* Save the real and effective user IDs. */
ruid = getuid();
exit_status = do_setuid();
exit(exit_status);
}