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

@@ -9,7 +9,7 @@ find_package(Boost 1.79.0 COMPONENTS json)
add_executable(app
src/main.cxx
src/Nvidia.cxx
src/NvidiaTemperatureSensor.cxx
src/Pwm.cxx
src/SensorsWrapper.cxx
src/HwmonTemperatureSensor.cxx

View File

@@ -1,16 +0,0 @@
#ifndef CORRELATEPWMRPM_H_
#define CORRELATEPWMRPM_H_
/*
** What I need:
** - All system RPM sensors
** - All system PWM controls
**
** ToDo: Find which PWM controller affects which RPM sensor
**
*/
class CorrelatePwmRpm {
public:
};
#endif // CORRELATEPWMRPM_H_

View File

@@ -8,12 +8,15 @@
class HwmonTemperatureSensor : public TemperatureSensor {
public:
HwmonTemperatureSensor(const sensors_chip_name *chipName,
const sensors_feature *feature,
const sensors_subfeature *subfeature);
int getTemperature() override;
int temperature() override;
std::string name() override;
private:
const sensors_chip_name *mChipName;
const sensors_feature *mFeature;
const sensors_subfeature *mSubFeature;
};

View File

@@ -1,11 +0,0 @@
#ifndef NVIDIA_H_
#define NVIDIA_H_
class Nvidia {
public:
Nvidia();
~Nvidia();
double get_gpu_temperature();
};
#endif // NVIDIA_H_

View File

@@ -0,0 +1,15 @@
#ifndef NVIDIA_H_
#define NVIDIA_H_
#include <TemperatureSensor.h>
class NvidiaTemperatureSensor : public TemperatureSensor {
public:
NvidiaTemperatureSensor();
~NvidiaTemperatureSensor();
int temperature() override;
std::string name() override;
};
#endif // NVIDIA_H_

View File

@@ -5,7 +5,8 @@
class TemperatureSensor {
public:
virtual int getTemperature() = 0;
virtual int temperature() = 0;
virtual std::string name() = 0;
};
#endif // TEMPERATURESENSOR_H_

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;