fis-gtm/sr_unix/ojchildioset.c

189 lines
5.2 KiB
C

/****************************************************************
* *
* Copyright 2001, 2009 Fidelity Information Services, Inc *
* *
* This source code contains the intellectual property *
* of its copyright holder(s), and is made available *
* under a license. If you do not know the terms of *
* the license, please stop and do not read further. *
* *
****************************************************************/
#include "mdef.h"
#include <errno.h>
#include "gtm_fcntl.h"
#include "gtm_stdio.h"
#include "gtm_string.h"
#include "gtm_unistd.h"
#include "gtm_stat.h"
#include "job.h"
#include "gtmio.h"
#include "eintr_wrappers.h"
#include "gtmmsg.h"
#ifdef __MVS__
#include "gtm_zos_io.h"
#endif
GBLREF boolean_t job_try_again;
#define NULL_DEV_FNAME "/dev/null" /* Null device file name */
#define OPEN_RSRC_CRUNCH_FAILURE \
(EDQUOT == errno || ENFILE == errno || ENOMEM == errno || ENOSPC == errno || ETIMEDOUT == errno)
/*
* ---------------------------------------------------------
* Set up input, output and error file descriptors in
* a child.
* ---------------------------------------------------------
*/
bool ojchildioset(job_params_type *jparms)
{
int dup_ret, in_fd, out_fd, err_fd, save_errno;
char fname_buf[1024], buf[1024];
int rc;
ZOS_ONLY(int realfiletag;)
error_def(ERR_TEXT);
error_def(ERR_JOBFAIL);
ZOS_ONLY(error_def(ERR_BADTAG);)
/* Redirect input */
strncpy(fname_buf, jparms->input.addr, jparms->input.len);
*(fname_buf + jparms->input.len) = '\0';
OPENFILE(fname_buf, O_RDONLY, in_fd);
if (FD_INVALID == in_fd)
{
if (OPEN_RSRC_CRUNCH_FAILURE)
job_try_again = TRUE;
else
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stdin (open) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
}
return FALSE;
}
CLOSEFILE(0, rc);
FCNTL3(in_fd, F_DUPFD, 0, dup_ret);
if (-1 == dup_ret)
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stdin (fcntl) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
return FALSE;
}
#ifdef __MVS__
/* policy tagging because by default input is /dev/null */
if (-1 == gtm_zos_tag_to_policy(in_fd, TAG_UNTAGGED, &realfiletag))
TAG_POLICY_SEND_MSG(fname_buf, errno, realfiletag, TAG_UNTAGGED);
#endif
CLOSEFILE_RESET(in_fd, rc); /* resets "in_fd" to FD_INVALID */
/*
* Redirect Output
*/
strncpy(fname_buf, jparms->output.addr, jparms->output.len);
*(fname_buf + jparms->output.len) = '\0';
CREATE_FILE(fname_buf, 0666, out_fd);
if (FD_INVALID == out_fd)
{
if (OPEN_RSRC_CRUNCH_FAILURE)
job_try_again = TRUE;
else
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stdout (creat) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
}
return FALSE;
}
#ifdef __MVS__
/* tagging as ASCII is fine now, that might change in the future for gtm_utf8_mode */
if (-1 == gtm_zos_set_tag(out_fd, TAG_ASCII, TAG_TEXT, TAG_FORCE, &realfiletag))
TAG_POLICY_SEND_MSG(fname_buf, errno, realfiletag, TAG_ASCII);
#endif
CLOSEFILE_RESET(out_fd, rc); /* resets "out_fd" to FD_INVALID */
OPENFILE(fname_buf, O_WRONLY, out_fd);
if (FD_INVALID == out_fd)
{
if (OPEN_RSRC_CRUNCH_FAILURE)
job_try_again = TRUE;
else
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stdout (open) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
}
return FALSE;
}
CLOSEFILE(1, rc);
FCNTL3(out_fd, F_DUPFD, 0, dup_ret);
if (-1 == dup_ret)
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stdout (fcntl) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
return FALSE;
}
CLOSEFILE_RESET(out_fd, rc); /* resets "out_fd" to FD_INVALID */
/*
* Redirect Error
*/
strncpy(fname_buf, jparms->error.addr, jparms->error.len);
*(fname_buf + jparms->error.len) = '\0';
CREATE_FILE(fname_buf, 0666, err_fd);
if (FD_INVALID == err_fd)
{
if (OPEN_RSRC_CRUNCH_FAILURE)
job_try_again = TRUE;
else
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stderr (creat) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
}
return FALSE;
}
#ifdef __MVS__
if (-1 == gtm_zos_set_tag(err_fd, TAG_EBCDIC, TAG_TEXT, TAG_FORCE, &realfiletag))
TAG_POLICY_SEND_MSG(fname_buf, errno, realfiletag, TAG_EBCDIC);
#endif
CLOSEFILE_RESET(err_fd, rc); /* resets "err_fd" to FD_INVALID */
OPENFILE(fname_buf, O_WRONLY, err_fd);
if (FD_INVALID == err_fd)
{
if (OPEN_RSRC_CRUNCH_FAILURE)
job_try_again = TRUE;
else
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stderr (open) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
}
return FALSE;
}
CLOSEFILE(2, rc);
FCNTL3(err_fd, F_DUPFD, 0, dup_ret);
if (-1 == dup_ret)
{
save_errno = errno;
SPRINTF(buf, "Error redirecting stderr (fcntl) to %s", fname_buf);
gtm_putmsg(VARLSTCNT(7) ERR_JOBFAIL, 0, ERR_TEXT, 2, LEN_AND_STR(buf), save_errno);
return FALSE;
}
CLOSEFILE_RESET(err_fd, rc); /* resets "err_fd" to FD_INVALID */
return(TRUE);
}