summaryrefslogtreecommitdiff
path: root/kvmd/apps
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2022-04-25 15:44:00 +0300
committerMaxim Devaev <[email protected]>2022-04-25 15:44:00 +0300
commit293490298cbe5896920b338f05a8d269b47c04fd (patch)
tree539cc1b49251f0c9b3ca51c0939be8c5bbacc312 /kvmd/apps
parent2294b5a9e167d72eecfd527c2f296312c34fbf2c (diff)
report a serial number
Diffstat (limited to 'kvmd/apps')
-rw-r--r--kvmd/apps/kvmd/info/hw.py25
1 files changed, 16 insertions, 9 deletions
diff --git a/kvmd/apps/kvmd/info/hw.py b/kvmd/apps/kvmd/info/hw.py
index 9a4d0c53..aac21c15 100644
--- a/kvmd/apps/kvmd/info/hw.py
+++ b/kvmd/apps/kvmd/info/hw.py
@@ -20,6 +20,7 @@
# ========================================================================== #
+import os
import asyncio
from typing import List
@@ -53,9 +54,12 @@ class HwInfoSubmanager(BaseInfoSubmanager):
self.__vcgencmd_cmd = vcgencmd_cmd
self.__state_poll = state_poll
+ self.__dt_cache: Dict[str, str] = {}
+
async def get_state(self) -> Dict:
- (model, cpu_temp, throttling) = await asyncio.gather(
- self.__get_dt_model(),
+ (model, serial, cpu_temp, throttling) = await asyncio.gather(
+ self.__read_dt_file("model"),
+ self.__read_dt_file("serial-number"),
self.__get_cpu_temp(),
self.__get_throttling(),
)
@@ -63,6 +67,7 @@ class HwInfoSubmanager(BaseInfoSubmanager):
"platform": {
"type": "rpi",
"base": model,
+ "serial": serial,
},
"health": {
"temp": {
@@ -83,13 +88,15 @@ class HwInfoSubmanager(BaseInfoSubmanager):
# =====
- async def __get_dt_model(self) -> Optional[str]:
- model_path = f"{env.PROCFS_PREFIX}/proc/device-tree/model"
- try:
- return (await aiofs.read(model_path)).strip(" \t\r\n\0")
- except Exception as err:
- get_logger(0).error("Can't read DT model from %s: %s", model_path, err)
- return None
+ async def __read_dt_file(self, name: str) -> Optional[str]:
+ if name not in self.__dt_cache:
+ path = os.path.join(f"{env.PROCFS_PREFIX}/proc/device-tree", name)
+ try:
+ self.__dt_cache[name] = (await aiofs.read(path)).strip(" \t\r\n\0")
+ except Exception as err:
+ get_logger(0).error("Can't read DT %s from %s: %s", name, path, err)
+ return None
+ return self.__dt_cache[name]
async def __get_cpu_temp(self) -> Optional[float]:
temp_path = f"{env.SYSFS_PREFIX}/sys/class/thermal/thermal_zone0/temp"