2019-01-16 21:14:24 +01:00
|
|
|
/* Copyright 2013-2019 MultiMC Contributors
|
2016-06-16 02:20:23 +02:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2017-08-22 17:47:06 -07:00
|
|
|
#include <fstream>
|
|
|
|
#include <string>
|
|
|
|
|
2016-06-16 02:20:23 +02:00
|
|
|
#include "PrintInstanceInfo.h"
|
|
|
|
#include <launch/LaunchTask.h>
|
|
|
|
|
2017-08-22 17:47:06 -07:00
|
|
|
#ifdef Q_OS_LINUX
|
2018-10-31 22:44:23 +01:00
|
|
|
namespace {
|
|
|
|
void probeProcCpuinfo(QStringList &log)
|
|
|
|
{
|
2017-08-22 17:47:06 -07:00
|
|
|
std::ifstream cpuin("/proc/cpuinfo");
|
|
|
|
for (std::string line; std::getline(cpuin, line);)
|
|
|
|
{
|
|
|
|
if (strncmp(line.c_str(), "model name", 10) == 0)
|
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
log << QString::fromStdString(line.substr(13, std::string::npos));
|
2017-08-22 17:47:06 -07:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2018-10-31 22:44:23 +01:00
|
|
|
}
|
2017-08-22 17:47:06 -07:00
|
|
|
|
2018-10-31 22:44:23 +01:00
|
|
|
void runLspci(QStringList &log)
|
|
|
|
{
|
|
|
|
// FIXME: fixed size buffers...
|
2017-08-22 17:47:06 -07:00
|
|
|
char buff[512];
|
2017-08-22 18:02:03 -07:00
|
|
|
int gpuline = -1;
|
|
|
|
int cline = 0;
|
2018-10-31 22:44:23 +01:00
|
|
|
FILE * lspci = popen("lspci -k", "r");
|
|
|
|
|
|
|
|
if (!lspci)
|
|
|
|
return;
|
|
|
|
|
|
|
|
while (fgets(buff, 512, lspci) != NULL)
|
2017-08-22 17:47:06 -07:00
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
std::string str(buff);
|
|
|
|
if (str.length() < 9)
|
|
|
|
continue;
|
|
|
|
if (str.substr(8, 3) == "VGA")
|
2017-08-22 17:47:06 -07:00
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
gpuline = cline;
|
|
|
|
log << QString::fromStdString(str.substr(35, std::string::npos));
|
|
|
|
}
|
|
|
|
if (gpuline > -1 && gpuline != cline)
|
|
|
|
{
|
|
|
|
if (cline - gpuline < 3)
|
2017-08-22 18:35:10 -07:00
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
log << QString::fromStdString(str.substr(1, std::string::npos));
|
2017-08-22 18:35:10 -07:00
|
|
|
}
|
2017-08-22 18:02:03 -07:00
|
|
|
}
|
2018-10-31 22:44:23 +01:00
|
|
|
cline++;
|
2017-08-22 17:47:06 -07:00
|
|
|
}
|
2018-10-31 22:44:23 +01:00
|
|
|
pclose(lspci);
|
|
|
|
}
|
|
|
|
|
|
|
|
void runGlxinfo(QStringList & log)
|
|
|
|
{
|
|
|
|
// FIXME: fixed size buffers...
|
|
|
|
char buff[512];
|
|
|
|
FILE *glxinfo = popen("glxinfo", "r");
|
|
|
|
if (!glxinfo)
|
|
|
|
return;
|
|
|
|
|
|
|
|
while (fgets(buff, 512, glxinfo) != NULL)
|
2017-08-22 18:02:03 -07:00
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
if (strncmp(buff, "OpenGL version string:", 22) == 0)
|
2017-08-22 18:02:03 -07:00
|
|
|
{
|
2018-10-31 22:44:23 +01:00
|
|
|
log << QString::fromUtf8(buff);
|
|
|
|
break;
|
2017-08-22 18:02:03 -07:00
|
|
|
}
|
|
|
|
}
|
2018-10-31 22:44:23 +01:00
|
|
|
pclose(glxinfo);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void PrintInstanceInfo::executeTask()
|
|
|
|
{
|
|
|
|
auto instance = m_parent->instance();
|
|
|
|
QStringList log;
|
|
|
|
|
|
|
|
#ifdef Q_OS_LINUX
|
|
|
|
::probeProcCpuinfo(log);
|
|
|
|
::runLspci(log);
|
|
|
|
::runGlxinfo(log);
|
2017-08-22 17:47:06 -07:00
|
|
|
#endif
|
|
|
|
|
2018-10-31 22:44:23 +01:00
|
|
|
logLines(log, MessageLevel::MultiMC);
|
|
|
|
logLines(instance->verboseDescription(m_session), MessageLevel::MultiMC);
|
2017-08-22 17:47:06 -07:00
|
|
|
emitSucceeded();
|
2016-06-16 02:20:23 +02:00
|
|
|
}
|