mirror of
https://github.com/AsahiLinux/m1n1
synced 2025-01-05 09:48:45 +00:00
f71397abb7
Show the calculated rate for NCO channels' output based on the present register values. Signed-off-by: Martin Povišer <povik@protonmail.com>
138 lines
4.9 KiB
Python
Executable file
138 lines
4.9 KiB
Python
Executable file
#!/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}")
|