Blame envy24control/new_process.c

Packit Service b98cfc
#include <sys/wait.h>
Packit Service b98cfc
#include <signal.h>
Packit Service b98cfc
#include <errno.h>
Packit Service b98cfc
#include <unistd.h>
Packit Service b98cfc
#include <sys/stat.h>
Packit Service b98cfc
#include <sys/types.h>
Packit Service b98cfc
Packit Service b98cfc
#ifndef MAX_PARAM
Packit Service b98cfc
#define MAX_PARAM 10
Packit Service b98cfc
#endif
Packit Service b98cfc
Packit Service b98cfc
/*
Packit Service b98cfc
 * start child process
Packit Service b98cfc
 */
Packit Service b98cfc
int new_process(char * const cmd_line[MAX_PARAM])
Packit Service b98cfc
{
Packit Service b98cfc
	int proc_status;
Packit Service b98cfc
	pid_t pid;
Packit Service b98cfc
	pid_t w;
Packit Service b98cfc
	struct stat file_status;
Packit Service b98cfc
Packit Service b98cfc
	/* memory for storage of function pointers from the signal handling routines */
Packit Service b98cfc
	void (*int_stat)();
Packit Service b98cfc
	void (*quit_stat)();
Packit Service b98cfc
	void (*usr2_stat)();
Packit Service b98cfc
Packit Service b98cfc
	/*
Packit Service b98cfc
	 * check command file
Packit Service b98cfc
	 */
Packit Service b98cfc
Packit Service b98cfc
	/* search file */
Packit Service b98cfc
	if (stat(cmd_line[0], &file_status) < 0) {
Packit Service b98cfc
		fprintf(stderr, "Cannot find program '%s'.\n", cmd_line[0]);
Packit Service b98cfc
		fprintf(stderr, "You must specify path for '%s'.\n", cmd_line[0]);
Packit Service b98cfc
		return -errno;
Packit Service b98cfc
	}
Packit Service b98cfc
Packit Service b98cfc
	proc_status = 0;
Packit Service b98cfc
	/* check file status and permissions */
Packit Service b98cfc
	if (file_status.st_mode & S_IFREG) {
Packit Service b98cfc
		if (!(file_status.st_mode & S_IXOTH)) {
Packit Service b98cfc
			if (!(file_status.st_mode & S_IXGRP)) {
Packit Service b98cfc
				if (!(file_status.st_mode & S_IXUSR)) {
Packit Service b98cfc
					proc_status = -EACCES;
Packit Service b98cfc
				} else if (file_status.st_uid != getuid()) {
Packit Service b98cfc
					proc_status = -EACCES;
Packit Service b98cfc
				}
Packit Service b98cfc
			} else if ((file_status.st_gid != getgid()) && (file_status.st_uid != getuid())) {
Packit Service b98cfc
				proc_status = -EACCES;
Packit Service b98cfc
			}
Packit Service b98cfc
		}
Packit Service b98cfc
	} else {
Packit Service b98cfc
		proc_status = -EACCES;
Packit Service b98cfc
	}
Packit Service b98cfc
		
Packit Service b98cfc
	if (proc_status != 0) {
Packit Service b98cfc
		fprintf(stderr, "No permissions to execute program '%s'.\n", cmd_line[0]);
Packit Service b98cfc
		return proc_status;
Packit Service b98cfc
	}
Packit Service b98cfc
Packit Service b98cfc
	if ( (pid = fork() ) == 0) {
Packit Service b98cfc
		execv(cmd_line[0], cmd_line);
Packit Service b98cfc
	}
Packit Service b98cfc
Packit Service b98cfc
	/* for waiting ingnoring special interrupts */
Packit Service b98cfc
Packit Service b98cfc
	int_stat = signal(SIGINT, SIG_IGN);
Packit Service b98cfc
	quit_stat = signal(SIGQUIT, SIG_IGN);
Packit Service b98cfc
	usr2_stat = signal(SIGUSR2, SIG_IGN);
Packit Service b98cfc
Packit Service b98cfc
	/* waiting for the end of the child process */
Packit Service b98cfc
Packit Service b98cfc
	while ( ( (w = wait(&proc_status)) != pid ) && (w != -1) )
Packit Service b98cfc
		;
Packit Service b98cfc
	if (w == -1) {
Packit Service b98cfc
		proc_status = -errno;
Packit Service b98cfc
	}
Packit Service b98cfc
Packit Service b98cfc
	/* restore pointers from signal handling routines */
Packit Service b98cfc
Packit Service b98cfc
	signal(SIGINT, int_stat);
Packit Service b98cfc
	signal(SIGQUIT, quit_stat);
Packit Service b98cfc
	signal(SIGUSR2, usr2_stat);
Packit Service b98cfc
Packit Service b98cfc
	return proc_status;
Packit Service b98cfc
}