The pipe will soon be needed earlier, so initialise it earlier.
Ensure the file descriptors are closed on error.
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13592
Signed-off-by: Martin Schwenke <martin@meltin.net>
Reviewed-by: Amitay Isaacs <amitay@gmail.com>
(cherry picked from commit
c446ae5e1382d5e32c33ce92243daf6b4338e15a)
return -1;
}
+ ret = pipe(fd);
+ if (ret != 0) {
+ return -1;
+ }
+
argv = talloc_array(ectx, const char *, 14);
if (argv == NULL) {
+ close(fd[0]);
+ close(fd[1]);
return -1;
}
argv[13] = NULL;
if (argv[6] == NULL) {
+ close(fd[0]);
+ close(fd[1]);
talloc_free(argv);
return -1;
}
argv[0], argv[1], argv[2], argv[3], argv[4], argv[5],
argv[6], argv[7], argv[8], argv[9], argv[10]));
- ret = pipe(fd);
- if (ret != 0) {
- return -1;
- }
-
pid = ctdb_fork(ctdb);
if (pid == -1) {
close(fd[0]);