mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-07-30 13:48:07 +02:00
Add support for rockchip GPU stats (#17812)
* Set rockchip GPU name * Add support for calculating rockchip GPU load * Format consistently * Fix access error
This commit is contained in:
parent
80a13e43e9
commit
38ffe21b69
@ -175,6 +175,7 @@ class HailoAsyncInference:
|
|||||||
return self.hef.get_input_vstream_infos()[0].shape
|
return self.hef.get_input_vstream_infos()[0].shape
|
||||||
|
|
||||||
def run(self) -> None:
|
def run(self) -> None:
|
||||||
|
job = None
|
||||||
with self.infer_model.configure() as configured_infer_model:
|
with self.infer_model.configure() as configured_infer_model:
|
||||||
while True:
|
while True:
|
||||||
batch_data = self.input_store.get()
|
batch_data = self.input_store.get()
|
||||||
@ -202,6 +203,8 @@ class HailoAsyncInference:
|
|||||||
bindings_list=bindings_list,
|
bindings_list=bindings_list,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if job is not None:
|
||||||
job.wait(100)
|
job.wait(100)
|
||||||
|
|
||||||
|
|
||||||
|
@ -24,6 +24,7 @@ from frigate.util.services import (
|
|||||||
get_intel_gpu_stats,
|
get_intel_gpu_stats,
|
||||||
get_jetson_stats,
|
get_jetson_stats,
|
||||||
get_nvidia_gpu_stats,
|
get_nvidia_gpu_stats,
|
||||||
|
get_rockchip_gpu_stats,
|
||||||
get_rockchip_npu_stats,
|
get_rockchip_npu_stats,
|
||||||
is_vaapi_amd_driver,
|
is_vaapi_amd_driver,
|
||||||
)
|
)
|
||||||
@ -232,6 +233,11 @@ async def set_gpu_stats(
|
|||||||
else:
|
else:
|
||||||
stats["intel-vaapi"] = {"gpu": "", "mem": ""}
|
stats["intel-vaapi"] = {"gpu": "", "mem": ""}
|
||||||
hwaccel_errors.append(args)
|
hwaccel_errors.append(args)
|
||||||
|
elif "preset-rk" in args:
|
||||||
|
rga_usage = get_rockchip_gpu_stats()
|
||||||
|
|
||||||
|
if rga_usage:
|
||||||
|
stats["rockchip"] = rga_usage
|
||||||
elif "v4l2m2m" in args or "rpi" in args:
|
elif "v4l2m2m" in args or "rpi" in args:
|
||||||
# RPi v4l2m2m is currently not able to get usage stats
|
# RPi v4l2m2m is currently not able to get usage stats
|
||||||
stats["rpi-v4l2m2m"] = {"gpu": "", "mem": ""}
|
stats["rpi-v4l2m2m"] = {"gpu": "", "mem": ""}
|
||||||
|
@ -382,8 +382,29 @@ def get_intel_gpu_stats(sriov: bool) -> dict[str, str]:
|
|||||||
return results
|
return results
|
||||||
|
|
||||||
|
|
||||||
|
def get_rockchip_gpu_stats() -> dict[str, str]:
|
||||||
|
"""Get GPU stats using rk."""
|
||||||
|
try:
|
||||||
|
with open("/sys/kernel/debug/rkrga/load", "r") as f:
|
||||||
|
content = f.read()
|
||||||
|
except FileNotFoundError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
load_values = []
|
||||||
|
for line in content.splitlines():
|
||||||
|
match = re.search(r"load = (\d+)%", line)
|
||||||
|
if match:
|
||||||
|
load_values.append(int(match.group(1)))
|
||||||
|
|
||||||
|
if not load_values:
|
||||||
|
return None
|
||||||
|
|
||||||
|
average_load = f"{round(sum(load_values) / len(load_values), 2)}%"
|
||||||
|
return {"gpu": average_load, "mem": "-"}
|
||||||
|
|
||||||
|
|
||||||
def get_rockchip_npu_stats() -> dict[str, str]:
|
def get_rockchip_npu_stats() -> dict[str, str]:
|
||||||
"""Get stats using rk."""
|
"""Get NPU stats using rk."""
|
||||||
try:
|
try:
|
||||||
with open("/sys/kernel/debug/rknpu/load", "r") as f:
|
with open("/sys/kernel/debug/rknpu/load", "r") as f:
|
||||||
npu_output = f.read()
|
npu_output = f.read()
|
||||||
|
@ -101,6 +101,9 @@ export default function Statusbar() {
|
|||||||
case "intel-qsv":
|
case "intel-qsv":
|
||||||
gpuTitle = "Intel GPU";
|
gpuTitle = "Intel GPU";
|
||||||
break;
|
break;
|
||||||
|
case "rockchip":
|
||||||
|
gpuTitle = "Rockchip GPU";
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
gpuTitle = name;
|
gpuTitle = name;
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user