summaryrefslogtreecommitdiff
path: root/tools/proxyclient/m1n1/hw/pmu.py
blob: b545df4e7b95f5564137bef2710f5bf361887bff (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# SPDX-License-Identifier: MIT
import struct

from ..utils import *
from .spmi import SPMI

__all__ = ["PMU"]

class PMU:

    def __init__(self, u, adt_path=None):
        self.u = u
        if adt_path is None:
            adt_path = PMU.find_primary_pmu(u.adt)

        self.node = u.adt[adt_path]
        self.spmi = SPMI(u, adt_path.rpartition('/')[0])
        self.adt_path = adt_path
        self.primary = u.adt[adt_path].is_primary == 1
        self.reg = u.adt[adt_path].reg[0]

    def reset_panic_counter(self):
        if self.primary:
            leg_scrpad = self.node.info_leg__scrpad[0]
            self.spmi.write8(self.reg, leg_scrpad + 2, 0) # error counts

    @staticmethod
    def find_primary_pmu(adt):
        for child in adt["/arm-io"]:
            if child.name.startswith("nub-spmi"):
                for pmu in child:
                    compat = getattr(pmu, "compatible")[0] if hasattr(pmu, "compatible") else "unset"
                    primary = (getattr(pmu, "is-primary") == 1) if hasattr(pmu, "is-primary")  else False
                    if compat == "pmu,spmi" and primary:
                        return pmu._path.removeprefix('/device-tree')
        raise KeyError(f"primary 'pmu,spmi' node not found")