X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=stdin.c;h=0b84cdc72011e369bf290f671ae96d6e8cab8569;hp=5b6bf520cb6b09f54e6dc30cb3f21c8d7118ba63;hb=2d945f96dcd02bcabd02a79342712e089ed30c98;hpb=0810e4932d4d8fb477d4af5596d4b263d2538ff6 diff --git a/stdin.c b/stdin.c index 5b6bf520..0b84cdc7 100644 --- a/stdin.c +++ b/stdin.c @@ -31,6 +31,11 @@ static void stdin_pre_select(struct sched *s, struct task *t) { struct stdin_task *sit = container_of(t, struct stdin_task, task); + + if (sit->output_error && *sit->output_error < 0) { + t->error = *sit->output_error; + return; + } t->error = 0; sit->check_fd = 0; if (sit->loaded >= sit->bufsize) @@ -55,6 +60,10 @@ static void stdin_post_select(struct sched *s, struct task *t) struct stdin_task *sit = container_of(t, struct stdin_task, task); ssize_t ret; + if (sit->output_error && *sit->output_error < 0) { + t->error = *sit->output_error; + return; + } t->error = 0; if (!sit->check_fd) return; @@ -89,6 +98,7 @@ void stdin_set_defaults(struct stdin_task *sit) ret = mark_fd_nonblocking(STDIN_FILENO); if (ret >= 0) return; + sit->output_error = NULL; PARA_EMERG_LOG("%s\n", para_strerror(-ret)); exit(EXIT_FAILURE); }