Commit 550823b5 authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

AssignProcessToJobObject cannot assign current process

on Win7 with the most strict user account control setting 
(secure desktop)

Fix: use job object for child process only, not for current
process itself.
parent 1cb5bc32
...@@ -263,8 +263,7 @@ BOOL CUpgradeDlg::OnInitDialog() ...@@ -263,8 +263,7 @@ BOOL CUpgradeDlg::OnInitDialog()
jeli.BasicLimitInformation.LimitFlags = JOB_OBJECT_LIMIT_KILL_ON_JOB_CLOSE; jeli.BasicLimitInformation.LimitFlags = JOB_OBJECT_LIMIT_KILL_ON_JOB_CLOSE;
SetInformationJobObject(m_JobObject, JobObjectExtendedLimitInformation, SetInformationJobObject(m_JobObject, JobObjectExtendedLimitInformation,
&jeli, sizeof(jeli)); &jeli, sizeof(jeli));
if(!AssignProcessToJobObject(m_JobObject, GetCurrentProcess()))
ErrorExit("AssignProcessToJobObject failed");
m_Progress.ShowWindow(SW_HIDE); m_Progress.ShowWindow(SW_HIDE);
m_Ok.EnableWindow(FALSE); m_Ok.EnableWindow(FALSE);
...@@ -375,20 +374,47 @@ void CUpgradeDlg::UpgradeOneService(const string& servicename) ...@@ -375,20 +374,47 @@ void CUpgradeDlg::UpgradeOneService(const string& servicename)
si.hStdError= hPipeWrite; si.hStdError= hPipeWrite;
si.wShowWindow= SW_HIDE; si.wShowWindow= SW_HIDE;
si.dwFlags= STARTF_USESTDHANDLES |STARTF_USESHOWWINDOW; si.dwFlags= STARTF_USESTDHANDLES |STARTF_USESHOWWINDOW;
if (!CreateProcess(NULL, (LPSTR)commandline.c_str(), NULL, NULL, TRUE,
0, NULL, NULL, &si, &pi))
/*
We will try to assign child process to a job, to be able to
terminate the process and all of its children. It might fail,
in case current process is already part of the job which does
not allows breakaways.
*/
if (CreateProcess(NULL, (LPSTR)commandline.c_str(), NULL, NULL, TRUE,
CREATE_BREAKAWAY_FROM_JOB|CREATE_SUSPENDED, NULL, NULL, &si, &pi))
{ {
string errmsg("Create Process "); if(!AssignProcessToJobObject(m_JobObject, pi.hProcess))
errmsg+= commandline; {
errmsg+= " failed"; char errmsg[128];
ErrorExit(errmsg.c_str()); sprintf(errmsg, "AssignProcessToJobObject failed, error %d",
GetLastError());
ErrorExit(errmsg);
}
ResumeThread(pi.hThread);
} }
else
{
/*
Creating a process with CREATE_BREAKAWAY_FROM_JOB, reset this flag
and retry.
*/
if (!CreateProcess(NULL, (LPSTR)commandline.c_str(), NULL, NULL, TRUE,
0, NULL, NULL, &si, &pi))
{
string errmsg("Create Process ");
errmsg+= commandline;
errmsg+= " failed";
ErrorExit(errmsg.c_str());
}
}
hChildThread = pi.hThread; hChildThread = pi.hThread;
DWORD nbytes; DWORD nbytes;
bool newline= false;
int lines=0; int lines=0;
CloseHandle(hPipeWrite); CloseHandle(hPipeWrite);
string output_line; string output_line;
while(ReadFile(hPipeRead, pipeReadBuf, 1, &nbytes, NULL)) while(ReadFile(hPipeRead, pipeReadBuf, 1, &nbytes, NULL))
{ {
...@@ -402,7 +428,7 @@ void CUpgradeDlg::UpgradeOneService(const string& servicename) ...@@ -402,7 +428,7 @@ void CUpgradeDlg::UpgradeOneService(const string& servicename)
/* /*
Updating progress dialog.There are currently 9 messages from Updating progress dialog.There are currently 9 messages from
mysql_upgrade_service (actually it also writes Phase N/M but mysql_upgrade_service (actually it also writes Phase N/M but
we do not parse we do not parse the output right now).
*/ */
#define EXPRECTED_MYSQL_UPGRADE_MESSAGES 9 #define EXPRECTED_MYSQL_UPGRADE_MESSAGES 9
...@@ -576,8 +602,8 @@ void CUpgradeDlg::OnBnClickedCancel() ...@@ -576,8 +602,8 @@ void CUpgradeDlg::OnBnClickedCancel()
return; return;
} }
} }
if(!TerminateJobObject(m_JobObject, 1)) TerminateJobObject(m_JobObject, 1);
exit(1); exit(1);
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment