2013-11-01 14:33:00 -07:00
|
|
|
/******************************************************************************
|
|
|
|
Copyright (C) 2013 by Hugh Bailey <obs.jim@gmail.com>
|
2014-01-11 15:34:15 -08:00
|
|
|
Copyright (C) 2014 by Zachary Lund <admin@computerquip.com>
|
2013-11-01 14:33:00 -07:00
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
2013-12-27 18:43:28 -08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <unistd.h>
|
2014-07-12 07:19:49 -07:00
|
|
|
#include <sys/sysinfo.h>
|
|
|
|
#include <sys/utsname.h>
|
2013-11-01 14:33:00 -07:00
|
|
|
#include "util/dstr.h"
|
|
|
|
#include "obs.h"
|
|
|
|
|
2014-07-27 02:43:25 -07:00
|
|
|
const char *get_module_extension(void)
|
|
|
|
{
|
|
|
|
return ".so";
|
|
|
|
}
|
|
|
|
|
2014-01-24 11:52:22 -08:00
|
|
|
static inline bool check_path(const char* data, const char *path,
|
|
|
|
struct dstr * output)
|
2013-12-27 18:43:28 -08:00
|
|
|
{
|
|
|
|
dstr_copy(output, path);
|
|
|
|
dstr_cat(output, data);
|
2014-07-12 07:18:58 -07:00
|
|
|
|
2014-01-24 18:44:34 -08:00
|
|
|
blog(LOG_INFO, "Attempting path: %s\n", output->array);
|
2014-07-12 07:18:58 -07:00
|
|
|
|
2013-12-27 18:43:28 -08:00
|
|
|
return access(output->array, R_OK) == 0;
|
|
|
|
}
|
|
|
|
|
2014-01-24 11:52:22 -08:00
|
|
|
static inline bool check_lib_path(const char* data, const char *path,
|
|
|
|
struct dstr *output)
|
2013-12-27 18:43:28 -08:00
|
|
|
{
|
|
|
|
bool result = false;
|
|
|
|
struct dstr tmp;
|
2014-07-12 07:18:58 -07:00
|
|
|
|
2014-07-19 01:25:55 -07:00
|
|
|
dstr_init(&tmp);
|
2014-01-24 18:44:34 -08:00
|
|
|
dstr_cat(&tmp, data);
|
2013-12-27 18:43:28 -08:00
|
|
|
dstr_cat(&tmp, ".so");
|
2014-07-12 07:18:58 -07:00
|
|
|
result = check_path(tmp.array, path, output);
|
|
|
|
|
2013-12-27 18:43:28 -08:00
|
|
|
dstr_free(&tmp);
|
2014-07-12 07:18:58 -07:00
|
|
|
|
2013-12-27 18:43:28 -08:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2013-11-01 14:33:00 -07:00
|
|
|
/*
|
|
|
|
* /usr/local/lib/obs-plugins
|
|
|
|
* /usr/lib/obs-plugins
|
|
|
|
*/
|
|
|
|
char *find_plugin(const char *plugin)
|
2014-07-12 07:18:58 -07:00
|
|
|
{
|
2013-12-27 18:43:28 -08:00
|
|
|
struct dstr output;
|
|
|
|
dstr_init(&output);
|
|
|
|
|
2014-02-23 21:39:33 -08:00
|
|
|
if(sizeof(void*) == 4) {
|
2014-01-24 18:44:34 -08:00
|
|
|
if (check_lib_path(plugin, "../../obs-plugins/32bit/", &output))
|
|
|
|
return output.array;
|
2014-07-19 01:25:55 -07:00
|
|
|
|
|
|
|
if (check_lib_path(plugin, "../../obs-plugins/32bit/lib", &output))
|
|
|
|
return output.array;
|
2014-02-23 21:39:33 -08:00
|
|
|
} else {
|
2014-01-25 13:11:57 -08:00
|
|
|
if (check_lib_path(plugin, "../../obs-plugins/64bit/", &output))
|
|
|
|
return output.array;
|
2014-07-19 01:25:55 -07:00
|
|
|
|
|
|
|
if (check_lib_path(plugin, "../../obs-plugins/64bit/lib", &output))
|
|
|
|
return output.array;
|
2014-01-25 13:11:57 -08:00
|
|
|
}
|
2013-12-27 18:43:28 -08:00
|
|
|
|
2014-02-23 21:39:33 -08:00
|
|
|
if (OBS_INSTALL_PREFIX [0] != 0) {
|
2014-01-25 11:34:37 -08:00
|
|
|
if (check_lib_path(plugin,
|
|
|
|
OBS_INSTALL_PREFIX "lib/obs-plugins/",
|
2014-01-24 18:44:34 -08:00
|
|
|
&output))
|
|
|
|
return output.array;
|
2014-07-19 01:25:55 -07:00
|
|
|
|
|
|
|
if (check_lib_path(plugin,
|
|
|
|
OBS_INSTALL_PREFIX "lib/obs-plugins/lib",
|
|
|
|
&output))
|
|
|
|
return output.array;
|
2014-01-24 18:44:34 -08:00
|
|
|
}
|
2013-12-27 18:43:28 -08:00
|
|
|
|
|
|
|
dstr_free(&output);
|
2013-11-01 14:33:00 -07:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* /usr/local/share/libobs
|
|
|
|
* /usr/share/libobs
|
|
|
|
*/
|
|
|
|
char *find_libobs_data_file(const char *file)
|
|
|
|
{
|
2013-12-27 18:43:28 -08:00
|
|
|
struct dstr output;
|
|
|
|
dstr_init(&output);
|
|
|
|
|
2014-01-20 07:58:58 -08:00
|
|
|
if (check_path(file, OBS_DATA_PATH "/libobs/", &output))
|
2013-12-27 18:43:28 -08:00
|
|
|
return output.array;
|
|
|
|
|
2014-02-23 21:39:33 -08:00
|
|
|
if (OBS_INSTALL_PREFIX [0] != 0) {
|
2014-01-25 11:34:37 -08:00
|
|
|
if (check_path(file, OBS_INSTALL_DATA_PATH "/libobs/",
|
2014-01-24 18:44:34 -08:00
|
|
|
&output))
|
|
|
|
return output.array;
|
|
|
|
}
|
2013-12-27 18:43:28 -08:00
|
|
|
|
|
|
|
dstr_free(&output);
|
2013-11-01 14:33:00 -07:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* /usr/local/share/obs-plugins
|
|
|
|
* /usr/share/obs-plugins
|
|
|
|
*/
|
|
|
|
char *obs_find_plugin_file(const char *file)
|
2014-07-12 07:18:58 -07:00
|
|
|
{
|
2014-01-24 18:44:34 -08:00
|
|
|
struct dstr output;
|
|
|
|
dstr_init(&output);
|
2013-12-27 18:43:28 -08:00
|
|
|
|
2014-01-24 18:44:34 -08:00
|
|
|
if (check_path(file, OBS_DATA_PATH "/obs-plugins/", &output))
|
|
|
|
return output.array;
|
2013-12-27 18:43:28 -08:00
|
|
|
|
2014-02-23 21:39:33 -08:00
|
|
|
if (OBS_INSTALL_PREFIX [0] != 0) {
|
2014-01-25 11:34:37 -08:00
|
|
|
if (check_path(file, OBS_INSTALL_DATA_PATH "/obs-plugins/",
|
|
|
|
&output))
|
2014-01-24 18:44:34 -08:00
|
|
|
return output.array;
|
|
|
|
}
|
2013-12-27 18:43:28 -08:00
|
|
|
|
2014-01-24 18:44:34 -08:00
|
|
|
dstr_free(&output);
|
|
|
|
return NULL;
|
2013-11-01 14:33:00 -07:00
|
|
|
}
|
2014-07-12 00:21:06 -07:00
|
|
|
|
2014-07-12 07:19:49 -07:00
|
|
|
static void log_processor_info(void)
|
|
|
|
{
|
|
|
|
FILE *fp;
|
|
|
|
int physical_id = -1;
|
|
|
|
int last_physical_id = -1;
|
|
|
|
char *line = NULL;
|
|
|
|
size_t linecap = 0;
|
|
|
|
struct dstr processor;
|
|
|
|
|
|
|
|
blog(LOG_INFO, "Processor: %lu logical cores",
|
|
|
|
sysconf(_SC_NPROCESSORS_ONLN));
|
|
|
|
|
|
|
|
fp = fopen("/proc/cpuinfo", "r");
|
|
|
|
if (!fp)
|
|
|
|
return;
|
|
|
|
|
|
|
|
dstr_init(&processor);
|
|
|
|
|
|
|
|
while (getline(&line, &linecap, fp) != -1) {
|
|
|
|
if (!strncmp(line, "model name", 10)) {
|
|
|
|
char *start = strchr(line, ':');
|
|
|
|
if (!start || *(++start) == '\0')
|
|
|
|
continue;
|
|
|
|
dstr_copy(&processor, start);
|
|
|
|
dstr_resize(&processor, processor.len - 1);
|
|
|
|
dstr_depad(&processor);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!strncmp(line, "physical id", 11)) {
|
|
|
|
char *start = strchr(line, ':');
|
|
|
|
if (!start || *(++start) == '\0')
|
|
|
|
continue;
|
|
|
|
physical_id = atoi(start);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (*line == '\n' && physical_id != last_physical_id) {
|
|
|
|
last_physical_id = physical_id;
|
|
|
|
blog(LOG_INFO, "Processor: %s", processor.array);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fclose(fp);
|
|
|
|
dstr_free(&processor);
|
|
|
|
free(line);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void log_memory_info(void)
|
|
|
|
{
|
|
|
|
struct sysinfo info;
|
|
|
|
if (sysinfo(&info) < 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
blog(LOG_INFO, "Physical Memory: %luMB Total",
|
|
|
|
info.totalram / 1024 / 1024);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void log_kernel_version(void)
|
|
|
|
{
|
|
|
|
struct utsname info;
|
|
|
|
if (uname(&info) < 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
blog(LOG_INFO, "Kernel Version: %s %s", info.sysname, info.release);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void log_distribution_info(void)
|
|
|
|
{
|
|
|
|
FILE *fp;
|
|
|
|
char *line = NULL;
|
|
|
|
size_t linecap = 0;
|
|
|
|
struct dstr distro;
|
|
|
|
struct dstr version;
|
|
|
|
|
|
|
|
fp = fopen("/etc/os-release", "r");
|
|
|
|
if (!fp) {
|
|
|
|
blog(LOG_INFO, "Distribution: Missing /etc/os-release !");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dstr_init_copy(&distro, "Unknown");
|
|
|
|
dstr_init_copy(&version, "Unknown");
|
|
|
|
|
|
|
|
while (getline(&line, &linecap, fp) != -1) {
|
|
|
|
if (!strncmp(line, "NAME", 4)) {
|
|
|
|
char *start = strchr(line, '=');
|
|
|
|
if (!start || *(++start) == '\0')
|
|
|
|
continue;
|
|
|
|
dstr_copy(&distro, start);
|
|
|
|
dstr_resize(&distro, distro.len - 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!strncmp(line, "VERSION_ID", 10)) {
|
|
|
|
char *start = strchr(line, '=');
|
|
|
|
if (!start || *(++start) == '\0')
|
|
|
|
continue;
|
|
|
|
dstr_copy(&version, start);
|
|
|
|
dstr_resize(&version, version.len - 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
blog(LOG_INFO, "Distribution: %s %s", distro.array, version.array);
|
|
|
|
|
|
|
|
fclose(fp);
|
|
|
|
dstr_free(&version);
|
|
|
|
dstr_free(&distro);
|
|
|
|
free(line);
|
|
|
|
}
|
|
|
|
|
2014-07-12 00:21:06 -07:00
|
|
|
void log_system_info(void)
|
|
|
|
{
|
2014-07-12 07:19:49 -07:00
|
|
|
log_processor_info();
|
|
|
|
log_memory_info();
|
|
|
|
log_kernel_version();
|
|
|
|
log_distribution_info();
|
2014-07-12 00:21:06 -07:00
|
|
|
}
|