Re: [Updated PATCH 2/2] Improve transport helper exec failure reporting

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Ilari Liusvaara schrieb:
On Thu, Dec 31, 2009 at 06:48:02PM +0100, Johannes Sixt wrote:
In case 3, it is expected that the child process prints a suitable
error message. Therefore, you should start with merely replacing the
unconditional

	exit(127);
by
	if (errno == ENOENT)
		exit(127);
	else
		die_errno("Cannot exec %s", cmd->argv[0]);

And then you can think about how you support the ENOENT case better.
My proposal for this was to do the PATH lookup manually before the
fork(), and then the above conditional would melt down to simply:

	die_errno("Cannot exec %s", cmd->argv[0]);


The child process can't sanely print anything. Stderr would go to
who knows where.

Wrong - because:

Parent process should have much better idea what to
do with errors.

Very correct. For this reason, the parent process assigns a stderr channel to the child (or does not do so to inherit its own stderr), and the child is expected to use it. Errors due to execvp failures are no exception, IMO (except ENOENT, as always).

-- Hannes
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]