Created
December 21, 2022 09:44
-
-
Save rmtsrc/2f5c4f8a9218d389555c7373e7750f07 to your computer and use it in GitHub Desktop.
Check if a Raspberry Pi is being throttled due to under-voltage or over-heating
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env python | |
# https://github.com/HarlemSquirrel/scripts/blob/master/rpi-check-throttling.py | |
# https://blog.mccormack.tech/shell/2019/01/05/monitoring-raspberry-pi-power-and-thermal-issues.html | |
# https://github.com/raspberrypi/firmware/commit/404dfef3b364b4533f70659eafdcefa3b68cd7ae#commitcomment-31620480 | |
# 1110000000000000010 | |
# ||| |||_ under-voltage | |
# ||| ||_ currently throttled | |
# ||| |_ arm frequency capped | |
# |||_ under-voltage has occurred since last reboot | |
# ||_ throttling has occurred since last reboot | |
# |_ arm frequency capped has occurred since last reboot | |
import subprocess | |
GET_THROTTLED_CMD = 'vcgencmd get_throttled' | |
MESSAGES = { | |
0: 'Under-voltage detected. Check your power supply (volts/amps) matches your Pis min hardware requirements', | |
1: 'ARM frequency capped', | |
2: 'Currently throttled', | |
3: 'Soft temperature limit active', | |
16: 'Under-voltage has occurred since last reboot. Check your power supply (volts/amps) matches your Pis min hardware requirements', | |
17: 'ARM frequency capped has occurred since last reboot', | |
18: 'Throttling has occurred since last reboot', | |
19: 'Soft temperature limit has occurred' | |
} | |
class Logger: | |
COLOR_ERROR = '\033[91m' | |
COLOR_SUCCESS = '\033[92m' | |
COLOR_WARNING = '\033[93m' | |
COLOR_INFO = '\033[33m' | |
COLOR_RESET = '\033[0m' | |
@classmethod | |
def error(cls, msg): | |
print(cls.COLOR_ERROR + msg + cls.COLOR_RESET) | |
@classmethod | |
def success(cls, msg): | |
print(cls.COLOR_SUCCESS + msg + cls.COLOR_RESET) | |
@classmethod | |
def warn(cls, msg): | |
print(cls.COLOR_WARNING + msg + cls.COLOR_RESET) | |
@classmethod | |
def info(cls, msg): | |
print(cls.COLOR_INFO + msg + cls.COLOR_RESET) | |
print("Checking for throttling issues since last reboot...") | |
throttled_output = subprocess.check_output(GET_THROTTLED_CMD, shell=True) | |
throttled_binary = bin(int(throttled_output.split(b'=')[1], 0)) | |
warnings = 0 | |
for position, message in MESSAGES.items(): | |
# Check for the binary digits to be "on" for each warning message | |
if len(throttled_binary) > position and throttled_binary[0 - position - 1] == '1': | |
Logger.error(message) | |
warnings += 1 | |
Logger.info(subprocess.check_output(['vcgencmd', 'measure_temp'], universal_newlines=True)) | |
if warnings == 0: | |
Logger.success("No issues detected") | |
else: | |
Logger.warn("Issues were detected") |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment