m1n1/proxyclient/tools/dump_pmgr.py

139 lines
4.9 KiB
Python
Raw Permalink Normal View History

#!/usr/bin/env python3
# SPDX-License-Identifier: MIT
import sys, pathlib
sys.path.append(str(pathlib.Path(__file__).resolve().parents[1]))
from m1n1 import adt
from m1n1.setup import *
from m1n1.hw.nco import NCO
dt = u.adt
pmgr = dt["/arm-io/pmgr"]
dev_by_id = {dev.id: dev for dev in pmgr.devices}
pd_by_id = {pd.id: pd for pd in pmgr.power_domains}
clk_by_id = {clk.id: clk for clk in pmgr.clocks}
print("=== PS Regs ===")
for i, r in enumerate(pmgr.ps_regs):
print(f" #{i:2d} reg: {r.reg} off: {r.offset:05x} mask:{r.mask:08x}")
print()
print("=== Perf Regs ===")
for i, r in enumerate(pmgr.perf_regs):
print(f" #{i:2d} reg: {r.reg} off: {r.offset:05x} size:{r.size:05x} unk:{r.unk:08x}")
print()
print("=== PWR Gate Regs ===")
for i, r in enumerate(pmgr.pwrgate_regs):
print(f" #{i:2d} reg: {r.reg} off: {r.offset:05x} mask:{r.mask:08x} unk:{r.unk:08x}")
clock_users = {}
dev_users = {}
for dev in dt["/arm-io"]:
if hasattr(dev, "clock_ids") and dev.clock_ids:
for i, clk in enumerate(dev.clock_ids):
clock_users.setdefault(clk, []).append(f"{dev._path}.clk[{i}]")
if hasattr(dev, "clock_gates") and dev.clock_gates:
for i, pdev in enumerate(dev.clock_gates):
dev_users.setdefault(pdev, []).append(f"{dev._path}.clkgate[{i}]")
if hasattr(dev, "power_gates") and dev.power_gates:
for i, pdev in enumerate(dev.power_gates):
dev_users.setdefault(pdev, []).append(f"{dev._path}.pwrgate[{i}]")
print()
print("=== Devices ===")
for i, dev in enumerate(pmgr.devices):
flags = ", ".join(k for k in dev.flags if k[0] != "_" and dev.flags[k])
s = f" #{i:3d} {dev.name:20s} id: {dev.id:3d} psreg: {dev.psreg:2d}:{dev.psidx:2d} "
s += f" flags: {flags:24s} unk1_0: {dev.unk1_0} unk1_1: {dev.unk1_1} unk1_2: {dev.unk1_2} "
s += f" perf_reg: {dev.perf_block}:{dev.perf_idx:#04x} unk3: {dev.unk3:3d} {dev.unk2_0:2d} {dev.ps_cfg16:2d} {dev.unk2_3:3d}"
if not dev.flags.no_ps:
ps = pmgr.ps_regs[dev.psreg]
addr = pmgr.get_reg(ps.reg)[0] + ps.offset + dev.psidx * 8
val = p.read32(addr)
s += f" @ {addr:#x} = {val:#010x}"
else:
s += f" @ "
if dev.pd:
pd = pd_by_id[dev.pd]
s += f" pd: {pd.name:20s}"
else:
s += " "
if any(dev.parents):
s += " parents: " + ", ".join(dev_by_id[idx].name if idx in dev_by_id else f"#{idx}" for idx in dev.parents if idx)
print(s)
for i in dev_users.get(dev.id, []):
print(f" User: {i}")
print()
print("=== Clocks ===")
for i, clk in enumerate(pmgr.clocks):
perf = pmgr.perf_regs[clk.perf_block]
reg = pmgr.get_reg(perf.reg)[0] + 0x100 + clk.perf_idx * 0x10
print(f" #{i:3d} {clk.name:20s} id: {clk.id:3d} reg:{clk.perf_block}:{clk.perf_idx:#4x} ({reg:#x}) {clk.unk:#x}")
print()
print("=== Power Domains ===")
for i, pd in enumerate(pmgr.power_domains):
perf = pmgr.perf_regs[pd.perf_block]
reg = pmgr.get_reg(perf.reg)[0] + 0x100 + pd.perf_idx * 0x10
print(f" #{i:3d} {pd.name:20s} id: {pd.id:3d} reg:{pd.perf_block}:{pd.perf_idx:#4x} ({reg:#x})")
print()
print("=== Events ===")
for i, ev in enumerate(pmgr.events):
perf = pmgr.perf_regs[ev.perf_block]
reg = pmgr.get_reg(perf.reg)[0] + 0x100 + ev.perf_idx * 0x10
v = f" #{i:3d} {ev.name:20s} unk:{ev.unk1:#3x}/{ev.unk2}/{ev.unk3} id: {ev.id:3d} reg:{ev.perf_block}:{ev.perf_idx:#4x} ({reg:#x})"
if ev.perf2_idx:
perf2 = pmgr.perf_regs[ev.perf2_block]
reg2 = pmgr.get_reg(perf2.reg)[0] + 0x100 + ev.perf2_idx * 0x10
v += f" reg2:{ev.perf2_block}:{ev.perf2_idx:#4x} ({reg2:#x})"
print(v)
arm_io = dt["/arm-io"]
print()
print("=== Fixed clocks ===")
for clk in range(256):
users = clock_users.get(clk, [])
if users:
print(f" #{clk}")
for j in users:
print(f" User: {j}")
print()
print("=== Boot clocks ===")
for i, (freq, reg, nclk) in enumerate(zip(arm_io.clock_frequencies,
arm_io.clock_frequencies_regs,
arm_io.clock_frequencies_nclk)):
v = ""
clk_type = reg >> 56
reg = reg & 0xFFFFFFFFFFFFFF
if clk_type == 0x9c:
v = f"fixed: {reg}"
elif clk_type in (0xa0, 0xa1, 0xa4, 0xa5):
v = f"regval: {p.read32(reg):#x}"
elif clk_type == 0xa8:
regvals = [p.read32(reg+off*4) for off in range(5)]
try:
# we are using the freq value from ADT as fin of NCO,
# that's not exactly correct
nco_freq = NCO.calc_rate(freq, regvals)
except ValueError as e:
nco_freq = 0
v = f"nco: (calculated rate: {nco_freq:d}) "
for val in regvals:
v += f"{val:#x} "
print(f"#{i:3}: {freq:10d} {nclk} {clk_type:#x}/{reg:#x}: {v}")
for j in clock_users.get(i + 256, []):
print(f" User: {j}")