mirror of
https://github.com/AsahiLinux/m1n1
synced 2024-11-22 14:43:08 +00:00
m1n1.hw.pmu: Add SPMI PMU support for resetting the panic counter
Replace the handrolled implementation in experiments/agx_1tri.py and tools/reset_panic_counter.py. In addition reset the panic counter in reboot.py and run_guest.py. If can reboot or start guests the boot process works fine and macOS recovery needs to leave us alone. Signed-off-by: Janne Grunau <j@jannau.net>
This commit is contained in:
parent
5cea0db10d
commit
b6e9333cd6
6 changed files with 46 additions and 18 deletions
|
@ -7,11 +7,9 @@ sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
|
||||||
from m1n1.setup import *
|
from m1n1.setup import *
|
||||||
from m1n1.shell import run_shell
|
from m1n1.shell import run_shell
|
||||||
|
|
||||||
from m1n1.hw.spmi import SPMI
|
from m1n1.hw.pmu import PMU
|
||||||
|
|
||||||
s = SPMI(u, "/arm-io/nub-spmi")
|
PMU(u).reset_panic_counter()
|
||||||
leg_scrpad = 0x9f00
|
|
||||||
s.write8(15, leg_scrpad + 2, 0) # error counts
|
|
||||||
|
|
||||||
from m1n1.agx import AGX
|
from m1n1.agx import AGX
|
||||||
from m1n1.agx.context import *
|
from m1n1.agx.context import *
|
||||||
|
|
34
proxyclient/m1n1/hw/pmu.py
Normal file
34
proxyclient/m1n1/hw/pmu.py
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
# 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.spmi = SPMI(u, adt_path.rpartition('/')[0])
|
||||||
|
self.adt_path = adt_path
|
||||||
|
self.primary = getattr(u.adt[adt_path], "is-primary") == 1
|
||||||
|
|
||||||
|
def reset_panic_counter(self):
|
||||||
|
if self.primary:
|
||||||
|
leg_scrpad = self.u.adt[self.adt_path].info_leg__scrpad[0]
|
||||||
|
self.spmi.write8(15, 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")
|
|
@ -3,6 +3,8 @@ import struct
|
||||||
|
|
||||||
from ..utils import *
|
from ..utils import *
|
||||||
|
|
||||||
|
__all__ = ["SPMI"]
|
||||||
|
|
||||||
CMD_EXT_WRITE = 0x00
|
CMD_EXT_WRITE = 0x00
|
||||||
CMD_EXT_READ = 0x20
|
CMD_EXT_READ = 0x20
|
||||||
CMD_EXT_WRITEL = 0x30
|
CMD_EXT_WRITEL = 0x30
|
||||||
|
|
|
@ -4,5 +4,8 @@ import sys, pathlib
|
||||||
sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
|
sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
|
||||||
|
|
||||||
from m1n1.setup import *
|
from m1n1.setup import *
|
||||||
|
from m1n1.hw.pmu import PMU
|
||||||
|
|
||||||
|
PMU(u).reset_panic_counter()
|
||||||
|
|
||||||
p.reboot()
|
p.reboot()
|
||||||
|
|
|
@ -4,18 +4,6 @@ import sys, pathlib
|
||||||
sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
|
sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
|
||||||
|
|
||||||
from m1n1.setup import *
|
from m1n1.setup import *
|
||||||
from m1n1.hw.spmi import SPMI
|
from m1n1.hw.pmu import PMU
|
||||||
|
|
||||||
compatible = u.adt["/arm-io"].compatible[0]
|
PMU(u).reset_panic_counter()
|
||||||
|
|
||||||
if compatible == "arm-io,t6000":
|
|
||||||
s = SPMI(u, "/arm-io/nub-spmi0")
|
|
||||||
leg_scrpad = u.adt["/arm-io/nub-spmi0/spmi-mpmu"].info_leg__scrpad[0]
|
|
||||||
elif compatible == "arm-io,t8103":
|
|
||||||
s = SPMI(u, "/arm-io/nub-spmi")
|
|
||||||
leg_scrpad = u.adt["/arm-io/nub-spmi/spmi-pmu"].info_leg__scrpad[0]
|
|
||||||
else:
|
|
||||||
print(f"Unknown SoC comaptible '{compatible}'")
|
|
||||||
exit()
|
|
||||||
|
|
||||||
s.write8(15, leg_scrpad + 2, 0) # error counts
|
|
||||||
|
|
|
@ -23,6 +23,7 @@ from m1n1.proxyutils import *
|
||||||
from m1n1.utils import *
|
from m1n1.utils import *
|
||||||
from m1n1.shell import run_shell
|
from m1n1.shell import run_shell
|
||||||
from m1n1.hv import HV
|
from m1n1.hv import HV
|
||||||
|
from m1n1.hw.pmu import PMU
|
||||||
|
|
||||||
iface = UartInterface()
|
iface = UartInterface()
|
||||||
p = M1N1Proxy(iface, debug=False)
|
p = M1N1Proxy(iface, debug=False)
|
||||||
|
@ -62,6 +63,8 @@ if args.symbols:
|
||||||
symfile = args.symbols.open("rb")
|
symfile = args.symbols.open("rb")
|
||||||
hv.load_macho(args.payload.open("rb"), symfile=symfile)
|
hv.load_macho(args.payload.open("rb"), symfile=symfile)
|
||||||
|
|
||||||
|
PMU(u).reset_panic_counter()
|
||||||
|
|
||||||
for i in args.script:
|
for i in args.script:
|
||||||
try:
|
try:
|
||||||
hv.run_script(i)
|
hv.run_script(i)
|
||||||
|
|
Loading…
Reference in a new issue