Я пытаюсь использовать devcon.exe для проверки состояния различных аппаратных средств. В этом примере я пытаюсь проверить свой статус SATA HBA, но devcon ноет по этому поводу. Вот код:
int main(int argc, char** argv) {
std::string cmdLine("\"C:\\Users\\afalanga\\Documents\\Visual Studio 2010\\Projects\\PlayGround\\Debug\\devcon.exe\" status PCI\\VEN_8086^&DEV_3A22^&SUBSYS_75201462^&REV_00");
char* pCmdLine(new char[cmdLine.length() + 10]);
memset(pCmdLine, 0, cmdLine.length() + 10);
for(int i(0); i < cmdLine.length(); i++)
pCmdLine[i] = cmdLine.at(i);
STARTUPINFO si = { sizeof(STARTUPINFO) };
PROCESS_INFORMATION pi = {0};
if(!CreateProcess(NULL, pCmdLine, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
std::cout << "Create child process failed. Error code: "
<< GetLastError() << std::endl;
return 1;
}
WaitForSingleObject(pi.hProcess, INFINITE);
CloseHandle(pi.hThread);
CloseHandle(pi.hProcess);
return 0;
}
Проблема в том, что когда вышеприведенное выполняется, devcon жалуется, что «подходящие устройства не найдены». Однако, если я скопирую/вставлю эту командную строку из отладчика в свою командную строку и нажму клавишу ввода (или, конечно, удалю все кавычки, которые окружает ее отладчик), команда будет выполняться идеально, как и ожидалось.
Что я ошибаюсь в передаче строки? То, что выше, является результатом чтения документов CreateProcess() в MSDN (выяснилось, что первый аргумент не обязательно нужен, и аргументы cmd вообще не должны туда идти). Причина, по которой я выделяю 10 дополнительных байтов памяти для копирования строки, заключается в том, что «все», что может измениться внутри функции CreateProcess(), может сделать это, не топая другую память. По крайней мере, так я думал, когда делал это.
memset
вместо простого()
? - person ildjarn   schedule 13.03.2012