diff options
author | Simeon Bird <bladud@gmail.com> | 2013-02-14 00:56:02 (GMT) |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2013-02-28 01:27:30 (GMT) |
commit | f391ec72c2e4416bf8e5d7482ace49247cc2017c (patch) | |
tree | d491fc95285be5defb03e0e1c8ac3caec246314c /src/corelib/tools/qscopedvaluerollback.cpp | |
parent | 848a584dc0ab22cceb64d891b42525ff789ac0db (diff) | |
download | Qt-f391ec72c2e4416bf8e5d7482ace49247cc2017c.zip Qt-f391ec72c2e4416bf8e5d7482ace49247cc2017c.tar.gz Qt-f391ec72c2e4416bf8e5d7482ace49247cc2017c.tar.bz2 |
Fix QTBUG-18934 by checking return value of qt_safe_pipe
When QProcess->start() is called, Qt creates a pipe to the process to
get its exit value and output.
It does this with qt_create_pipe, which calls qt_safe_pipe.
qt_safe_pipe, on failure, returns 1. qt_create_pipe then
sets errno and returns void.
The calling function, QProcessPrivate::startProcess, does not check
errno, and thus continues to fork the process, assuming the pipe has been
created successfully.
The child process then has no way to pass its exit value to the calling
process, since the communication pipes it would normally use do not
exist, and thus when it exits it becomes a zombie.
As a bonus, if waitForFinished is called on a broken process, a crash
results because it is trying to wait on a pipe which does not exist.
The fix makes qt_create_pipe return an integer, and QProcess::startProcess
check the return value, set processError and not create the child
process.
Task-Number: QTBUG-18934
Cherry-picked from qtbase f575dc214630b3e3ebd66477a623c78405724468
Change-Id: I2e1effdd0617be5b8c5492bcbcf5f2b1584b2241
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
Diffstat (limited to 'src/corelib/tools/qscopedvaluerollback.cpp')
0 files changed, 0 insertions, 0 deletions