Cleanup, rename

This commit is contained in:
2022-09-11 19:30:13 +02:00
parent 1985e72c16
commit 7111a20203
10 changed files with 57 additions and 58 deletions

View File

@@ -5,12 +5,17 @@
using namespace std;
HwmonTemperatureSensor::HwmonTemperatureSensor(
const sensors_chip_name *chipName, const sensors_subfeature *subfeature)
: mChipName(chipName), mSubFeature(subfeature) {}
const sensors_chip_name *chipName, const sensors_feature *feature,
const sensors_subfeature *subfeature)
: mChipName(chipName), mFeature(feature), mSubFeature(subfeature) {}
int HwmonTemperatureSensor::getTemperature() {
int HwmonTemperatureSensor::temperature() {
double *value;
sensors_get_value(mChipName, mSubFeature->number, value);
return static_cast<int>(*value);
}
string HwmonTemperatureSensor::name() {
return sensors_get_label(mChipName, mFeature);
}

View File

@@ -1,17 +0,0 @@
#include <include/nvml.h>
#include <Nvidia.h>
Nvidia::Nvidia() { nvmlInit_v2(); }
Nvidia::~Nvidia() { nvmlShutdown(); }
double Nvidia::get_gpu_temperature() {
nvmlDevice_t device;
nvmlDeviceGetHandleByIndex_v2(0, &device);
unsigned int temp;
nvmlDeviceGetTemperature(device, NVML_TEMPERATURE_GPU, &temp);
return static_cast<double>(temp);
}

View File

@@ -0,0 +1,21 @@
#include <include/nvml.h>
#include <NvidiaTemperatureSensor.h>
using namespace std;
NvidiaTemperatureSensor::NvidiaTemperatureSensor() { nvmlInit_v2(); }
NvidiaTemperatureSensor::~NvidiaTemperatureSensor() { nvmlShutdown(); }
int NvidiaTemperatureSensor::temperature() {
nvmlDevice_t device;
nvmlDeviceGetHandleByIndex_v2(0, &device);
unsigned int temp;
nvmlDeviceGetTemperature(device, NVML_TEMPERATURE_GPU, &temp);
return static_cast<int>(temp);
}
string NvidiaTemperatureSensor::name() { return "GPU"; }

View File

@@ -6,7 +6,7 @@
#include <sensors/sensors.h>
#include <HwmonTemperatureSensor.h>
#include <Nvidia.h>
#include <NvidiaTemperatureSensor.h>
#include <Pwm.h>
#define CONFIG_FILE "/etc/conf.d/sensors"
@@ -29,19 +29,17 @@ std::vector<std::shared_ptr<TemperatureSensor>> sensors() {
auto tempFeature = sensors_get_subfeature(chipName, feature,
SENSORS_SUBFEATURE_TEMP_INPUT);
if (tempFeature)
sensors.push_back(
std::make_shared<HwmonTemperatureSensor>(chipName, tempFeature));
sensors.push_back(std::make_shared<HwmonTemperatureSensor>(
chipName, feature, tempFeature));
}
}
sensors.push_back(std::make_shared<NvidiaTemperatureSensor>());
return sensors;
}
int main() {
Nvidia nv;
auto temp = nv.get_gpu_temperature();
std::cout << "\nGPU Temp: " << temp << std::endl;
class PWM pwm;
std::cout << '\n';
pwm.dumpValues();
@@ -53,7 +51,7 @@ int main() {
auto tempSensors = sensors();
for (auto s : tempSensors) {
std::cout << s->getTemperature() << std::endl;
std::cout << s->name() << ": " << s->temperature() << std::endl;
}
return 0;