2023-04-09 13:03:20 +00:00
|
|
|
/* Copyright 2013-2023 MultiMC Contributors
|
2016-06-16 00:20:23 +00: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-23 00:47:06 +00:00
|
|
|
#include <fstream>
|
|
|
|
#include <string>
|
|
|
|
|
2016-06-16 00:20:23 +00:00
|
|
|
#include "PrintInstanceInfo.h"
|
|
|
|
#include <launch/LaunchTask.h>
|
|
|
|
|
2021-12-12 00:35:46 +00:00
|
|
|
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
|
2018-10-31 21:44:23 +00:00
|
|
|
namespace {
|
2021-12-12 00:35:46 +00:00
|
|
|
#if defined(Q_OS_LINUX)
|
2018-10-31 21:44:23 +00:00
|
|
|
void probeProcCpuinfo(QStringList &log)
|
|
|
|
{
|
2017-08-23 00:47:06 +00: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 21:44:23 +00:00
|
|
|
log << QString::fromStdString(line.substr(13, std::string::npos));
|
2017-08-23 00:47:06 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2018-10-31 21:44:23 +00:00
|
|
|
}
|
2017-08-23 00:47:06 +00:00
|
|
|
|
2018-10-31 21:44:23 +00:00
|
|
|
void runLspci(QStringList &log)
|
|
|
|
{
|
|
|
|
// FIXME: fixed size buffers...
|
2017-08-23 00:47:06 +00:00
|
|
|
char buff[512];
|
2017-08-23 01:02:03 +00:00
|
|
|
int gpuline = -1;
|
|
|
|
int cline = 0;
|
2018-10-31 21:44:23 +00:00
|
|
|
FILE * lspci = popen("lspci -k", "r");
|
|
|
|
|
|
|
|
if (!lspci)
|
|
|
|
return;
|
|
|
|
|
|
|
|
while (fgets(buff, 512, lspci) != NULL)
|
2017-08-23 00:47:06 +00:00
|
|
|
{
|
2018-10-31 21:44:23 +00:00
|
|
|
std::string str(buff);
|
|
|
|
if (str.length() < 9)
|
|
|
|
continue;
|
|
|
|
if (str.substr(8, 3) == "VGA")
|
2017-08-23 00:47:06 +00:00
|
|
|
{
|
2018-10-31 21:44:23 +00:00
|
|
|
gpuline = cline;
|
|
|
|
log << QString::fromStdString(str.substr(35, std::string::npos));
|
|
|
|
}
|
|
|
|
if (gpuline > -1 && gpuline != cline)
|
|
|
|
{
|
|
|
|
if (cline - gpuline < 3)
|
2017-08-23 01:35:10 +00:00
|
|
|
{
|
2018-10-31 21:44:23 +00:00
|
|
|
log << QString::fromStdString(str.substr(1, std::string::npos));
|
2017-08-23 01:35:10 +00:00
|
|
|
}
|
2017-08-23 01:02:03 +00:00
|
|
|
}
|
2018-10-31 21:44:23 +00:00
|
|
|
cline++;
|
2017-08-23 00:47:06 +00:00
|
|
|
}
|
2018-10-31 21:44:23 +00:00
|
|
|
pclose(lspci);
|
|
|
|
}
|
2021-12-12 00:35:46 +00:00
|
|
|
#elif defined(Q_OS_FREEBSD)
|
|
|
|
void runSysctlHwModel(QStringList &log)
|
|
|
|
{
|
|
|
|
char buff[512];
|
|
|
|
FILE *hwmodel = popen("sysctl hw.model", "r");
|
|
|
|
while (fgets(buff, 512, hwmodel) != NULL)
|
|
|
|
{
|
|
|
|
log << QString::fromUtf8(buff);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
pclose(hwmodel);
|
|
|
|
}
|
2018-10-31 21:44:23 +00:00
|
|
|
|
2021-12-12 00:35:46 +00:00
|
|
|
void runPciconf(QStringList &log)
|
|
|
|
{
|
|
|
|
char buff[512];
|
|
|
|
std::string strcard;
|
|
|
|
FILE *pciconf = popen("pciconf -lv -a vgapci0", "r");
|
|
|
|
while (fgets(buff, 512, pciconf) != NULL)
|
|
|
|
{
|
|
|
|
if (strncmp(buff, " vendor", 10) == 0)
|
|
|
|
{
|
|
|
|
std::string str(buff);
|
|
|
|
strcard.append(str.substr(str.find_first_of("'") + 1, str.find_last_not_of("'") - (str.find_first_of("'") + 2)));
|
|
|
|
strcard.append(" ");
|
|
|
|
}
|
|
|
|
else if (strncmp(buff, " device", 10) == 0)
|
|
|
|
{
|
|
|
|
std::string str2(buff);
|
|
|
|
strcard.append(str2.substr(str2.find_first_of("'") + 1, str2.find_last_not_of("'") - (str2.find_first_of("'") + 2)));
|
|
|
|
}
|
|
|
|
log << QString::fromStdString(strcard);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
pclose(pciconf);
|
|
|
|
}
|
|
|
|
#endif
|
2018-10-31 21:44:23 +00:00
|
|
|
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-23 01:02:03 +00:00
|
|
|
{
|
2018-10-31 21:44:23 +00:00
|
|
|
if (strncmp(buff, "OpenGL version string:", 22) == 0)
|
2017-08-23 01:02:03 +00:00
|
|
|
{
|
2018-10-31 21:44:23 +00:00
|
|
|
log << QString::fromUtf8(buff);
|
|
|
|
break;
|
2017-08-23 01:02:03 +00:00
|
|
|
}
|
|
|
|
}
|
2018-10-31 21:44:23 +00:00
|
|
|
pclose(glxinfo);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void PrintInstanceInfo::executeTask()
|
|
|
|
{
|
|
|
|
auto instance = m_parent->instance();
|
|
|
|
QStringList log;
|
|
|
|
|
2021-12-12 00:35:46 +00:00
|
|
|
#if defined(Q_OS_LINUX)
|
2018-10-31 21:44:23 +00:00
|
|
|
::probeProcCpuinfo(log);
|
|
|
|
::runLspci(log);
|
|
|
|
::runGlxinfo(log);
|
2021-12-12 00:35:46 +00:00
|
|
|
#elif defined(Q_OS_FREEBSD)
|
|
|
|
::runSysctlHwModel(log);
|
|
|
|
::runPciconf(log);
|
|
|
|
::runGlxinfo(log);
|
2017-08-23 00:47:06 +00:00
|
|
|
#endif
|
|
|
|
|
2021-10-17 22:47:02 +00:00
|
|
|
logLines(log, MessageLevel::Launcher);
|
2023-04-08 17:03:20 +00:00
|
|
|
logLines(instance->verboseDescription(m_session, m_quickPlayTarget), MessageLevel::Launcher);
|
2017-08-23 00:47:06 +00:00
|
|
|
emitSucceeded();
|
2016-06-16 00:20:23 +00:00
|
|
|
}
|