Skip to content

Commit

Permalink
Merge pull request #6365 from chu11/libsubprocess_bufsize_zero
Browse files Browse the repository at this point in the history
libsubprocess: check bufsize is > 0
  • Loading branch information
mergify[bot] authored Oct 11, 2024
2 parents d69bedd + 0482fd6 commit 50f8dc2
Show file tree
Hide file tree
Showing 4 changed files with 52 additions and 19 deletions.
38 changes: 26 additions & 12 deletions src/common/libsubprocess/server.c
Original file line number Diff line number Diff line change
Expand Up @@ -30,15 +30,17 @@
#include "server.h"
#include "client.h"

/* Keys used to store subprocess server, rexec.exec request, and
* 'subprocesses' zlistx handle in the subprocess object.
/* Keys used to store subprocess server, exec request
* (i.e. rexec.exec), and 'subprocesses' zlistx handle in the
* subprocess object.
*/
static const char *srvkey = "flux::server";
static const char *msgkey = "flux::request";
static const char *lstkey = "flux::handle";

struct subprocess_server {
flux_t *h;
char *service_name;
char *local_uri;
uint32_t rank;
subprocess_log_f llog;
Expand Down Expand Up @@ -140,7 +142,8 @@ static void proc_completion_cb (flux_subprocess_t *p)
/* no fallback if this fails */
if (flux_respond_error (s->h, request, ENODATA, NULL) < 0) {
llog_error (s,
"error responding to rexec.exec request: %s",
"error responding to %s.exec request: %s",
s->service_name,
strerror (errno));
}
}
Expand Down Expand Up @@ -218,7 +221,8 @@ static void proc_state_change_cb (flux_subprocess_t *p,
}
if (rc < 0) {
llog_error (s,
"error responding to rexec.exec request: %s",
"error responding to %s.exec request: %s",
s->service_name,
strerror (errno));
}
return;
Expand Down Expand Up @@ -252,7 +256,8 @@ static int proc_output (flux_subprocess_t *p,
"pid", flux_subprocess_pid (p),
"io", io) < 0) {
llog_error (s,
"error responding to rexec.exec request: %s",
"error responding to %s.exec request: %s",
s->service_name,
strerror (errno));
goto error;
}
Expand Down Expand Up @@ -395,7 +400,8 @@ static void server_exec_cb (flux_t *h,
error:
if (flux_respond_error (h, msg, errno, errmsg) < 0) {
llog_error (s,
"error responding to rexec.exec request: %s",
"error responding to %s.exec request: %s",
s->service_name,
strerror (errno));
}
flux_cmd_destroy (cmd);
Expand Down Expand Up @@ -425,12 +431,13 @@ static void server_write_cb (flux_t *h,
"io", &io) < 0
|| iodecode (io, &stream, NULL, &data, &len, &eof) < 0) {
llog_error (s,
"Error decoding rexec.write request: %s",
"Error decoding %s.write request: %s",
s->service_name,
strerror (errno));
goto out;
}
if (s->auth_cb && (*s->auth_cb) (msg, s->arg, &error) < 0) {
llog_error (s, "rexec.write: %s", error.text);
llog_error (s, "%s.write: %s", s->service_name, error.text);
goto out;
}

Expand Down Expand Up @@ -497,14 +504,16 @@ static void server_kill_cb (flux_t *h,
goto error;
if (flux_respond (h, msg, NULL) < 0) {
llog_error (s,
"error responding to rexec.kill request: %s",
"error responding to %s.kill request: %s",
s->service_name,
strerror (errno));
}
return;
error:
if (flux_respond_error (h, msg, errno, errmsg) < 0) {
llog_error (s,
"error responding to rexec.kill request: %s",
"error responding to %s.kill request: %s",
s->service_name,
strerror (errno));
}
}
Expand Down Expand Up @@ -566,7 +575,8 @@ static void server_list_cb (flux_t *h,
if (flux_respond_pack (h, msg, "{s:i s:o}", "rank", s->rank,
"procs", procs) < 0) {
llog_error (s,
"error responding to rexec.list request: %s",
"error responding to %s.list request: %s",
s->service_name,
strerror (errno));
}
return;
Expand All @@ -575,7 +585,8 @@ static void server_list_cb (flux_t *h,
error:
if (flux_respond_error (h, msg, errno, errmsg) < 0) {
llog_error (s,
"error responding to rexec.list request: %s",
"error responding to %s.list request: %s",
s->service_name,
strerror (errno));
}
json_decref (procs);
Expand Down Expand Up @@ -666,6 +677,7 @@ void subprocess_server_destroy (subprocess_server_t *s)
server_killall (s, SIGKILL);
zlistx_destroy (&s->subprocesses);
flux_future_destroy (s->shutdown);
free (s->service_name);
free (s->local_uri);
free (s);
errno = saved_errno;
Expand Down Expand Up @@ -695,6 +707,8 @@ subprocess_server_t *subprocess_server_create (flux_t *h,
if (!(s->subprocesses = zlistx_new ()))
goto error;
zlistx_set_destructor (s->subprocesses, proc_destructor);
if (!(s->service_name = strdup (service_name)))
goto error;
if (!(s->local_uri = strdup (local_uri)))
goto error;
if (flux_get_rank (h, &s->rank) < 0)
Expand Down
27 changes: 21 additions & 6 deletions src/common/libsubprocess/test/channel.c
Original file line number Diff line number Diff line change
Expand Up @@ -430,6 +430,12 @@ void test_bufsize_error (flux_reactor_t *r)
char *av[] = { "/bin/true", NULL };
flux_cmd_t *cmd;
flux_subprocess_t *p = NULL;
flux_subprocess_ops_t ops = {
.on_completion = completion_cb,
.on_channel_out = subprocess_standard_output,
.on_stdout = subprocess_standard_output,
.on_stderr = subprocess_standard_output
};

ok ((cmd = flux_cmd_create (1, av, NULL)) != NULL, "flux_cmd_create");

Expand All @@ -439,18 +445,27 @@ void test_bufsize_error (flux_reactor_t *r)
ok (flux_cmd_setopt (cmd, "TEST_CHANNEL_BUFSIZE", "ABCD") == 0,
"flux_cmd_setopt set TEST_CHANNEL_BUFSIZE success");

flux_subprocess_ops_t ops = {
.on_completion = completion_cb,
.on_channel_out = subprocess_standard_output,
.on_stdout = subprocess_standard_output,
.on_stderr = subprocess_standard_output
};
p = flux_local_exec (r, 0, cmd, &ops);
ok (p == NULL
&& errno == EINVAL,
"flux_local_exec fails with EINVAL due to bad bufsize input");

flux_cmd_destroy (cmd);

ok ((cmd = flux_cmd_create (1, av, NULL)) != NULL, "flux_cmd_create");

ok (flux_cmd_add_channel (cmd, "TEST_CHANNEL") == 0,
"flux_cmd_add_channel success adding channel TEST_CHANNEL");

ok (flux_cmd_setopt (cmd, "TEST_CHANNEL_BUFSIZE", "0") == 0,
"flux_cmd_setopt set TEST_CHANNEL_BUFSIZE success");

p = flux_local_exec (r, 0, cmd, &ops);
ok (p == NULL
&& errno == EINVAL,
"flux_local_exec fails with EINVAL due to bufsize zero");

flux_cmd_destroy (cmd);
}

int main (int argc, char *argv[])
Expand Down
2 changes: 1 addition & 1 deletion src/common/libsubprocess/test/stdio.c
Original file line number Diff line number Diff line change
Expand Up @@ -166,7 +166,7 @@ void output_no_readline_cb (flux_subprocess_t *p, const char *stream)

sprintf (cmpbuf, "%s:hi\n", stream);
ok (streq (outputbuf, cmpbuf),
"flux_subprocess_read_line returned correct data");
"flux_subprocess_read returned correct data");
/* 1 + 2 + 1 for ':', "hi", '\n' */
ok (outputbuf_len == (strlen (stream) + 1 + 2 + 1),
"flux_subprocess_read returned correct amount of data");
Expand Down
4 changes: 4 additions & 0 deletions src/common/libsubprocess/util.c
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,10 @@ int cmd_option_bufsize (flux_subprocess_t *p, const char *name)
uint64_t size;
if (parse_size (val, &size) < 0)
goto cleanup;
if (size == 0) {
errno = EINVAL;
goto cleanup;
}
if (size > INT_MAX) {
errno = EOVERFLOW;
goto cleanup;
Expand Down

0 comments on commit 50f8dc2

Please sign in to comment.