blob: 2f5ee760808cab1ea0d30b40422461f0457724be [file] [log] [blame]
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +05301/*
2 * SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION &
3 * AFFILIATES. All rights reserved.
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#pragma once
8
Rohit PAI0a888262025-06-11 08:52:29 +05309#include "Inventory.hpp"
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053010#include "MctpRequester.hpp"
11#include "NvidiaDeviceDiscovery.hpp"
Harshit Aghera902c6492025-05-08 15:57:42 +053012#include "NvidiaGpuPowerSensor.hpp"
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053013#include "NvidiaGpuSensor.hpp"
14
Harshit Aghera775199d2025-05-27 14:20:24 +053015#include <NvidiaGpuEnergySensor.hpp>
Harshit Aghera6b712322025-07-31 19:25:12 +053016#include <NvidiaGpuPowerPeakReading.hpp>
Harshit Agherabef4d412025-05-27 14:53:56 +053017#include <NvidiaGpuVoltageSensor.hpp>
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053018#include <boost/asio/io_context.hpp>
19#include <boost/asio/steady_timer.hpp>
20#include <sdbusplus/asio/connection.hpp>
21#include <sdbusplus/asio/object_server.hpp>
22
23#include <chrono>
24#include <cstdint>
25#include <memory>
26#include <string>
Harshit Aghera5e7decc2025-05-07 16:20:16 +053027#include <vector>
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053028
29class GpuDevice
30{
31 public:
32 GpuDevice(const SensorConfigs& configs, const std::string& name,
33 const std::string& path,
34 const std::shared_ptr<sdbusplus::asio::connection>& conn,
35 uint8_t eid, boost::asio::io_context& io,
36 mctp::MctpRequester& mctpRequester,
37 sdbusplus::asio::object_server& objectServer);
38
39 const std::string& getPath() const
40 {
41 return path;
42 }
43
44 private:
45 void makeSensors();
46
47 void read();
48
Harshit Aghera5e7decc2025-05-07 16:20:16 +053049 void processTLimitThresholds(uint8_t rc,
50 const std::vector<int32_t>& thresholds);
51
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053052 uint8_t eid{};
53
54 std::chrono::milliseconds sensorPollMs;
55
56 boost::asio::steady_timer waitTimer;
57
58 mctp::MctpRequester& mctpRequester;
59
60 std::shared_ptr<sdbusplus::asio::connection> conn;
61
62 sdbusplus::asio::object_server& objectServer;
63
64 std::shared_ptr<NvidiaGpuTempSensor> tempSensor;
Harshit Agheraba138da2025-05-05 12:26:35 +053065 std::shared_ptr<NvidiaGpuTempSensor> tLimitSensor;
Harshit Agherab10a67b2025-05-27 12:19:29 +053066 std::shared_ptr<NvidiaGpuTempSensor> dramTempSensor;
Harshit Aghera902c6492025-05-08 15:57:42 +053067 std::shared_ptr<NvidiaGpuPowerSensor> powerSensor;
Harshit Aghera6b712322025-07-31 19:25:12 +053068 std::shared_ptr<NvidiaGpuPowerPeakReading> peakPower;
Harshit Aghera775199d2025-05-27 14:20:24 +053069 std::shared_ptr<NvidiaGpuEnergySensor> energySensor;
Harshit Agherabef4d412025-05-27 14:53:56 +053070 std::shared_ptr<NvidiaGpuVoltageSensor> voltageSensor;
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053071
72 SensorConfigs configs;
73
74 std::string name;
75
76 std::string path;
Rohit PAI0a888262025-06-11 08:52:29 +053077
78 std::shared_ptr<Inventory> inventory;
Harshit Aghera4ecdfaa2025-05-22 11:35:39 +053079};